转: JavaScript 获取对象属性和方法

一、获取对象属性和方法

Object.keys()for in 返回对象的可枚举属性和方法名称数组

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

时间: 2024-12-26 19:31:56

转: JavaScript 获取对象属性和方法的相关文章

JavaScript原生对象属性和方法详解——Array对象 转载

length 设置或返回 数组中元素的数目. 注意:设置 length 属性可改变数组的大小.如果设置的值比其当前值小,数组将被截断,其尾部的元素将丢失.如果设置的值比它的当前值大,数组将增大,新的元素被添加到数组的尾部,它们的值为 undefined.所以length不一定代表数组的元素个数. var arr = new Array(3) arr[0] = "John" arr[1] = "Andy" arr[2] = "Wendy" cons

JS获取对象“属性和方法”的方法

平时在写的代码过程中,经常会遇到对对象Object的数据处理.而在对对象的数据处理中,操作最频繁的是“数据引用”.“值的修改”.“获取关键字(属性)”.平时最烦的也是“获取关键字”,经常忘记怎么去获取,这里做一下整理. 既然要"获取关键字",那么得首先有一个对象才行.创建对象的方式很多,我自己惯用的方式有三种: 1.通过原始构造函数 new Object();创建一个对象,然后赋值: var testObj= new Object(); testObj.name = "sha

JavaScript - document对象属性和方法

document对象的属性和方法 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <title>test10.html</title> <script type="text/javascript"> //document对象的属性 /*alert(document.referrer); a

JavaScript原生对象属性和方法详解——String对象

length length 属性可返回字符串中的字符数目. length 是根据字符串的UTF-16编码来获取长度的,空字符串长度为0.length 不可修改. charAt() charAt() 方法可返回指定位置的字符.注意,JavaScript 并没有一种有别于字符串类型的字符数据类型,所以返回的字符是长度为 1 的字符串. stringObject.charAt(index) 参数index是必需的.表示字符串中某个位置的数字,即字符在字符串中的下标.字符串中第一个字符的下标是 0.如果

浅析JavaScript访问对象属性和方法及区别

属性是一个变量,用来表示一个对象的特征,如颜色.大小.重量等:方法是一个函数,用来表示对象的操作,如奔跑.呼吸.跳跃等. 在JavaScript中通常使用"."运算符来存取对象的属性的值.或者使用[]作为一个关联数组来存取对象的属性. 对象的属性和方法统称为对象的成员. 访问对象的属性 在JavaScript中,可以使用" . "和" [ ] "来访问对象的属性. 1. 使用" . "来访问对象属性 语法: objectNam

javascript window对象属性和方法

window对象 window对象表示一个浏览器窗口或一个框架.在客户端JavaScript中,window对象是全局对象,所有的表达式 都在当前的环境中计算.也就是说,要引用当前窗口根本不需要特殊的语法,可以把那个窗口的属性当作全局变量 来使用.例如,可以只写document,而不必写window.document. window对象属性 标红色的: 重要的 标黑色的: 正常不用  closed:   返回窗口是否已被关闭 defaultStatus:      设置或返回窗口状态栏中的默认文

第六课 JAVA反射获取对象属性和方法(通过配置文件)

Service1.java package reflection; public class Service1 { public void doService1(){ System.out.println("业务方法1"); } } Service2.java package reflection; public class Service2 { public void doService2(){ System.out.println("业务方法1"); } } s

JS获取对象“属性”的方法

1 var testObj= new Object(); 2 testObj.name = "shangguan"; 3 testObj.age= 25; 4 testObj.action = function () { 5 return this.name; 6 } 1.对象内置属性方法:Object.keys():该方法返回一个数组,数组内包括对象内可枚举属性以及方法名称. 1 var keys= Object.keys(testObj); 2 console.log(keys);

javascript Location对象属性和方法

Location对象 Location对象包含有关当前URL的信息 https://blog.csdn.net/u010953692/article/details/80901035#3 https(协议)   blog.csdn.net(域名)   /u010953692/article/details/80901035(路径)   #3(锚点) Location对象属性 hash: 设置或返回从井号(#) 开始的 URL (锚)  ↓ host:   设置或返回主机名和当前 URL 的端口号