JavaScript 动态添加与获取obeject对象的属性

前言

在写微信小程序的时候,笔者遇到个问题,需要往一个object对象里添加一个新的属性,但是这个属性是个变量,按照Object.attribute = value 的老方法是不行的,那就需要新的方式来解决这个问题

解决办法

上网查了一下资料,发现有两种方法可以解决往一个object对象里添加一个新的属性的问题.
方法一:

var temp = {};//新建一个空的对象
var key = "testKey"; 
var value = "testValue";//key和value 都是变量,可任意取值
temp[key] = value; // temp = {"testKey":"testValue"}

方法一还是很好理解的,用了类似数组的思想给对象添加属性。一般情况下,推荐使用这种方法,在小程序里也是可以使用的.

方法二:

我们可以借助一个eval函数来解决这个问题。
函数说明:
eval (string) 函数接受一个string字符串,它可以计算字符串,或者把字符串翻译成可执行的JavaScript语句并执行

eval("3+4");//返回7
var x = 7;
eval("alert(x)");// 执行 alert(7);

类似的,我们可以用eval函数给object 对象动态添加属性

var temp = {};//新建一个空的对象
var key = "testKey"; 
var value = "testValue";//key和value 都是变量,可任意取值
eval("temp."+key+"= '"+value+"'")// temp = {"testKey":"testValue"}
                                 //注意,要使用 单引号 把 value的值括起来形成字符串,不然会把value值当成一个变量,就会报错

方法二用起来不太直观,而且在小程序中并不支持 eval()函数,所以推荐使用方法一

ps:
反过来,我们也可以动态获取 Obeject的属性

var temp = {"testKey":"testValue"}
var key = "testKey"; 
var value1 = temp[key];
var value2 = eval("temp."+key); // value1= value2 = ”testValue“

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值