對於indexOf()的用法一直停留在查找第幾個字符串,卻不知道它能用到數組去重中,首先還是溫顧下indexOf()的語法:
<!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>
下面見證奇跡的時刻 數組去重的用法:
/*寫法一:*/
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"]
