js中关于array的常用方法

最近总结了一些关于array中的常用方法,

其中大部分的方法来自于《JavaScript框架设计》这本书,

如果有更好的方法,或者有关于string的别的常用的方法,希望大家不吝赐教。

直接上代码:

  1 /**
  2  * 判定数组是否包含指定目标
  3  * @param target
  4  * @param item
  5  * @returns {boolean}
  6  */
  7 function contains(target,item) {
  8     return target.indexOf(item) > -1;
  9 }
 10
 11 /**
 12  * 移除数组中指定位置的元素,返回布尔表示成功与否
 13  * @param target
 14  * @param index
 15  * @returns {boolean}
 16  */
 17 function removeAt(target,index) {
 18     return !!target.splice(index,1).length;
 19 }
 20
 21 /**
 22  * 移除数组中第一个匹配传参的那个元素,返回布尔表示成功与否
 23  * @param target
 24  * @param item
 25  * @returns {boolean}
 26  */
 27 function remove(target,item) {
 28     const index = target.indexOf(item);
 29     if (~index) {
 30         return removeAt(target,index);
 31     }
 32     return false;
 33 }
 34
 35 /**
 36  * 对数组进行洗牌
 37  * @param array
 38  * @returns {array}
 39  */
 40 function shuffle(array) {
 41     let m = array.length, t, i;
 42     // While there remain elements to shuffle…
 43     while (m) {
 44         // Pick a remaining element…
 45         i = Math.floor(Math.random() * m--);
 46
 47         // And swap it with the current element.
 48         t = array[m];
 49         array[m] = array[i];
 50         array[i] = t;
 51     }
 52     return array;
 53 }
 54
 55 /**
 56  * 从数组中随机抽选一个元素出来
 57  * @param target
 58  * @returns {*}
 59  */
 60 function random(target) {
 61     return target[Math.floor(Math.random() * target.length)];
 62 }
 63
 64 /**
 65  * 对数组进行平坦化处理,返回一个一维的新数组
 66  * @param target
 67  * @returns {Array}
 68  */
 69 function flatten (target) {
 70     let result = [];
 71     target.forEach(function(item) {
 72         if(Array.isArray(item)) {
 73             result = result.concat(flatten(item));
 74         } else {
 75             result.push(item);
 76         }
 77     });
 78     return result;
 79 }
 80
 81 /**
 82  * 去重操作,有序状态
 83  * @param target
 84  * @returns {Array}
 85  */
 86 function unique(target) {
 87     let result = [];
 88     loop: for (let i = 0,n = target.length;i < n; i++) {
 89         for (let x = i + 1;x < n;x++) {
 90             if (target[x] === target[i]) {
 91                 continue loop;
 92             }
 93         }
 94         result.push(target[i]);
 95     }
 96     return result;
 97 }
 98
 99 /**
100  * 去重操作,无序状态,效率最高
101  * @param target
102  * @returns {Array}
103  */
104 function unique1(target) {
105     let obj = {};
106     for (let i = 0,n = target.length; i < n;i++) {
107         obj[target[i]] = true;
108     }
109     return Object.keys(obj);
110 }
111
112 /**
113  * 过滤属性中的null和undefined,但不影响原数组
114  * @param target
115  * @returns {Array.<T>|*}
116  */
117 function compat(target) {
118     return target.filter(function(el) {
119         return el != null;
120     })
121 }
122
123 /**
124  * 根据指定条件(如回调或对象的某个属性)进行分组,构成对象返回。
125  * @param target
126  * @param val
127  * @returns {{}}
128  */
129 function groupBy(target,val) {
130     var result = {};
131     var iterator = isFunction(val) ? val : function(obj) {
132         return obj[val];
133     };
134     target.forEach(function(value,index) {
135         var key = iterator(value,index);
136         (result[key] || (result[key] = [])).push(value);
137     });
138     return result;
139 }
140 function isFunction(obj){
141     return Object.prototype.toString.call(obj) === ‘[object Function]‘;
142 }
143
144 // 例子
145 function iterator(value) {
146    if (value > 10) {
147        return ‘a‘;
148    } else if (value > 5) {
149        return ‘b‘;
150    }
151    return ‘c‘;
152 }
153 var target = [6,2,3,4,5,65,7,6,8,7,65,4,34,7,8];
154 console.log(groupBy(target,iterator));
155
156
157
158 /**
159  * 获取对象数组的每个元素的指定属性,组成数组返回
160  * @param target
161  * @param name
162  * @returns {Array}
163  */
164 function pluck(target,name) {
165     let result = [],prop;
166     target.forEach(function(item) {
167         prop = item[name];
168         if (prop != null) {
169             result.push(prop);
170         }
171     });
172     return result;
173 }
174
175 /**
176  * 根据指定条件进行排序,通常用于对象数组
177  * @param target
178  * @param fn
179  * @param scope
180  * @returns {Array}
181  */
182 function sortBy(target,fn,scope) {
183     let array = target.map(function(item,index) {
184         return {
185             el: item,
186             re: fn.call(scope,item,index)
187         };
188     }).sort(function(left,right) {
189         let a = left.re, b = right.re;
190         return a < b ? -1 : a > b ? 1 : 0;
191     });
192     return pluck(array,‘el‘);
193 }
194
195 /**
196  * 对两个数组取并集
197  * @param target
198  * @param array
199  * @returns {Array}
200  */
201 function union(target,array) {
202     return unique(target.concat(array));
203 }
204
205 /**
206  * 对两个数组取交集
207  * @param target
208  * @param array
209  * @returns {Array.<T>|*}
210  */
211 function intersect(target,array) {
212     return target.filter(function(n) {
213         return ~array.indexOf(n);
214     })
215 }
216
217 /**
218  * 返回数组中的最小值,用于数字数组
219  * @param target
220  * @returns {*}
221  */
222 function min(target) {
223     return Math.min.apply(0,target);
224 }
225
226 /**
227  * 返回数组中的最大值,用于数字数组
228  * @param target
229  * @returns {*}
230  */
231 function max(target) {
232     return Math.max.apply(0,target);
233 }

最后模拟一下数组中的pop,oush,shift和unshift的实现原理

 1 const _slice = Array.prototype.slice;
 2 Array.prototype.pop = function() {
 3     return this.splice(this.length - 1,1)[0];
 4 };
 5 Array.prototype.push = function() {
 6     this.splice.apply(this,[this.length,0].concat(_slice.call(arguments)));
 7     return this.length;
 8 };
 9 Array.prototype.shift = function() {
10     return this.splice(0,1)[0];
11 };
12 Array.prototype.unshift = function() {
13     this.splice.apply(this,
14         [0,0].concat(_slice.call(arguments)));
15     return this.length;
16 };
时间: 2024-12-17 06:59:45

js中关于array的常用方法的相关文章

JS数组去重,js中数组(Array)的排序(sort)

JS数组去重 var ddd = [1,2,4,5,2, 222,1,5,6]; var uq = {}; var rq = []; for(var i=0; i<9; i++){ if(!uq[ddd[i]]){ uq[ddd[i]] = true; rq.push(ddd[i]); } } return rq; js中数组(Array)的排序(sort)注意事项 var arrDemo = new Array(); arrDemo[0] = 10; arrDemo[1] = 50; arrD

js中数组Array的一些常用方法总结

var list = new Array()是我们在js中常常写到的代码,今天就总结一下Array的对象具有哪些方法. list[0] = 0; list[1] = 1; list[2] = 2; 或者这样声明:var list = [0,1,2]; (1) shift():  alert(list.shift()); //删除数组的第一个元素,返回删除的值.这里是0  alert(list.length); //返回的数组长度是2 (2) unshift( i , j ): list.unsh

js中数组Array的操作

JS中数组有很多操作,作为前端多多少少知道点,但每次要用时都需要去百度,有点麻烦,所以在这儿做个备忘,简单总结些平时最常用的数组操作. shift:删除原数组第一项,并返回删除元素的值: var a = [1,2,3,4,5]; var b = a.shift(); //a:[2,3,4,5] b:1 注:如果数组为空则返回undefined unshift:将参数添加到原数组开头,并返回数组的长度 var a = [1,2,3,4,5]; var b = a.unshift(-2,-1); /

js中数组的一常用方法总结

js中一切皆对象,所有对象有的方法在数组中都可以使用,下面来介绍一些常用方法 这里将来方法分为七种分别为:栈方法,队列方法,重排序方法,操作方法,位置方法,迭代方法,归并方法 一.栈方法 :模拟类似栈的LIFO(Last-In-First-Out)数据结构的一些方法 var fruits = [ "apple" ,"banana"  ] ; 1.push : 在数组的末尾插入n项 ,返回新数组长度 eg :  var count = fruits.push(&quo

JS中数组Array的用法示例介绍 (转)

new Array() new Array(len) new Array([item0,[item1,[item2,...]]] 使用数组对象的方法: var objArray=new Array(); objArray.concact([item1[,item2[,....]]]-------------------将参数列表连接到objArray的后面形成一个新的数组并返回,原有数组不受影响.如:var arr=["a","b","c"];

D3.js中对array的使用

由于D3类库和array密切相关,我们有必要讨论一下D3中的数据绑定以及在数组内部运算的方法. 1.D3中的数组 和其他编程语言一样,D3的数组元素可以是数字或者字符等类型,例如: someData=[20,36,48,59,600,88]; 此外,考虑json数据在网络传输中的便利性,D3数组也支持将json对象,如: someBook=[{name:"book1", price: 50}, {name:"book2", price: 150}, {name:&q

js 中 new Array() var a={} var a=[] new Object()

var a={}; new Object(); 表示定义一个空对象: new Array(); var a=[]; 表示定义一个空数组: 其他: 数组表示有序数据的集合,而对象表示无序数据的集合: 在Javascript语言中,关联数组就是对象,对象就是关联数组.这一点与php语言完全不同,在php中,关联数组也是数组. 单个对象是没有length属性的,所以不能a.length求长度:数组可以:

js中的Array()

//数组的声明方式 var arr=[0,1,2,3,4,5]; var arr1= new Array();  arr1[0]='6';      arr1[1]='7';      arr1[2]='8';      arr1[3]='9';      arr1[4]='10';     var arr2=new Array(11,12,13); var arr3=new Array(1);   arr3[0]='14';      //数组链接concat();   document.wr

js中数组Array对象的方法sort()的应用

一. sort()方法的介绍 //给一组数据排序 var arrNum = [12,1,9,23,56,100,88,66]; console.log("排序前的数组:"+arrNum); arrNum.sort();//默认按照字母排序 console.log("排序后的数组:"+arrNum); //对数组进行升序排列,将函数作为参数传入 arrNum.sort(function (a,b) { return a-b;//数组中两两比较,结果为正(a>b)