var test=[1,2,3,4,5,6,7]; var arr=test; arr.splice(2,1); alert(test);//1,2,4,5,6,7 JS数组实质上是对象.因此,上面的源代码最后打印出的是1,2,3,4,5,6.这是因为将test赋值给arr实际上是将数组的引用赋值给arr,所以操作arr也同时会改变源数组. 要实现数组克隆,可以下方法:Array.prototype.clone=function(){ return this.slice(0);
这个问题说大不大说小不小,如果你有幸踩了这个坑,一定会找这篇文章,哈哈~ 现说一下JS数字的类型:基本类型和引用类型 先看下下面两个栗子: var a = 30; var b = a; a = 20; console.log( b ) // 30 var a = [1,2]; var b = a; a[0] = 5; console.log( b ) // [5,2] 简单的说: number,string类型都是基本类型,而基本类型存放在栈区,访问时按值访问,赋值是按照普通方式赋值: 对象和数
var a = {n: 1}; var b = a; a.x = a = {n: 2}; console.log(a.x); console.log(b.x); 有道题是这样的,觉得很奇葩,分析一下 1.对象 引用类型 对象属于引用类型,c,java,js里面都是的,对象就是引用类型,包括数组. 上面的a是引用类型,a保存的是对象 {n: 1}的地址,对这个对象的引用.b = a .把a里面的地址赋值给了b,b也指向{n: 1}这个对象的物理地址.所以,a 一旦做赋值更改,修改的是a对引用的修改