这样做有更简洁或可读的方式吗?
var foo={a:111,c:333,somePropertyThatShouldntBeAdded:'xxx'}; var myobj={x:1,y:2,z:3}; if(foo.a){myobj.a=foo.a;} if(foo.b){myobj.b=foo.b;} if(foo.c){myobj.c=foo.c;}
编辑.上下文为什么我这样做是在下面.
var obj={value:this.text,css:{color:'#929292',margin:'1px 0px'}}; if(this.width){obj.css.width=this.width;} if(this.type){obj.type=this.type;} if(this.id){obj.id=this.id;} var input=$('<input/>',obj)
解决方法
您可以使用简单的基于循环的方法:
var foo={a:111,z:3}; ['a','b','c'].forEach(function(key) { if(key in foo) { myobj[key] = foo[key]; } });
请注意我是如何使用in关键字的.如果属性的值为(例如)false或0,则当前解决方案将不起作用.
另外,为了获得更好的解决方案,请提供一些上下文:为什么有条件地复制属性?也许你可以开始避免这种情况.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。