加入收藏 | 设为首页 | 会员中心 | 我要投稿 PHP编程网 - 黄冈站长网 (http://www.0713zz.com/)- 数据应用、建站、人体识别、智能机器人、语音技术!
当前位置: 首页 > 教程 > 正文

JavaScript 获取对象属性和技巧

发布时间:2021-12-10 18:21:17 所属栏目:教程 来源:互联网
导读:一、获取对象属性和方法 Object.keys() 返回对象的可枚举属性和方法的名称数组。 Object.getOwnPropertyNames() 返回的数组的所有属性(可枚举或不可枚举)直接找到给定对象。 // 创建一个对象的构造方法 function myObj(name, attr) { this.name = name; this.
一、获取对象属性和方法
 
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
 
深入探究JavaScript的 {} 语句块  http://www.linuxidc.com/Linux/2016-02/128493.htm
 
 
 
二、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

(编辑:PHP编程网 - 黄冈站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读