国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 開發(fā) > JS > 正文

JavaScript數(shù)組去重的多種方法(四種)

2024-05-06 16:39:46
字體:
供稿:網(wǎng)友

數(shù)組去重,一般需求是給你一個(gè)數(shù)組,調(diào)用去重方法,返回?cái)?shù)值副本,副本中沒有重復(fù)元素。一般來說,兩個(gè)元素通過 === 比較返回 true 的視為相同元素,需要去重,所以,1 和 "1" 是不同的元素,1 和 new Number(1) 是不同的元素,{} 和 {} 是不同的元素(引用不同)。(當(dāng)然如果需求認(rèn)為 {} 和 {} 算作相同的元素,那么解法就不一樣了)

method 1

使用兩重循環(huán)

function unique(arr) { var res = []; for(var i = 0, len = arr.length;i < len; i++) {  var item = arr[i];  for(var j = 0, jLen = res.length; j<jLen; j++) {   if(item == res[j]) break;  }  if(j == jLen) res.push(item); } return res;}

method 2

function unique(arr) { var ret = [] for (var i = 0; i < arr.length; i++) { var item = arr[i] if (ret.indexOf(item) === -1) {  ret.push(item) } } return ret}

這里判斷可以使用一個(gè)語法糖

function unique(arr) { var res = []; for(var i = 0, len = arr.length;i < len; i++) {  var item = arr[i];  (res.indexOf(item) === -1) && res.push(item); } return res;}

但是在低版本瀏覽器并沒有 indexOf

var indexOf = [].indexOf ? function(arr, item) {  return arr.indexOf(item) } : function indexOf(arr, item) {  for (var i = 0; i < arr.length; i++) {  if (arr[i] === item) {   return i  }  }  return -1 }function unique(arr) { var ret = [] for (var i = 0; i < arr.length; i++) { var item = arr[i] if (indexOf(ret, item) === -1) {  ret.push(item) } } return ret}

method3

使用兩重循環(huán)的另外一種比較方式,前面是將原數(shù)組的元素和結(jié)果數(shù)組一一比較,下面我們可以將原數(shù)組的重復(fù)元素的最后一個(gè)元素放入數(shù)組中

function unique(arr) { var ret = []; var len = arr.length; var isRepeat; for(var i=0; i<len; i++) {  isRepeat = false;  for(var j=i+1; j<len; j++) {   if(arr[i] === arr[j]){    isRepeat = true;    break;   }  }  if(!isRepeat){   ret.push(arr[i]);  } } return ret;}

這里還有一個(gè)優(yōu)化的版本

function unique(a) { var res = []; for (var i = 0, len = a.length; i < len; i++) { for (var j = i + 1; j < len; j++) {  // 這一步十分巧妙  // 如果發(fā)現(xiàn)相同元素  // 則 i 自增進(jìn)入下一個(gè)循環(huán)比較  if (a[i] === a[j])  j = ++i; //j = i = i + 1; } res.push(a[i]); } return res;}

method4

用 javascript 中的 object 對(duì)象來當(dāng)作 哈希表

function dedup(arr) { var hashTable = {}; return arr.filter(function(value,index,arr){  var key = JSON.stringify(value);  var match = Boolean(hashTable[key]);  return (match ? false : hashTable[key] = true); });}

因?yàn)?Object 的 key 值都是 String 類型,所以對(duì)于 1 和 "1" 無法分別,我們可以稍微改進(jìn)下,將類型也存入 key 中

function dedup(arr) { var ret = []; var hash = {}; for(var i = 0; i < arr.length; i++) {  var item = arr[i];  var key = typeof(item) + item;  if(hash[key] !== 1) {   ret.push(item)   hash[key] = 1;  } } return ret;}

總結(jié)

以上所述是小編給大家介紹的JavaScript數(shù)組去重的多種方法(四種),希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)VeVb武林網(wǎng)網(wǎng)站的支持!


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到JavaScript/Ajax教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 濮阳市| 长子县| 年辖:市辖区| 神木县| 武乡县| 银川市| 民勤县| 千阳县| 璧山县| 安庆市| 定西市| 萍乡市| 会理县| 天镇县| 前郭尔| 丰县| 大庆市| 砀山县| 霍州市| 西盟| 肇庆市| 文化| 东阿县| 松阳县| 保亭| 二连浩特市| 铜川市| 九台市| 松溪县| 鹤山市| 马关县| 临夏市| 高碑店市| 绍兴市| 太原市| 沙坪坝区| 凤翔县| 清水河县| 阿坝| 陕西省| 宜川县|