zoukankan      html  css  js  c++  java
  • JS 对象 创建对象 对象的属性 对象的遍历

    对象

      JavaScript 中的对象(Object)是一组数据的无序集合。其中,每一条数据都是由键:值组成(例 如:name:'HanMeiMei' )。

      其中,值可以是任意数据类型,而键只能是字符串类型。

    注:其实,在 JavaScript 中,除了六种基本数据类型之外,就还只有一种引用数据类型 —— 对象。

    定义对象、创建对象

      定义对象的方式有两种:

        字面量方式:

    let obj1 = {};

        

         构造函数方式:

    let obj2 = new Object();

    对象的属性

      当对象中某一条数据的键所对应的值是非函数类型,则我们将这条数据叫做对象的属性。

    let student = {
     name: 'HanMeiMei',
     age: 20
    }
    /*name 和 age 两个键对应的值都不是函数,因此这两条数据我们就叫做 student 对象的属
    *性。
    */

     

        属性操作

      通过点运算符 . 来操作一个对象的属性。

    let person = {
         name: "lisa",
         job: "SoftWare Engineer"
    };
    person.name = "zhangsan"; // 修改已有的属性
    person.age = 30; // 添加没有的属性
    console.log( person.job ); // 查看已有的属性

      通过方括号 [] 操作一个对象的属性。

    let person = {
         name: "lisa",
         job: "SoftWare Engineer"
    };
    person["name"] = "zhangsan"; // 修改已有的属性
    person["age"] = 30; // 添加没有的属性
    console.log( person["job"] ); // 查看已有的属性

      通过 delete 关键字来删除一个对象的属性。

    let person = {
         name: "lisa",
         job: "SoftWare Engineer"
    };
    delete person.job; // 删除 person 对象的属性 job,只能一个一个的删除

    对象的方法

      当对象中某一条数据的键所对应的值是函数类型,则我们将这条数据叫做对象的方法。

    let person = {
     name: 'HanMeiMei',
     introduce: function(){
     console.log( 'my name is HanMeiMei' );
         }
    }
    //introduce 对应的值是函数,这条数据我们就叫做 person 对象的方法。

      方法操作

      对象方法的操作类似于对象属性的操作,同样具有以下三种方式:

        通过点运算符 . 来访问一个对象的方法。

    let person = {
         name: 'HanMeiMei',
         introduce: function(){
             console.log( 'my name is HanMeiMei' );
         }
    }
    person.introduce(); // 调用 person 对象的 introduce 方法        

        通过方括号 [] 来访问一个对象的方法。

    let person = {
         name: 'HanMeiMei',
         introduce: function(){
             console.log( 'my name is HanMeiMei' );
         }
    }
    person["introduce"](); // 调用 person 对象的 introduce 方法

        通过 delete 关键字来删除一个对象的方法。

    let person = {
         name: 'HanMeiMei',
         introduce: function(){
            console.log( 'my name is HanMeiMei' );
         }
    }
    delete person.introduce; // 方法名后面没有方括号    

    注:删除属性,输出该属性为undefined,删除方法,调用方法时会报错。

    对象的遍历

      for-in

    let person = {
        name: 'HanMeiMei',
        age: 20,
        gender: 'male',
        introduce: function () {
            console.log('my name is HanMeiMei');
        }
    }
    let name = Symbol('name');
    person[name] = `看不到`;
    console.log(person);
    for (let key in person) {
        console.log(key); 
    }

    注:for-in 无法遍历通过 symbol 值定义的属性。

      

      for-of

    //获取对象的键名
    for(let item of Object.keys(person)){
        console.log(item);
    }

    //获取对象的值
    for(let item of Object.values(person)){
        console.log(item);
    }

    //获取对象的键值对
    for(let item of Object.entries(person)){
        console.log(item);
    }

    注:同样都看不到symbol 值定义的属性。

    console.log(Reflect.ownKeys(person));//输出person对象所有的键
    console.log(Reflect.ownValues(person));//想要 输出person对象所有的值  此句报错

     注:这个方法可以看到symbol值定义的属性(键),但是没有对应的取值方法。

      

    对象方法中的 this

      对象的方法中可以使用 this 关键字。

    let foo = {
         bar: function(){
             console.log(this);
         }
    }
    foo.bar(); // { bar: [Function: bar] }

      对象方法中的 this 永远指向调用该方法时 . 或 [] 前的那个对象。如上例中 bar 方法的 this 就一定指向 foo 对象。

    对象的扩展

      对象的解构

    var { name: name, age: age } = { name: "zhangsan", age: 20 };
    console.log( name ); // zhangsan
    console.log( age ); // 20

      var { name: name, age: age } 中,“:”后面的 name(age) 是 var 将要声明的变量,“:”前面的 name(age) 指定了该变量在赋值符号右边的对象中取哪一个属性的值,

      在 ES6 中,如果属性名跟属性值的变量名相同时,可以简写。即:

    let a = 1;
    let b = 2;
    let obj = { a: a, b: b }
    // 简写
    let obj = { a, b }

      所以:

    let { name, age } = { name: "zhangsan", age: 20 };
    console.log( name ); // zhangsan
    console.log( age ); // 20

      

      对象解构的默认值

      对象的解构赋值允许指定默认值。

    // 没有默认值
    let { name1 } = {};
    console.log( name1 ); // undefined
    // 有默认值
    let { name2 = "张三" } = {};
    console.log( name2 ); // 张三
    let { name3 = "张三", age } = { name3: "李四", age: 30 };
    console.log( name3, age ); // 李四 30

    总结

      不管是数组、Set、Map,还是对象,它们都表现出了一个共同的特征,可以按某种特定的结构存放大量的数据。

      这些数据存放在一起作为一个整体我们可以称它们是一个集合;而集合中数据间存在关系,这就说明数据是有结构的,那么这个集合也可以叫做数据结构。

      所谓数据结构,就是计算机存储和组织数据的方式。说得通俗一点,主要就是指将数据以什么样的结构 存储到计算机里面。

      所以数组、Set、Map,对象,它们就都是一种数据结构。数组、Set、Map还能归属于对象。

      在程序方面,最为常用的数据结构,就是数组,这种结构将多个数据有序的排列在一起,形成了一个集合。

  • 相关阅读:
    iOS项目中常见的文件
    RN 导入原有Xcode项目中,引入Pod依赖出现的问题与解决
    Xcode中StoryBoard Reference 新特性的使用
    非等高cell实战(01)-- 实现微博页面
    iOS回顾笔记(09) -- Cell的添加、删除、更新、批量操作
    iOS回顾笔记(08) -- 自定义Cell的类型和创建步骤总结
    unittest中的测试固件
    unittest测试用例的执行顺序
    unittest各个组件之间的关系
    ubuntu16.04开机时的.local问题
  • 原文地址:https://www.cnblogs.com/jiayouba/p/11955127.html
Copyright © 2011-2022 走看看