switch(e.target.title){
case "矩形":
// console.log("画矩形")
Draw.drawAll(this.mapId,"rectangle")
break;
case "圆形":
// console.log("画圆形")
Draw.drawAll(this.mapId,"ellipse")
break;
case "多边形":
// console.log("画多边形")
Draw.drawAll(this.mapId,"polygon")
break;
case "折线":
// console.log("画折线")
Draw.drawAll(this.mapId,"polyline")
break;
default:
// console.log("画出错了")
break;
}
我们一直知道forEach是没有返回值并且不直接改变原数组的,今天发现是不直接改变,实际上里面是包含着改变的。
1. forEach(item, index, arr),三个参数,如果直接用item=xxx是无法改变原数组的,但是如果用arr[index]就可以改变原数组。
var s = [1,2,3,4];
s.forEach(item=>{
item = 'a'
});
console.log(s);// ["1", "2", "3", "4"] 未改变原数组
s.forEach((item, index, arr)=>{
arr[index] = 'b'
});
console.log(s);// ["b", "b", "b", "b"] 改变了原数组
2. 数组里面的子元素是对象,那么是可以改变对应属性的
var s = [{a:1}, {a:1}];
s.forEach(item=>{
item = null;
});
console.log(s);//[{a: 1} ,{a: 1}] 未改变原数组
s.forEach(item=>{
item.a = 666;
});
console.log(s); // [{a: 666}, {a: 666}] //改变的原数组里面的对象属性
————————————————
版权声明:本文为CSDN博主「Klingonsss」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_15241071/article/details/90059163
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。