Ⅰ es6如何快速的删除数组元素
这就是数组去重了。。专属。
var str=['hello','node','element','node','hello','blue','red'];
var str1=[];
function first(args){
for(i=0;i<args.length;i++){
if(str1.indexOf(args[i])<0){
str1.push(args[i])
}
}
return str1;
}
first(str);
console.log(str1)
Ⅱ es6能去除数组中重复的对象吗
这就是数组去重了。。内。容
var str=['hello','node','element','node','hello','blue','red'];
var str1=[];
function first(args){
for(i=0;i<args.length;i++){
if(str1.indexOf(args[i])<0){
str1.push(args[i])
}
}
return str1;
}
first(str);
console.log(str1)
Ⅲ ES6 数组对象的几个新方法
push() 方法可向数组的末尾添加一个或多个元素,并返回新的长度。
语法:
arrayObject.push(newelement1,newelement2,....,newelementX)
参数回:
newelement1 必需。要答添加到数组的第一个元素。
newelement2 可选。要添加到数组的第二个元素。
newelementX 可选。可添加多个元素。 实例在本例中,我们将创建一个数组,并通过添加一个元素来改变其长度:<script type="text/javascript">var arr = new Array(3)arr[0] = "George"arr[1] = "John"arr[2] = "Thomas"document.write(arr + "<br />")document.write(arr.push("James") + "<br />")document.write(arr)</script>输出:George,John,Thomas4George,John,Thomas,James
Ⅳ es6判断一个数组中是否有重复的元素
方法:
无需思考,我们可以得到 O(n^2) 复杂度的解法。定义一个变量数组 res 保存结果,遍历需要去重的数组,如果该元素已经存在在 res 中了,则说明是重复的元素,如果没有,则放入 res 中。
function unique(a) {
var res = [];
for (var i = 0, len = a.length; i < len; i++) {
var item = a[i];
for (var j = 0, jLen = res.length; j < jLen; j++) {
if (res[j] === item)
break;
}
if (j === jLen)
res.push(item);
}
return res;
}
var a = [1, 1, '1', '2', 1];
var ans = unique(a);
console.log(ans); // => [1, "1", "2"]
代码非常简单,那么是否能更简洁些?如果不考虑浏览器兼容,我们可以用 ES5 提供的 Array.prototype.indexOf 方法来简化代码。
function unique(a) {
var res = [];
for (var i = 0, len = a.length; i < len; i++) {
var item = a[i];
(res.indexOf(item) === -1) && res.push(item);
}
return res;
}
var a = [1, 1, '1', '2', 1];
var ans = unique(a);
console.log(ans); // => [1, "1", "2"]
既然用了 indexOf,那么不妨再加上 filter。
function unique(a) {
var res = a.filter(function(item, index, array) {
return array.indexOf(item) === index;
});
return res;
}
var a = [1, 1, '1', '2', 1];
var ans = unique(a);
console.log(ans); // => [1, "1", "2"]
Ⅳ es6 for of怎么获取index
如果是 Map 的 for ... of 就比较简单:
for(const[key,value]ofmap){
console.log(key,value);
}
但是你问的应该是数组。
数组的 for ... of 获取不了 index,你需要用 forEach
vararr=['a','b','c'];
arr.forEach((item,i)=>{
console.log(item,i);
});
但是其实也可以把 Array 想办法转成 Map,
newMap(arr.map((item,i)=>[i,item]))
在一行代码里面实现for ... of:
vararr=['a','b','c'];
for(let[i,item]ofnewMap(arr.map((item,i)=>[i,item]))){
console.log(i,item);
}
Ⅵ js判断某个元素是否在数组中在就返回索引位置
可以使用jquery的$.inArray(某元素,数组); 若是有此值返回此值的下标索引,没有返回-1;
或者使用原生js的indexOf返回索引(ES5还是ES6的规范)。
Ⅶ ES6数组中的几个方法
如果想将对象数组转换成map集合,需要用到es6的语法。
比如对象数组为let arr = [{a:1,b:2},{a:3,b:4}];
首先我们要获取内arr中每个对象的key和value,这里我容们可以结合map和Object.entries()两个方法来实现。
let result = [];
arr.map(o=>{
let map = new Map();
for(let [k, v] of Object.entries(o)){
map.set(k, v);
}
result.push(map);
});
最终result就是转换后的map集合了。
Ⅷ 如何把JavaScript数组中指定的一个元素移动到第一位
varfruits=["Banana","Orange","Apple","Mango"];
varstr=fruits.splice(2,1);
fruits.unshift(str[0]);
Ⅸ es6 rece方法是遍历数组吗
rece方法有两个参数,复第一个制参数是一个callback,用于针对数组项的操作;第二个参数则是传入的初始值,这个初始值用于单个数组项的操作。需要注意的是,rece方法返回值并不是数组,而是形如初始值的经过叠加处理后的操作。