导航:首页 > 编程语言 > 给对象赋值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

友情链接