如何通过JavaScript反射机制实现复杂属性的动态赋值与访问?
- 内容介绍
- 文章标签
- 相关推荐
本文共计388个文字,预计阅读时间需要2分钟。
这篇文章主要介绍了JavaScript中的反射和属性赋值实例解析。内容以示例代码为主,讲解清晰,适合有一定基础的读者学习。对想深入了解JavaScript的读者或工作者具有一定的参考价值。需要的朋友可以参考以下内容:
1. JavaScript反射示例代码解析
2.属性赋值实例讲解
3.与Java和.NET的比较
这篇文章主要介绍了JavaScript 反射和属性赋值实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
Java和.NET都有着比较完善的反射机制,用来处理未知的对象并获取它们的属性和方法。JavaScript虽然没有完善的反射体系,但在编程的时候还是可以通过代码设计来实现类似反射的基本功能。
function Antzone(){ this.webName="蚂蚁部落"; this.age=6; } Antzone.prototype={ address:"青岛市南区" } var auth = { ADD:false, LIST:false, EXPORT:false, IMPORT:false, SEARCH:false }; console.log(Object.keys(auth)); var auth1 = ["ADD","LIST","SEARCH"]; let antzone=new Antzone(); console.log(Object.getOwnPropertyNames(antzone)); var names = Object.getOwnPropertyNames(auth); console.log(names); if(auth1.length > 0){ for(var i=0;i<names.length;i++){ for(var j=0;j<auth1.length;j++){ if(auth1[j] == names[i]){ auth[names[i]]=true; break; } } } } console.log(auth);
结果:
js output console.log: ["ADD", "LIST", "EXPORT", "IMPORT", "SEARCH"] console.log: ["webName", "age"] console.log: ["ADD", "LIST", "EXPORT", "IMPORT", "SEARCH"] console.log: { ADD: true LIST: true EXPORT: false IMPORT: false SEARCH: true }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。
本文共计388个文字,预计阅读时间需要2分钟。
这篇文章主要介绍了JavaScript中的反射和属性赋值实例解析。内容以示例代码为主,讲解清晰,适合有一定基础的读者学习。对想深入了解JavaScript的读者或工作者具有一定的参考价值。需要的朋友可以参考以下内容:
1. JavaScript反射示例代码解析
2.属性赋值实例讲解
3.与Java和.NET的比较
这篇文章主要介绍了JavaScript 反射和属性赋值实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
Java和.NET都有着比较完善的反射机制,用来处理未知的对象并获取它们的属性和方法。JavaScript虽然没有完善的反射体系,但在编程的时候还是可以通过代码设计来实现类似反射的基本功能。
function Antzone(){ this.webName="蚂蚁部落"; this.age=6; } Antzone.prototype={ address:"青岛市南区" } var auth = { ADD:false, LIST:false, EXPORT:false, IMPORT:false, SEARCH:false }; console.log(Object.keys(auth)); var auth1 = ["ADD","LIST","SEARCH"]; let antzone=new Antzone(); console.log(Object.getOwnPropertyNames(antzone)); var names = Object.getOwnPropertyNames(auth); console.log(names); if(auth1.length > 0){ for(var i=0;i<names.length;i++){ for(var j=0;j<auth1.length;j++){ if(auth1[j] == names[i]){ auth[names[i]]=true; break; } } } } console.log(auth);
结果:
js output console.log: ["ADD", "LIST", "EXPORT", "IMPORT", "SEARCH"] console.log: ["webName", "age"] console.log: ["ADD", "LIST", "EXPORT", "IMPORT", "SEARCH"] console.log: { ADD: true LIST: true EXPORT: false IMPORT: false SEARCH: true }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。

