JS-面向对象-操作对象的属性 / 检测对象的某个属性是否存在 / 遍历(枚举)对象的属性 / 属性的分类

跟風遠走 提交于 2019-11-30 09:16:39

操作对象的属性


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
    <script>
        
        var obj1 = {
            fullName: '谭文华'
        };

        // 为对象添加新属性
        obj1.age = 20;
        obj1['gender'] = '男';

        // 修改对象的已有属性的值
        obj1.fullName = '赵志刚';
        obj1['age'] = obj1.age + 1;

        // 删除对象的属性
        delete obj1.gender;
        delete obj1['age'];

        console.log(obj1)


    
    </script>
</body>
</html>

检测对象的某个属性是否存在


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
    <script>
        
        var obj1 = {
            fullName: '谭文华'
        };

        // 为对象添加新属性
        obj1.age = 20;
        obj1['gender'] = '男';

        // 修改对象的已有属性的值
        obj1.fullName = '赵志刚';
        obj1['age'] = obj1.age + 1;

        // 删除对象的属性
        delete obj1.gender;
        delete obj1['age'];

        console.log(obj1)


    
    </script>
</body>
</html>

遍历(枚举)对象的属性


<!DOCTYPE html>
<html lang="zh">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <script>

        var obj1 = {
            firstName: '赵四',
            lastName: '尼古拉斯',
            get fullName() {
                return this.firstName + '.' + this.lastName;
            },
            set fullName(newFullName) {
                newFullName = newFullName.split('.');
                this.firstName = newFullName[0];
                this.lastName = newFullName[1];
            }
        };

        // 特性指的是对属性的描述符

        // 使用 Object.getOwnPropertyDescriptor() 方法获取单个属性的特性
        var descriptor1 = Object.getOwnPropertyDescriptor(obj1, 'firstName');

        // 数据属性 firstName 的特性:
        // configurable: true // 是否可以删除属性,以及使用可以改变属性的类型(例如,从数据属性变成访问器属性)
        // enumerable: true   // 是否可以枚举该属性
        // value: "赵四"      // 数据属性的值
        // writable: true     // 是否可以修改属性的值

        var descriptor2 = Object.getOwnPropertyDescriptor(obj1, 'fullName');

        // 访问器属性 fullName 的特性:
        // configurable: true            // 是否可以删除属性,以及使用可以改变属性的类型(例如,从数据属性变成访问器属性)
        // enumerable: true              // 是否可以枚举该属性
        // get: ƒ fullName()             // 具有 get 方法表示可以读取改属性的值
        // set: ƒ fullName(newFullName)  // 具有 set 方法表示可以修改该属性的值

        // 我们也可以使用 Object.getOwnPropertyDescriptors() 方法一次获取对象中所有属性的特性
        var descriptor3 = Object.getOwnPropertyDescriptors(obj1);

        console.log(descriptor3)
        // obj1 对象中所有属性的特性:
        // {
        //     firstName: {
        //         configurable: true
        //         enumerable: true
        //         value: "赵四"
        //         writable: true
        //     },
        //     lastName: {
        //         configurable: true
        //         enumerable: true
        //         value: "尼古拉斯"
        //         writable: true
        //     },
        //     fullName: {
        //         configurable: true
        //         enumerable: true
        //         get: ƒ fullName()
        //         set: ƒ fullName(newFullName)
        //     }
        // }

    </script>
</body>

</html>

属性的分类


<!DOCTYPE html>
<html lang="zh">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>

<body>
    <script>

        var obj1 = {
            firstName: '赵四',
            lastName: '尼古拉斯',
            get fullName() {
                return this.firstName + '.' + this.lastName;
            },
            set fullName(newFullName) {
                newFullName = newFullName.split('.');
                this.firstName = newFullName[0];
                this.lastName = newFullName[1];
            }
        };

        // 使用 Object.defineProperty() 修改已有属性的特性
        // Object.defineProperty(obj1, 'firstName', {
        //     configurable: false,
        //     enumerable: false,
        //     value: '刘能',
        //     writable: false
        // })

        // 使用 Object.defineProperty() 添加新属性,并指定新属性的特性
        Object.defineProperty(obj1, 'age', {
            configurable: false,
            enumerable: false,
            value: 20,
            writable: false
        })

        // 使用 Object.defineProperties() 一次添加或修改多个属性的特性
        Object.defineProperties(obj1, {
            firstName: {
                configurable: false,
                enumerable: false,
                value: "赵四",
                writable: false
            },
            lastName: {
                configurable: false,
                enumerable: false,
                value: "尼古拉斯",
                writable: false
            },
            fullName: {
                configurable: false,
                enumerable: false,
                get: function() {},
                set: function(newFullName) {}
            },
            gender: {
                configurable: false,
                enumerable: false,
                value: "男",
                writable: false
            }
        })


        // 不可删除
        // delete obj1.firstName

        // 不可枚举
        // for(var key in obj1) {
        //     console.log(key)
        // }

        // 不可修改
        // obj1.firstName = '宋小宝';
        
        console.log(obj1)
    </script>
</body>

</html>
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!