導航:首頁 > 編程語言 > 給對象賦值js

給對象賦值js

發布時間:2023-09-01 08:26:46

1. javaScript 中將一個 對象 賦值給 另一個 的問題

buy:function(buyList){buyList.forEach(function(good){good.farmer=this;});},buy是Farmer類的method,buyList中放了一些物品good,裡面有3類物品,每類物品都有一個屬性是farmer(外鍵連到類Farmer)我發現這個運行出錯,求

2. js對象屬性賦值時,可以用三元表達式為什麼不能用if(){}else{}

for(vari=0;i<nodes1.length;i++){
if(nodes1[i].nodeName=="P"&&nodes1[i].nodeType==1){
if(i%2==0){
nodes1[i].style.backgroundColor="yellow";
}else{
nodes1[i].style.backgroundColor="red";
}
}
}

if(){}else{} 是語句,是沒有返回值的,而三元表達式則是表達式,是可以直接賦值的。所以你不能想當然就這么用。

如果你真想獲得類似三元表達式的效果,可以這樣:

for(vari=0;i<nodes1.length;i++){
if(nodes1[i].nodeName=="P"&&nodes1[i].nodeType==1){
nodes1[i].style.backgroundColor=function(){
if(i%2==0){//把if語句放入一個匿名函數中
return"yellow";
}else{
return"red";
}
}();//立即執行這個匿名函數
}
}

3. JavaScript中直接給對象賦值和屬性賦值有何區別

var b=「123」
b.len="nihao"
alert(b.len)

第一行給b賦值為"123",那麼b就被定義為字元串類型的變數了,而不是一個基於自定義類的專對象。
而對於字屬符串變數,是不能再給它賦一個自定義的len屬性的。

另外,字元串變數有個只讀的length屬性,表示字元串的長度。
可以訪問該屬性:
alert(b.length); //OK
但不能賦值,賦值無效:
b.length = 6; //無效

4. 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仍然改變的)。

5. JS可否 var a[id] = new init();創建對象數組、進行賦值

function add(){ //添加一個對象到對象數組a
var a[id] = new init(); //-- 這里的變數聲明是錯誤的,應該講專var去除掉屬.
id++;
if(id==10000)id = 0;
}

改為
var id=0;
function add(){
a[id] = new init();
id++;
if(id==10000)id = 0;
}

6. 怎麼給 js 對象 賦 null 值

obj
=
null;就行。
以下代碼是正常執行的function
test()
{
var
button1
=
document.getElementById("button1");
button1.attachEvent("onclick",buttonEvent);
button1.click();
}
現在我們改造一下
function
test()
{
var
button1
=
document.getElementById("button1");
button1
=
null;
button1.attachEvent("onclick",buttonEvent);
button1.click();
}
運行後,腳本將出錯,網頁錯誤詳細信息如下:
消息:
'null'
為空或不是對象。
這說明進行了button1
=
null;句代碼後,button1這對象為null了。
若是button1
=
null替換為button1
=
"null";那麼button1的值就為字元串「null」,有引號與沒有引號兩者的區別甚大。
排版有點亂,不過希望這答案能幫助你

7. 給js對象賦值,如何賦值key

pastResult是數組,所以只能用0,1,2

//用對象
varpastResult={};
pastResult['F_iID']=feature.attributes.F_iID;
pastResult['F_sName']=feature.attributes.F_sName;
pastResult['F_sAddress']=feature.attributes.F_sAddress;

alert(pastResult['F_iID']);
alert(pastResult['F_sName']);
alert(pastResult['F_sAddress']);
閱讀全文

與給對象賦值js相關的資料

熱點內容
文件包下載的安裝包在哪裡 瀏覽:811
90版本升級不送 瀏覽:186
工具箱英文 瀏覽:382
南翔嘉定編程課哪裡好 瀏覽:853
win10改變文件格式 瀏覽:475
linux中的物理地址和虛擬地址 瀏覽:493
有哪些app可以接游戲訂單 瀏覽:472
蘋果硬碟數據恢復要多少錢 瀏覽:394
js綁定下拉框資料庫數據 瀏覽:448
cad文件怎麼復制到另一個文件里邊 瀏覽:858
dxp鑽孔文件 瀏覽:631
iphone大悅城換機 瀏覽:538
找結婚對象上什麼網站 瀏覽:974
學生信息管理系統程序設計報告 瀏覽:640
微信文件怎麼刪除怎麼恢復 瀏覽:407
編程程序怎麼復制 瀏覽:467
文件更改 瀏覽:327
冰點文件路徑 瀏覽:730
軟體一點開文件就關閉 瀏覽:88
網路如何把人捧紅 瀏覽:961

友情鏈接