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