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']);