㈠ 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]=
"王五";