核心提示:html开发中三种好用的数组去重方法解析。 var a = [5,6,5,4,3,{},3,字符]方法一:建立新数组,利用indexOf判断是否存在于新数组中,不存在则push到新数组,最后返回新数组...
html开发中三种好用的数组去重方法解析。
var a = [5,6,5,4,'3',{},3,'字符']
方法一:建立新数组,利用indexOf判断是否存在于新数组中,不存在则push到新数组,最后返回新数组。
function unique0() { let ret = []; for(let i = 0;len = a.length,i < len;i ++){ if(ret.indexOf(a[i]) === -1){ ret.push(a[i]) } } return ret } console.log(unique0(a))
方法二:利用object对象保存数组值,判断数组值是否已经保存在object中,未保存则push到新数组并用object[key]=1的方式记录保存。
function unique1(a) { let ret = []; let hash = {}; for(let i = 0;len = a.length,i < len ;i ++){ let key = typeof a[i] + a[i]//数据类型判断,避免隐式类型换 if(!hash[key]){ hash[key] = 1; ret.push(a[i]) } } return ret } console.log(unique1(a))
方法三:ES6:set(新的数据结构,类似于数组,但是成员的值都是唯一的,没有重复的值。),新方法Array.from(Array增加了from函数用来将其他对象转换成数组)。
function unique2(a) { let ret = new Set(a) return Array.from(ret) } console.log(unique2(a))