js动态为对象添加属性和方法

JavaScript016

js动态为对象添加属性和方法,第1张

简单的补个例子上,希望楼主能把addMethods的第二个参数大致有几种情况写清楚。

我再把我的答案补充完整

//判断类型的方法

var isType = function(object) {

  return Object.prototype.toString.call(object)

    .match(/^\[object\s(.*)\]$/)[1]

}

var addMethods = function(obj, arr){

    if(isType(obj) !== 'Object'){

        return alert('第一个参数必须是对象!')

    }

    //TODO

}

对象合并:

var obj = {a:1, name: 'test'}

var shuxing = {name:"super",sex:"19",work:"IT"}

for(var r in shuxing){

eval("obj."+r+"=shuxing."+r)

}

alert(obj.a)

alert(obj.name)

alert(obj.sex)

alert(obj.work)

当然可以写成函数方式:

function objMerger(obj1, obj2)

{

for(var r in obj2){

eval("obj1."+r+"=obj2."+r)

}

return obj1

}

obj = objMerger(obj, shuxing)

添加属性用setAttribute()方法,可以传入两个参数,第一个是属性名称,第二个是要设置的属性值

var li = document.getElementsByTagName('li')[0]

//设置 li 属性,如 data-falg,设置为true

li.setAttribute("data-falg", "true")

也可以获取属性用getAttribute(),传入一个参数,是想获取的属性名称,返回的是该属性的值