[英]Add new element to an existing object
我一直在寻找一种方法来向现有对象添加新元素,就像推送数组一样
我试过这个并没有用:
var myFunction = {
Author: 'my name ',
date: '15-12-2012',
doSomething: function(){
alert("helloworld")
}
};
myFunction.push({
bookName:'mybook',
bookdesc: 'new'
});
console.log(myFunction);
用这个:
myFunction.bookName = 'mybook';
myFunction.bookdesc = 'new';
或者,如果您使用jQuery:
$(myFunction).extend({
bookName:'mybook',
bookdesc: 'new'
});
push
方法是错误的,因为它属于Array.prototype
对象。
要创建命名对象,请尝试以下操作:
var myObj = function(){
this.property = 'foo';
this.bar = function(){
}
}
myObj.prototype.objProp = true;
var newObj = new myObj();
只需执行myFunction.foo = "bar"
添加它。 myFunction
是这种情况下对象的名称。
Danilo Valente上面提到的jQuery语法不起作用。 它应该如下 -
$.extend(myFunction,{
bookName:'mybook',
bookdesc: 'new'
});
您可以使用Extend将新对象添加到现有对象。
您正在寻找jQuery扩展方法 。 这将允许您将其他成员添加到已创建的JS对象中。
您可以将JSON存储在数组中,然后使用push
将JSON数据插入到数组中
看看这个https://jsfiddle.net/cx2rk40e/2/
$(document).ready(function(){
// using jQuery just to load function but will work without library.
$( "button" ).on( "click", go );
// Array of JSON we will append too.
var jsonTest = [{
"colour": "blue",
"link": "http1"
}]
// Appends JSON to array with push. Then displays the data in alert.
function go() {
jsonTest.push({"colour":"red", "link":"http2"});
alert(JSON.stringify(jsonTest));
}
});
JSON.stringify(jsonTest)
结果
[{"colour":"blue","link":"http1"},{"colour":"red","link":"http2"}]
这个答案可能对希望模仿类似结果的用户有用。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.