转: JavaScript 获取对象属性和方法
一、获取对象属性和方法
Object.getOwnPropertyNames()
返回的数组的所有属性(可枚举或不可枚举)直接找到给定对象。
1 // 创建一个对象的构造方法
2 function myObj(name, attr) {
3 this.name = name;
4 this.attr = attr;
5
6 this.sayHi = function () {
7 return 'hi everyone!!!';
8 }
9 }
10
11 // 创建一个对象
12 var myTester = new myObj("shinejaie", 1)
13 // 获取直接在对象上定义(可枚举)的属性和方法
14 var arr = Object.keys(myTester);
15 console.log('arr', arr); // 输出 arr ["name", "attr", "sayHi"]
16
17 // 返回的数组的所有属性(可枚举或不可枚举)直接找到给定对象。
18 console.log("attr", Object.getOwnPropertyNames(myTester)); // 输出 attr ["name", "attr", "sayHi"]
19
20 // 在 Object 原型上增加一个属性
21 Object.prototype.newShine = "it's me";
22
23 // 返回可枚举属性一直找到该对象的原型链
24 for (var i in myTester) {
25 console.log(i);
26 }
27 // 输出 name,attr,sayHi,newShine
28
29 // 返回直接定义在该对象上的可枚举属性
30 for (var i in myTester) {
31 if (myTester.hasOwnProperty(i)) {
32 console.log(i);
33 }
34 }
35 // 输出 name,attr,sayHi

二、Object.keys()、Object.getOwnPropertyNames()、for...in...对比

1 // 不可枚举的对象属性
2 var nonenum = Object.create({}, {
3 getFoo: {
4 value: function () {
5 return this.foo;
6 },
7 enumerable: false
8 }
9 });
10 nonenum.foo = 1;
11 nonenum.asj = 2;
12
13 // 获取对象可枚举或不可枚举的属性
14 console.log(Object.getOwnPropertyNames(nonenum).sort()); // 输出 ["asj", "foo", "getFoo"]
15
16 // 获取对象可枚举的属性
17 console.log(Object.keys(nonenum).sort()); // 输出 ["asj", "foo"]
18
19 // 返回直接定义在该对象上的可枚举属性
20 for (var i in nonenum) {
21 if (nonenum.hasOwnProperty(i)) {
22 console.log(i); // 输出 foo asj
23 }
24 }

三、分别获取JavaScript对象属性名和方法名

1 // 创建一个对象的构造方法
2 function myObj(name, attr) {
3 this.name = name;
4 this.attr = attr;
5
6 this.sayHi = function () {
7 return 'hi everyone!!!';
8 }
9 }
10
11 // 创建一个对象
12 var myTester = new myObj("shinejaie", 1)
13
14 // 获取对象方法
15 for (var i in myTester) {
16 if (myTester.hasOwnProperty(i) && typeof myTester[i] == "function") {
17 console.log("对象方法: ", i, "=", myTester[i])
18 }
19 }
20 // 输出 对象方法: sayHi = () { return 'hi everyone!!!'; }
21
22 // 获取对象属性
23 for (var i in myTester) {
24 if (myTester.hasOwnProperty(i) && typeof myTester[i] != "function") {
25 console.log("对象属性: ", i);
26 }
27 }
28 // 输出 对象属性: name 对象属性: attr

转: JavaScript 获取对象属性和方法的更多相关文章
- JavaScript 获取对象属性和方法
ShineJaie 原创整理,转载请注明出处. 一.获取对象属性和方法 Object.keys() 返回对象的可枚举属性和方法的名称数组. Object.getOwnPropertyNames() 返 ...
- JavaScript 访问对象属性和方法及区别
这篇文章主要介绍了浅析JavaScript访问对象属性和方法及区别的相关资料,仅供参考 属性是一个变量,用来表示一个对象的特征,如颜色.大小.重量等:方法是一个函数,用来表示对象的操作,如奔跑.呼吸. ...
- javascript window对象属性和方法
window对象 window对象表示一个浏览器窗口或一个框架.在客户端JavaScript中,window对象是全局对象,所有的表达式 都在当前的环境中计算.也就是说,要引用当前窗口根本不需要特殊的 ...
- JS获取对象“属性和方法”的方法
平时在写的代码过程中,经常会遇到对对象Object的数据处理.而在对对象的数据处理中,操作最频繁的是“数据引用”.“值的修改”.“获取关键字(属性)”.平时最烦的也是“获取关键字”,经常忘记怎么去获取 ...
- 浅析JavaScript访问对象属性和方法及区别
属性是一个变量,用来表示一个对象的特征,如颜色.大小.重量等:方法是一个函数,用来表示对象的操作,如奔跑.呼吸.跳跃等. 在JavaScript中通常使用”."运算符来存取对象的属性的值.或 ...
- javascript Location对象属性和方法
Location对象 Location对象包含有关当前URL的信息 https://blog.csdn.net/u010953692/article/details/80901035#3 https( ...
- 第五课 JAVA反射获取对象属性和方法(通过配置文件)
Service1.java package reflection; public class Service1 { public void doService1(){ System.out.print ...
- JS获取对象“属性”的方法
var testObj= new Object(); testObj.name = "shangguan"; testObj.age= ; testObj.action = fun ...
- JavaScript原生对象属性和方法详解——Array对象
http://www.feeldesignstudio.com/2013/09/native-javascript-object-properties-and-methods-array/ lengt ...
随机推荐
- js promise看这篇就够了
一.背景 大家都知道nodejs很快,为什么会这么快呢,原因就是node采用异步回调的方式来处理需要等待的事件,使得代码会继续往下执行不用在某个地方等待着.但是也有一个不好的地方,当我们有很多回调的时 ...
- centos下在php.ini设置时区
错误: PHP Warning: Unknown: It is not safe to rely on the system's timezone settings. You are *require ...
- ie下常见的css兼容问题
1.border-radius 边框圆角 IE8及以下浏览器不支持border-radius webkit引擎支持-webkit-borderradius 私有属性 mozilla Gecko引擎支持 ...
- matlab文件读写处理实例(三)——读取文件特定行
(1) 读取文件特定行 CODE: ; ; if nline==line fprintf(fidout,'%s\n',tline); data ...
- python 编写简单的setup.py
学习python也已经有一段时间了,发现python作为脚本语言一个很重要的特点就是简单易用,而且拥有巨多的第三方库,几乎方方面面的库都有,无论你处于哪个行业,想做什么工作,几乎都能找到对应的第三方库 ...
- 通过重写 class 的 ToString() 来简化获取 enum 的 DescriptionAttribute 值
通过重写 class 的 ToString() 来简化获取 enum 的 DescriptionAttribute 值 目录 一.常见的 enum 类型 二.演变:class 版本的 enum 类型 ...
- JavaScript 基本语法 -- 运算符的优先级
在所有的运算里,都是有运算顺序的.小时候学四则运算的时候,我们都知道这么一个规则:先乘除后加减,有括号要先算括号! 同样的,在JavaScript里面,运算符也是有相应的优先级的.其优先级如下表所示, ...
- 给php加速安装APC
说明:APC-3.1.13 适应于 php-5.4.27 下载: wget http://blog.xinfilm.com/softdir/APC-3.1.13.tgz tar -zxvf APC-3 ...
- java导入项目有红色叹号
原因:缺少jar包 解决: 选中项目 -> 右键 -> Build Path -> Configer Builder Path -> 删除掉有错的J ...
- 事务与隔离级别------《Designing Data-Intensive Applications》读书笔记10
和数据库打交道的程序员绕不开的话题就是:事务,作为一个简化访问数据库的应用程序的编程模型.通过使用事务,应用程序可以忽略某些潜在的错误场景和并发问题,由数据库负责处理它们.而并非每个应用程序都需要事务 ...