㈠ js中,关于数组赋值变化问题。var arr = [1,4,5,9,0];var t =arr.随便一种方法();
对象之间等号操作 不是赋值 是引用
㈡ JS中,如何把一个一维数组赋值给二维数组
procts[i][j].push(plist);
这句JS代码,其实是二维数组,然后元素又是一个数组,结果是一个三维数组。
因此在获回取对象属性时,需要添答加索引,才行。
procts[i][j][k].proctName
㈢ js赋值 怎么传值赋值
要说js的赋值方式时首先要说明js的数值类型:基本类型和引用类型。
1、基本类型
基本的数据类型有:undefined,boolean,number,string,null。 基本类型存放在栈区,访问是按值访问的,就是说你可以操作保存在变量中的实际的值。
3、数组是引用类型
我们先来看一个例子:
vara=[1,2,3];
varb=a;
a=[4,5,6];
alert(b);//[1,2,3]
好像数组是基本类型一样。。,但是:
vara=[1,2,3];
varb=a;
a.pop();
alert(b);//[1,2]
这是怎么回事?因为:(知乎解释)
a = [4,5,6];//改变的是a引用本身,没有改变数组对象,a和b没有了关系。
a.pop();//改变的是数组对象,a引用没有改变。
b = a;//该操作后,b直接指向数组对象,不是b指向a,a再指向数组。
//所以改变a引用并不会对b引用造成影响,改变数组对象可以。
这个问题就跟我之前在React todo-list 一篇中提到的问题一样:
var tasks=this.state.data;
tasks=tasks.filter(function(i){
return i.index!=taskId;
});
由于filter函数是返回一个新的数组,虽然仍然用tasks去接收,但这时候tasks的指向已经是新数组啦,所以tasks和data已经不在有关系。(concat也是返回新数组)
而push和splice函数是在原数组上操作,所谓在原数组操作,指的是指向不变,所以tasks和data是相关联的。
4、参数传递
js的函数参数传递为值传递。
当传入的是 基本类型的参数时:就是复制了份内容给i而已,i与age之间没有关系。
function setAge(i)
{
alert(i);//24
i = 18;
alert(i);//18,i的改变不会影响外面的age
};
var age = 24;
setAge(age);
alert(age);//24
当传入的参数为引用类型时:
function setName(obj)
{
obj.name = 'haha';
};
var obj2 = new Object();
setName(obj2);
alert(obj2.name); // haha
这看起来很像是传递的是引用,因为obj.name受到改变了,但其实不是,其实还是值,因为obj2本身的值就是新对象的地址,所以传进去的就是这个地址。
这是阿里2014年的笔试题:
var a = 1;
var obj = {
b: 2
};
var fn = function () {};
fn.c = 3;
function test(x, y, z) {
x = 4;
y.b = 5;
z.c = 6;
return z;
}
test(a, obj, fn);
alert(a + obj.b + fn.c);
答案:12
首先test传递进去的实参中,a是基本类型(,复制了一份值),obj是object(指向地址,你动我也动),fn也当然不是基本类型啦。在执行test的时候,x被赋值为4(跟a没关系,各玩各的,a仍然为1),y的b被赋值为5,那obj的b也变为5,z的c变为6,那fn的c当然也会是6. 所以alert的结果应该是1+5+6 =12. (其实test不返回z也一样,z仍然改变的)。
㈣ js中怎么把值放入数组中
不知道复你什么意思?这是最基本制的:
(1)
使用方括号,创建数组的同时赋初值
var
myA=["张三",
"李四","王五"];
var
b=[10,20,30,40];
(2)
使用new
操作符,创建数组的同时赋初值
var
myA=new
Array("张三",
"李四","王五");
注意圆括号和方括号的区别,不能任意使用。
(3)
先创建长度为10的数组,内容后面再赋值
var
anArray
=
new
Array(9);
anArray[0]=
"张三";
anArray[1]=
"李四";
anArray[2]=
"王五";