美文网首页
对数组列表中对象排重

对数组列表中对象排重

作者: 如风_周 | 来源:发表于2017-01-03 20:43 被阅读35次

2种格式数据排重

一、对数组中对象直接排重,序号据用","分割

/**
 * 对数组中对象的某一个属性进行排重
 * 实现原理: 新建2个数组,一个保存去重后的数据(List),一个保存属性(key),遍历data数组,查找List数组中
 *是否存在key的值,如果存在,对序号进行处理,不存在就保存在List中,输出List
 * [listPaiChong 数据排重]
 * @param  {[type]} data [要排重的数组]
 * @param  {[type]} key  [数组对象中属性]
 * @return {[type]}      [Array]
 */
function listPaiChong(data, key) {
    var List = []; // 去重后的数据
    var item = []; //临时保存的数据(key的值)
    for (var i = 0; i < data.length; i++) {
        var value = item.indexOf(data[i][key]);
        if (value === -1) {
            item.push(data[i][key]);
            List.push(data[i]);
        } else {
            //取最早的重复数据
            var number = List[value].NUMBER; //保存重复的序号
            List[value].NUMBER = number + "," + List[value].NUMBER;
        }
    }
    return List;
}

二、数据排重为特定格式

var testS = "1,2,3,5,7,9,14,15,16,17,19,21,22,24,26,27,29,30,32,33,34,37";
console.log(testS);
var testArray = testS.split(",");
var resultArray = ["0"];
for (var i = 0; i < testArray.length; i++) {
    var index = parseInt(testArray[i]),
        resultLastIndex = resultArray[resultArray.length - 1];
    if (resultLastIndex.indexOf("-") > 0) {
        var resultLastIndexArray = resultLastIndex.split("-");
        resultLastIndex = resultLastIndexArray[resultLastIndexArray.length - 1];
        if (index - (parseInt(resultLastIndex)) === 1) {
            resultArray[resultArray.length - 1] = resultLastIndexArray[0] + "-" + index;
        } else {
            resultArray.push(index.toString());
        }
    } else {
        if (index - (parseInt(resultLastIndex)) === 1) {
            resultArray[resultArray.length - 1] = resultLastIndex + "-" + index;
        } else {
            resultArray.push(index.toString());
        }
    }
}
if (resultArray[0].indexOf("0-") === 0) {
    var headArray = resultArray[0].split("-");
    for (var i = 0; i < testArray.length - 1; i++) {
        if (parseInt(testArray[i]) > parseInt(headArray[0]) && parseInt(testArray[i]) <= parseInt(headArray[1])) {
            resultArray[0] = parseInt(testArray[i]) === parseInt(headArray[1]) ? headArray[1] : testArray[i] + "-" + headArray[1]
            break;
        }
    }
} else {
    resultArray.splice(0, 1);
}
console.log(resultArray.join(","));

相关文章

  • 对数组列表中对象排重

    2种格式数据排重 一、对数组中对象直接排重,序号据用","分割 二、数据排重为特定格式

  • 数组去重的几种方式

    上篇我们写到了数组中包含多条对象的去重方式数组中包含多条对象的去重方式,今天我们就写一下普通数组去重吧. 数组去重...

  • JS使用reduce方法数组去重原理解析

    初始化数据结构如下: 根据数组元素对象中name属性来为数组去重 obj 对象中存储的必须是键值对(这样容易判断对...

  • HZ数组对象去重

    // 根据数组对象中属性去重 思路:在原数组对象中 直接捡出 不重复的 数组对象, 过程:1.获取不重复的属性数组...

  • js中数组对象去重的方法

    采用数组中的reduce方法,遍历数组,也是通过对象访问属性的方法 参考js中数组对象去重的方法

  • 内置对象——可索引的集合对象Array

    在Javascript中Array是用于构造数组的全局对象,数组是类似于列表的高阶对象。 语法:```[eleme...

  • 数组对象去重方法:

    数组对象去重方法: // 数组对象去重 ```` toRetry = (arr = []) => { let re...

  • 2-5 列表渲染

    列表渲染将列表的内容拼装成数组,放置到模板当中将数据拼装成数组 JSX 对象 使用 数组的 map 方法,对每一项...

  • 实现数组去重有哪些方式

    简单的数组去重 数组对象去重

  • js数组去重、对象数组去重

    普通数组去重 一、普通数组去重 方法一:遍历数组法 方法二:排序法 方法三:对象法 对象数组去重 方法一:将对象数...

网友评论

      本文标题:对数组列表中对象排重

      本文链接:https://www.haomeiwen.com/subject/mkamvttx.html