【重温基础】15.JS对象介绍

栏目: JavaScript · 发布时间: 5年前

内容简介:从这篇文章开始,复习关于【一本可爱的JavaScript小书,内容分成三大部分:

从这篇文章开始,复习 MDN 中级教程 的内容了,在 初级教程 中,我和大家分享了一些比较简单基础的知识点,并放在我的 【 Cute-JavaScript 】系列文章中。

关于【 Cute-JavaScript 】 :

一本可爱的JavaScript小书,内容分成三大部分: ES规范系列JS基础系列面试题系列 ,目前我还在抓紧更新,喜欢的朋友可以 github 上Star一下呀,下面放一张首页图:

【重温基础】15.JS对象介绍

正文开始

本文是 重温基础 系列文章的第十五篇。

今日感受:耐心为人处世。

本章节复习的是JS中的关于对象还有原型等相关知识。

前置知识:

关于使用对象,可以先阅读一下我的 《12.使用对象》 这篇文章。

下面也先重温一点基础。

1.概念

对象是一个包含相关数据和方法的集合,由 变量方法 组成,通常称为对象的 属性方法 ,比如:

let me = {
    name : 'pingan',
    eat: function(){
        console.log('eat eat eat!!!');
    }
}

其中, name 就是 me 这个对象的一个属性, eat 就是 me 这个对象的一个方法。

访问对象的属性是这样的:

me.name;   // "pingan"
me.eat();  // "eat eat eat!!!"

另外在访问对象属性时,有以下两种方式:

let me = {
    name : 'pingan',
}
// 点表示法
me.name;   // me.name => "pingan"

// 括号表示法
me["name"];// me.name => "pingan"

括号表示法中,必须是字符串。

我们常常这么设置对象的属性:

let me = {
    name : 'pingan',
}
// 点表示法
me.name = "leo";   // me => {name: "leo"}

// 括号表示法
me["name"] = "leo";// me => {name: "leo"}

2.简单的面向对象介绍

这里简单介绍下JavaScrip的面向对象编程OOP。

面向对象编程(Object Oriented Programming,OOP,面向对象程序设计)是一种计算机编程架构。OOP 的一条基本原则是计算机程序是由单个能够起到子程序作用的单元或对象组合而成。 —— 百度百科

【重温基础】15.JS对象介绍

我们这里定义一个简单的对象模型,比如我,我的身上可能有很多信息(姓名,年龄,身高等等),这时候我们可以将这些信息抽取出来,像这样:

let leo = {
    name : 'leo',
    age  : 26,
    height : 180,
}

这样我们就将我的信息抽取成一个JS的对象了,但是这样有个局限性,这样定义的话,一次只能定义一个人,如果这时候,有一百个人,那么我们就需要定义一百个这样的对象,显然这是不可取的。

所以,这里就引入一个重要的函数—— 构造函数将相同的特性封装成通用的对象 ,实现定义一次,其他地方都可以使用,这也是OOP的核心思想:

// 传入 name 参数使得可以定义任何人作为对象
function Person (name){
    let me = {};
    me.name = name;
    me.doSomething = function(){
        console.log(me.name);
    }
    return me;
}

创建一个函数“ Person ”,只要传入不同的 name 即可得到不同的对象:

let leo = Person("leo");
leo.name;    // "leo"

let pingan = Person("pingan");
pingan.name; // "pingan"

但是似乎 Person 对象的定义,显得不够精简,因为还要定义一个 空对象 来接收各个属性和方法,幸好JavaScrip在构造函数中提供一个便捷的方法,我们将代码改造下:

function Person (name){
    this.name = name;
    this.doSomething = function(){
        console.log(this.name);
    }
}

对于 this 关键词,即无论是该对象的哪个实例被构造函数创建,它的 name 属性都是参数 name 的值, doSomething 方法中使用的也是参数 name 。简单理解就是用 this 指代了 Person

构造函数通常首字母大写,用于区分普通函数。

接下来,通过 new 关键词,使用前面创建的构造函数(使用构造函数也叫实例化):

let leo = new Person("leo");
leo.name;    // "leo"

let pingan = new Person("pingan");
pingan.name; // "pingan"

然后一个简单的构造函数就写好了,通常在开发的时候,可能会有很多的参数:

function Man(name, age, height, weight){
    this.name = name;
    this.age = age + '岁';
    this.HeightAndWeight = {
        height,
        weight
    };
    this.doSomething = function (){
        console.log(`
            ${this.name}: height:${this.HeightAndWeight.height}m, 
            weight:${this.HeightAndWeight.weight}Kg!!`
        );
    };
}

let leo = new Man("leo",25,1.8,68);
leo.doSomething();  // leo: height:1.8m, weight:68Kg!!

3.JS中的原型

3.1理解原型

这里需要先了解一下 ObjectFunction ,这两个函数都是JS的自带函数, Object 继承自己, Function 继承自己,相互继承对方,即 ObjectFunction 既是函数也是对象。

console.log(Function instanceof Object); // true
console.log(Object instanceof Function); // true

ObjectFunction 的实例,而 Function 是它自己的实例。

console.log(Function.prototype); // ƒ () { [native code] }
console.log(Object.prototype);  // Object

另外,只有通过 Function 创建的函数都是函数对象,其他都是普通对象(通常由 Object 创建):

function f1(){};
typeof f1 //"function"
 
 
var o1 = new f1();
typeof o1 //"object"
 
var o2 = {};
typeof o2 //"object"

理论知识:

JavaScript 常被描述为一种基于原型的语言 (prototype-based language)——每个对象拥有一个 原型对象 ,对象以其原型为模板、从原型继承方法和属性。

原型对象也可能拥有原型,并从中继承方法和属性,一层一层、以此类推。这种关系常被称为 原型链 (prototype chain),它解释了为何一个对象会拥有定义在其他对象中的属性和方法。

准确地说,这些属性和方法定义在Object的构造器函数(constructor functions)之上的 prototype 属性上,而非对象实例本身。

个人理解:

  • JS中所有的函数对象,都有一个 prototype 属性,对应当前对象的原型,但普通对象没有,而 prototype 属性下还有一个 constructor ,指向这个函数。
var p = {};
p.prototype;         // undefined
p instanceof Object; // true

function f (){}; 
f.prototype;         // object {constructor: ƒ}
f === f.prototype.constructor;           // true
Object === Object.prototype.constructor; // true
  • JS中所有的对象,都有一个 _proto_ 属性,指向 实例对象的构造函数原型 (由于 _proto_ 是个非标准属性,因此只有 ffchrome 两个浏览器支持,标准方法是 Object.getPrototypeOf() )。
var p = new Person(); 
p._proto === Person.prototype;  //true

修改原型:经常我们也需要对原型进行修改:

function Person (name){
    this.name = name;
}
// 添加一个getName方法
Person.prototype.getName = function(){
    return "名字:" + this.name;
}
var p = new Person("leo"); 
p.getName();   // "名字:leo"

这里也说明了原型进行继承, p 继承 Person 原型中新增的函数属性 getName

3.2原型链

概念:javascript中,每个对象都会在内部生成一个 proto 属性,当我们访问一个对象属性时,如果这个对象不存在就回去 proto 指向的对象里面找,一层一层找下去,,知道找到为止,如果到了原型链顶端,还没找到,则返回 undefined ,这就是javascript原型链的概念。

【重温基础】15.JS对象介绍

总结:

  • 除了 Objectprototype 的原型是 null ,所有对象和原型都有自己的原型,对象的原型指向原型对象。
  • JS中所有的东西都是对象,所有的东西都由 Object 衍生而来, 即所有东西原型链的终点指向null。

更加详细的介绍,可以查看下面参考文章。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Flexible Rails

Flexible Rails

Peter Armstrong / Manning Publications / 2008-01-23 / USD 44.99

Rails is a fantastic tool for web application development, but its Ajax-driven interfaces stop short of the richness you gain with a tool like Adobe Flex. Simply put, Flex is the most productive way t......一起来看看 《Flexible Rails》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具