首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

格式化js对象的长数组,将日期与数字、颜色与月份、日期与数字以及各自的颜色分隔开

,可以通过以下步骤实现:

  1. 遍历数组中的每个对象。
  2. 根据对象的属性类型进行分类,将日期与数字、颜色与月份分别存放在不同的数组中。
  3. 对日期与数字数组进行排序,可以使用JavaScript的sort()方法。
  4. 对颜色与月份数组进行排序,可以使用JavaScript的sort()方法。
  5. 将排序后的日期与数字数组和颜色与月份数组合并为一个新的数组。
  6. 根据新数组中的元素类型,将日期与数字、颜色与月份以及各自的颜色分隔开。
  7. 最后得到格式化后的数组。

以下是一个示例代码:

代码语言:txt
复制
// 假设原始数组为data
var data = [
  { value: 10, type: 'number' },
  { value: 'blue', type: 'color' },
  { value: '2022-01-01', type: 'date' },
  { value: 'red', type: 'color' },
  { value: 20, type: 'number' },
  { value: '2022-02-01', type: 'date' },
];

// 分类存放日期与数字、颜色与月份
var dateAndNumber = [];
var colorAndMonth = [];

data.forEach(function(obj) {
  if (obj.type === 'date' || obj.type === 'number') {
    dateAndNumber.push(obj.value);
  } else if (obj.type === 'color' || obj.type === 'month') {
    colorAndMonth.push(obj.value);
  }
});

// 对日期与数字数组进行排序
dateAndNumber.sort();

// 对颜色与月份数组进行排序
colorAndMonth.sort();

// 合并排序后的数组
var formattedArray = dateAndNumber.concat(colorAndMonth);

// 根据元素类型分隔开
var separatedArray = [];
var currentDateAndNumber = [];
var currentColorAndMonth = [];

formattedArray.forEach(function(value) {
  if (typeof value === 'number' || !isNaN(Date.parse(value))) {
    currentDateAndNumber.push(value);
  } else {
    currentColorAndMonth.push(value);
  }
});

separatedArray.push(currentDateAndNumber);
separatedArray.push(currentColorAndMonth);

console.log(separatedArray);

这样,separatedArray就是格式化后的数组,其中包含了按照日期与数字、颜色与月份以及各自的颜色分隔开的元素。

关于腾讯云相关产品和产品介绍链接地址,由于要求不能提及具体的云计算品牌商,无法给出相关链接。但腾讯云提供了丰富的云计算服务,可以根据具体需求在腾讯云官网上查找相关产品和文档。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 由浅入深,走进中级工程师都未必知道的 JavaScript 时间处理冷知识

    在过去,世界各地都各自订定当地时间,例如我国古代将一昼夜分为十二时辰,每一时辰相当于现代的两个小时。但随着交通和通信的发达,各地交流日益频繁,不同的地方时间给人们造成了许多困扰。于是在1884年的国际经度会议上制定了全球性的标准时,确定以英国伦敦格林威治区这个地方为零度经线的起点(本初子午线),并以地球由西向东每24小时自转一周360°,规定经度每隔15°,时差1小时,而每15°的经线则称为该时区的中央经线。全球被划分为24个时区,其中包含23个整时区及180°经线左右两侧的2个半时区。东经的时间比西经要早,也就是如果格林威治时间是中午12时,则中央经线15°E的时区为下午1时,中央经线30°E时区的时间为下午2时;反之,中央经线15°W的时区时间为上午11时,中央经线30°W时区的时间为上午10时。如果两人同时从格林威治的0°各往东、西方前进,当他们在经线180°时,就会相差24小时,所以经线180°被定为国际换日线,由西向东通过此线时日期要减去一日,反之,若由东向西则增加一日。

    01

    Java String.format 方法使用介绍

    String类,在JDK1.5中增加了一个非常有用的静态函数format(String  format, Objece...  argues),可以将各类数据格式化为字符串并输出。其中format参数指定了输出的格式,是最复杂也是最难掌握的一点,而argues则是一系列等待被格式化的对象。该函数对c语言中printf函数的用法进行了一定的模仿,因此有c语言基础的人学起来会轻松许多。下面我们着重讨论一下format 参数的格式及含义。          format参数中可以包含不需要转化的字符串,这些字符串是你写什么,最终就输出什么。同时还包含一些特殊格式的内容,来指定将哪个对象来转换,以及转换成什么形式。这种特殊的格式通通以 %index$ 开头,index从1开始取值,表示将第index个参数拿进来进行格式化。这一点比c语言要强一点, c语言只能按照参数的顺序依次格式化,而java可以选择第n个参数来格式化。由于该函数可以对任意一个对象进行格式化,不同的对象适用的参数也不同,因此我们下面分类来讨论。

    03

    awk 简明教程

    awk是一种编程语言,用于在linux/unix下对文本和数据进行处理。 数据可以来自标准输入、一个或多个文件,或其它命令的输出。 它支持用户自定义函数和动态正则表达式等先进功能,是linux/unix下的一个强大编程工具。 它在命令行中使用,但更多是作为脚本来使用。 awk 的处理文本和数据的方式是这样的,它逐行扫描文件,从第一行到最后一行,寻找匹配的特定模式的行,并在这些行上进行你想要的操作如果没有指定处理动作,则把匹配的行显示到标准输出(屏幕),如果没有指定模式,则所有被操作所指定的行都被处理。 awk 分别代表其作者姓氏的第一个字母因为它的作者是三个人,分别是 Alfred Aho、Brian Kernighan、Peter Weinberger。 gawk是awk的GNU版本,它提供了 Bell 实验室和 GNU 的一些扩展。

    02

    java学习与应用(4.6)--过滤器、监听器、JQuery、AJAX、JSON等

    Filter过滤器:客户端在请求服务器资源前和返回响应,会通过过滤器,以拦截请求完成特殊功能。登录校验、统一编码校验等一些通用操作放置到过滤器。 定义类实现接口Filter(javax.servlet),复写方法(init(服务器启动调用),doFilter(写入FilterChain.doFilter进入方法放行,之后的代码为返回响应执行的信息),destory(服务器关闭前执行)),配置拦截路径(@WebFilter(/*为所有资源都拦截))。 web.xml配置(WEB_INF下),配置filter标签下的filter-name,filter-class。配置filter-mapping标签下url-pattern,filter-name。也可直接用注解@WebFilter配置即可。 配置详解:拦截路径配置(具体资源路径、目录/xxx/*、后缀*.jsp,所有资源/*等)。 配置符合请求方式访问资源前进行的拦截(REQUEST浏览器直接请求,FORWARD转发访问资源,INCLUDE包含访问资源,ERROR跳转资源,ASYNC异步访问资源),使用注解的dispatcherType(可传入数组)。 也可配置web.xml的dispatcher标签拦截符合条件的资源被访问方式。 过滤器链(多个过滤器),资源进入通过的过滤器和返回的顺序相反。使用注解:过滤器执行的先后使用类名字符串比较(如AFilter,BFilter等)顺序执行。使用web.xml:filter-mapping的先后顺序执行 设置登录校验,可以在Filter中对指定页面校验session值判断放行和跳转等。敏感词汇过滤:使用装饰模式、代理模式等来增强request。在代理模式中使用代理对象代理真实对象达到增强真实对象,代理中增强返回值为。 静态代理使用类文件描述代理模式,动态代理在内存中形成代理类。代理对象和真实对象实现相同接口,使用Proxy的newInstance获取代理对象(传入如:lenovo. getClass(). getClassLoader(), lenovo. getClass(). getInterfaces(), new InvocationHandler( ),然后重写invoke),使用代理对象获取真实。 proxy为代理对象,method为代理对象被调用的方法,args为被调用时传递的参数。invoke中写入Object obj=method.invoke(xxx,args);return obj方式增强真实对象。通过修改代理传入的参数,返回值,和方法体,进行增强和修改。

    01
    领券