對於indexOf()的用法一直停留在查找第幾個字符串,殊不知道它能用到數組去重中,首先仍是溫顧下indexOf()的語法:javascript
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <!-- 1.indexOf() 方法對大小寫敏感! 2.若是要檢索的字符串值沒有出現,則該方法返回-1 。 --> </head> <body> <script> /* 語法: stringObject.indexOf(searchvalue,fromindex) searchvalue:必須。規定需檢索的字符串值 fromindex:可選的整數參數。規定在字符串中開始檢索的位置。它的合法取值是 0 到 stringObject.length -1。如省略該參數,則將從字符串的首字符開始檢索。 說明 該方法將從頭至尾地檢索字符串 stringObject,看它是否含有子串 searchvalue。開始檢索的位置在字符串的 fromindex 處或字符串的開頭(沒有指定 fromindex 時)。若是找到一個 searchvalue,則返回 searchvalue 的第一次出現的位置。stringObject 中的字符位置是從 0 開始的。 提示和註釋 註釋:indexOf() 方法對大小寫敏感! 註釋:若是要檢索的字符串值沒有出現,則該方法返回 -1。 實例: */ var str="Hello world!" document.write(str.indexOf("Hello") + "<br />"); document.write(str.indexOf("World") + "<br />"); document.write(str.indexOf("world")); /* 以上代碼的輸出: 0 -1 6 */ </script> </body> </html>
下面見證奇蹟的時刻 數組去重的用法:html
/*寫法一:*/ var arr = ['C','A','A','G','G','G','D'] var newArr = [] arr = arr.sort(function(a,b){ return a > b }).forEach(function(n){ if(newArr.indexOf(n) == -1){ newArr.push(n) } }) console.log(newArr);// ["A", "C", "D", "G"]
/*寫法二:*/ var arr = ['a','c','b','d','a','b'] var arr2 = []; for(var i = 0;i<arr.length;i++){ if(arr2.indexOf(arr[i])<0){ arr2.push(arr[i]); } } arr2.sort(); console.log(arr2);//["a", "b", "c", "d"]