千家信息网

JavaScript怎样获取对象属性和方法

发表于:2025-02-02 作者:千家信息网编辑
千家信息网最后更新 2025年02月02日,这篇文章主要介绍了JavaScript怎样获取对象属性和方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。javascript获取属性
千家信息网最后更新 2025年02月02日JavaScript怎样获取对象属性和方法

这篇文章主要介绍了JavaScript怎样获取对象属性和方法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

javascript获取属性的方法:1、创建一个对象的构造方法"function myObj(name, attr) {...}";2、通过"for (var i in myTester) {...}"方法获取对象方法即可。

本文操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

JavaScript 获取对象属性和方法

一、获取对象属性和方法

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

Object.getOwnPropertyNames() 返回的数组的所有属性(可枚举或不可枚举)直接找到给定对象。

// 创建一个对象的构造方法    function myObj(name, attr) {        this.name = name;        this.attr = attr;        this.sayHi = function () {            return 'hi everyone!!!';        }    }    // 创建一个对象    var myTester = new myObj("shinejaie", 1)    // 获取直接在对象上定义(可枚举)的属性和方法    var arr = Object.keys(myTester);    console.log('arr', arr); // 输出 arr ["name", "attr", "sayHi"]    // 返回的数组的所有属性(可枚举或不可枚举)直接找到给定对象。    console.log("attr", Object.getOwnPropertyNames(myTester)); // 输出 attr ["name", "attr", "sayHi"]    // 在 Object 原型上增加一个属性    Object.prototype.newShine = "it's me";    // 返回可枚举属性一直找到该对象的原型链    for (var i in myTester) {        console.log(i);    }    // 输出 name,attr,sayHi,newShine    // 返回直接定义在该对象上的可枚举属性    for (var i in myTester) {        if (myTester.hasOwnProperty(i)) {            console.log(i);        }    }    // 输出 name,attr,sayHi

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

// 不可枚举的对象属性    var nonenum = Object.create({}, {        getFoo: {            value: function () {                return this.foo;            },            enumerable: false        }    });    nonenum.foo = 1;    nonenum.asj = 2;    // 获取对象可枚举或不可枚举的属性    console.log(Object.getOwnPropertyNames(nonenum).sort()); // 输出 ["asj", "foo", "getFoo"]    // 获取对象可枚举的属性    console.log(Object.keys(nonenum).sort()); // 输出 ["asj", "foo"]    // 返回直接定义在该对象上的可枚举属性    for (var i in nonenum) {        if (nonenum.hasOwnProperty(i)) {            console.log(i); // 输出 foo asj        }    }

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

// 创建一个对象的构造方法    function myObj(name, attr) {        this.name = name;        this.attr = attr;        this.sayHi = function () {            return 'hi everyone!!!';        }    }    // 创建一个对象    var myTester = new myObj("shinejaie", 1)    // 获取对象方法    for (var i in myTester) {        if (myTester.hasOwnProperty(i) && typeof myTester[i] == "function") {            console.log("对象方法: ", i, "=", myTester[i])        }    }    // 输出 对象方法: sayHi = () { return 'hi everyone!!!'; }    // 获取对象属性    for (var i in myTester) {        if (myTester.hasOwnProperty(i) && typeof myTester[i] != "function") {            console.log("对象属性: ", i);        }    }    // 输出 对象属性: name 对象属性: attr

感谢你能够认真阅读完这篇文章,希望小编分享的"JavaScript怎样获取对象属性和方法"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!

0