来做一个关于这些方法的合集
数组克隆
第一种
var arr = [1, 2, 3, 4, 5];
var resArr = [];
for(var i = 0; i < arr.length; i++) {
resArr.push(arr[i]);
}
第二种
var arr = [1, 2, 3, 4, 5];
var resArr = arr.concat();
第三种
var arr = [1, 2, 3, 4, 5];
var resArr = arr.slice();
数组去重
第一种
function unique(arr) {
var res = [];
for(var i = 0; i < arr.length; i++) {
var item = arr[i];
if(res.indexOf(item) === -1) {
res.push(item);
}
}
return res;
}
第二种
function unique(arr) {
var res = [];
var hash = [];
for(var i = 0;i < arr.length; i++) {
var item = arr[i];
var key = typeof(item) + item;
if(hash[key] !== 1) {
res.push(item);
hash[key] = 1;
}
}
return res;
}
上面这种方法是我参考别人的,我并不是特别理解……….
数组排序
第一种 冒泡法
var num = 0;
for(var i = 0; i < arr.length; i++) {
if(arr[i] > arr[i+1]) {
num = arr[i];
arr[i] = arr[i+1];
arr[i+1] = num;
}
}
第二种 sort()
arr.sort(function sortNumber(a, b){
return a - b;
})
寻找最多字符
第一种
function getMost(str) {
var maxNum = 0;
var maxChar = [];
while(str) {
var char = str.charAt(0);
var arr = str.split(char);
n = str.length - arr.join('').length;
str = arr.join('');
if(n > maxNum) {
maxNum = n;
maxChar = [char];
} else if(n === maxNum) {
maxChar.push(char);
}
}
return {'maxNum':maxNum, 'maxChar':maxChar};
}
第二种
var str = 'dsfshkafjaoiurwjroijasdifui';
var arr = str.split('');
arr = arr.sort();
str = arr.join('');
var reg = /(\w)\1+/g;
var num = 0;
var value = null;
str.replace(reg, function($0, $1) {
if(num < $0.length) {
num = $0.length;
value = $1;
}
});
// value为最多的字符,num表示次数
寻找最多字符的方法来源于
h5学堂