• JS笔记(二):对象


    (一) 对象

    对象是JS的基本数据类型,类似于python的字典。然而对象不仅仅是键值对的映射,除了可以保持自有的属性,JS对象还可以从一个称为原型的对象继承属性,对象的方法通常是继承的属性。(这种对象之间属性的继承,应该就是JS对象和Python字典的主要区别)。还有另一个区别就是,JS对象可以设置属性特性,这里先跳过。

    除了字符串、数字、true、false、null和undefined之外,JS的值都是对象。

    (二) 原型

    每一个JS对象都和另一个对象相关联。这里的“另一个对象”指的就是原型,每一个对象都从原型继承属性。

    同使用{}一样,通过new object()创建的对象也继承自Object.prototype。通过new Arrray()创建的对象的原型就是Array.prototype,通过new Data()创建的对象的原型就是Date.prototype。

    没有原型的对象为数不多,Object.prototype就是其中之一,它不继承任何属性。其它原型对象都是普通对象,普通对象都具有原型。所有内置构造函数(以及大部分自定义的构造函数)都具有一个继承自Object.prototype的原型。例如Date.prototype的属性继承来自Object.prototype,因此new Data()创建的Date对象的属性同时继承自Date.prototype和Object.prototype。这一系列链接的原型对象就是所谓的“原型链”。

    感觉简单的说就是祖父对象-父对象-子对象…

    动物-猫科动物-猫亚科-猫属-荒漠猫,子对象具有父对象的所有属性。(JS对象没理解错的话,应该就是属性成员的集合,所以对象之间属性的继承很容易理解,但是方法是怎么回事?(和其他面向对象语言一样,理解为“继承父对象的行为(操作)”好像有点牵强。))

    看书里的意思(对象的方法通常是继承的属性),然后去看了下Object.prototype的实现才大概明白,这些方法其实应该也可以称为对象的属性。

    Object.prototype应该就是JS中顶级的对象(大部分对象都继承自Object.prototype)。

    1 var A = Object.create(Object.prototype) //创建一个空对象,和{}、new Obeject()一样

    (三) 继承

     1 //返回一个继承(原型)对象P所有属性的新对象
     2 function inherit(p){
     3     if(p == null) throw TypeError();
     4     if(Object.create)
     5         return Object.create(p);
     6     var t = typeof p;
     7     if(t !== "object" && t !== "function") throw TypeError();
     8     function f(){}
     9     f.prototype = p;
    10     return new f();
    11 }
    12 
    13 
    14 var people = {name:'小明',weight:35}
    15 var the_boy = inherit(people) //继承peop的属性
    16 the_boy.hobbies = '旅游' //添加属性成员
    17 var the_child = inherit(the_boy) //继承the_boy的属性
    18 
    19 console.log(the_boy.name)  //name来自people
    20 console.log(the_child.hobbies) //hobbies来自the_boy

    (四)  删除、检测、枚举属性

    1 var people = {name:'小明',weight:35,hobbies:'旅游'}
    2 
    3 //检测属性是否存在,也是用 关键字 in
    4 console.log('name' in people) //true
    5 console.log('x' in people)  //false
    6 
    7 //遍历属性,使用for/in 循环语句
    8 for(i in people)
    9     console.log(i)

    1 //删除属性,使用delete关键字
    2 delete people.name

    (五)getter、setter和属性特性

    1、JS对象属性由键、值和一组属性特性构成

    2、JS对象属性的值可以用getter和setter方法代替,getter和setter方法定义的属性叫存取器属性,它不同于数据属性,数据属性只是一个简单的值。

    3、我们可以设置JS对象属性的特性,例如设置为不可枚举。(这个也是JS对象和python字典之间的另一个区别)

    具体实现先跳过,先知道有这些功能,以后如果会用到,再具体了解下。

    (六)序列化对象JSON

     对象序列化,即将对象的状态转换为字符串,也可将字符串还原为对象。JS提供了JSON.stringify()和JSON.parse()来序列化和还原对象,这些方法都使用JSON作为数据交换格式。JSON的全称是JavaScript Object Notation ----JS对象表示法。JSON的语法是JS语法的子集,它并不能表示JS语法里的所有值,支持对象、数组、字符串、无穷大数字、true、false和null,并且他们可以序列化和还原。

    1 var people = {name:'小明',weight:35,hobbies:'旅游'}
    2 
    3 var p = JSON.stringify(people) //序列化对象
    4 console.log(p)
    5 
    6 var po = JSON.parse(p) //还原
    7 console.log(po)

  • 相关阅读:
    Unity 3D Customizing Your Workspace 自定义工作区
    Unity3D 学习界面 Learning the Interface
    【Python】函数功能描述
    没有显示器的情况下安装和使用树莓派
    【Linux】03-Linux用户权限相关命令
    【Linux】02-Linux远程管理常用命令
    【Linux】01-Linux基本命令
    【12c】DataGuard构建物理备用数据库(Cloud Control方式)
    【12c】一文教你详细了解如何安装Oracle Enterprise Manager Cloud Control 12c
    【12c】新特性:一文带你详细了解Oracle 12c 数据库的自动数据优化(ADO)
  • 原文地址:https://www.cnblogs.com/simple-free/p/9245806.html
Copyright © 2020-2023  润新知