当前位置: 首页 > news >正文

阜阳网站建设电话武汉大学人民医院洪山院区

阜阳网站建设电话,武汉大学人民医院洪山院区,什么平台做网站,想学服装设计从什么开始学起文章目录1. 原型2. 显式和隐式原型3. 原型链3.1 访问顺序4. instanceof4.1 如何判断1. 原型 函数的prototype属性 每个函数都有一个prototype属性,它默认指向一个Object空对象(即:原型对象)。原型对象中有一个属性constructor&a…

文章目录

  • 1. 原型
  • 2. 显式和隐式原型
  • 3. 原型链
    • 3.1 访问顺序
  • 4. instanceof
    • 4.1 如何判断

1. 原型

函数的prototype属性

  • 每个函数都有一个prototype属性,它默认指向一个Object空对象(即:原型对象)。
  • 原型对象中有一个属性constructor,它指向函数对象。

在这里插入图片描述
Person的prototype指向了它的Person Prototype,Person Prototype的constructor指向了Person 。


// 用户对象
function Person() {};console.log(Person.prototype);Person.prototype.getMoney = function() {return 5000000;console.log("身价500w");
}console.log((new Person()).getMoney());

在这里插入图片描述

给原型对象添加属性(一般都是方法)

  • 作用:函数的所有实例对象自动拥有原型中的属性(方法)

2. 显式和隐式原型

每个函数function都有一个prototype,即显式原型(属性)

每个实例对象都有一个__proto__,称为隐式原型(属性)。

对象的隐式原型的值为其对应构造函数的显式原型的值。

内存结构


// 第1步,内部语句:this.prototype = {}
function Fn() {};console.log(Fn.prototype);// 第2步,内部语句:this.__proto__ = Fn.prototype
let fn = new Fn();console.log(fn.__proto__);
console.log(fn.__proto__ === Fn.prototype);// 在原型上添加方法
Fn.prototype.test = function () {console.log("invoke test...");
}
fn.test();

以上代码对应内存结构如下:
在这里插入图片描述

总结:

  • 函数的prototype属性:在定义函数时自动添加的,默认值是一个空的Object对象。
  • 对象的__proto__属性:创建对象的时候自动添加的,默认值为构造函数的prototype属性值。
  • 可以在程序中直接操作显式原型,但不能直接操作隐式原型(ES6之前)

3. 原型链

3.1 访问顺序

原型链(隐式原型链),主要用于查找对象的属性(方法);访问一个对象的属性时,

  • 先在自身属性中查找,找到则返回
  • 如果没有,在沿着__proto__这条链向上查找,找到返回
  • 如果最终没找到,则返回undefined
            console.log(Object.prototype.__proto__)function Fn() {this.test1 = function() {console.log("test1()")}}Fn.prototype.test2 = function() {console.log("test2()")}let fn = new Fn();fn.test1();fn.test2();console.log(fn.toString);fn.test3();

在这里插入图片描述

输出如下:

在这里插入图片描述

构造函数/原型/实体对象的关系

在这里插入图片描述

函数的显式原型指向的对象默认是空Object实例对象(但是Object不满足)

所有函数都是Function的实例(包含Function)

Object的原型对象是原型链的尽头。

原型链的属性问题
读取对象的属性值时:会自动到原型链中查找
设置对象的属性值时:不会查找原型链,如果当前对象中没有此属性,直接添加此属性并设置其值
方法一般定义在原型中,属性一般通过构造函数定义在对象本身上。


function Fn() {}
Fn.prototype.a = 'xxx';
let fn1 = new Fn();
console.log(fn1.a, fn1);let fn2 = new Fn();
fn2.a = 'yyy';
console.log(fn1.a, fn2.a, fn1)

输出如下:

在这里插入图片描述

4. instanceof

4.1 如何判断

表达式:A instanceof B
如果B函数的显式原型对象在A对象的原型链上,返回true,否则返回false

Function 是通过new 自己产生的实例


function Foo() {}
let f1 = new Foo()
console.log(f1 instanceof Foo) // true
console.log(f1 instanceof Object) // true

在这里插入图片描述
完整的原型关系图:
在这里插入图片描述

http://www.hrbkazy.com/news/25190.html

相关文章:

  • 简单网站建设流程上海百度搜索排名优化
  • 哔哩哔哩高能建站sem推广什么意思
  • 哪里有微信网站建设全国疫情最新名单
  • align center 徐州seo公司
  • 网站title重复的后果网站注册搜索引擎的目的是
  • 浅谈天猫的电子商务网站建设网站首页的优化
  • 建站程序的价钱上海网站seo诊断
  • 网站备案更改吗百度企业官网认证
  • 工商年检网上申报系统泸州网站seo
  • 平面设计网上培训机构广州seo好找工作吗
  • 怎么用二维动画做网站首页步骤做小程序要多少钱
  • 德阳定制建站网站建设制作认识网络营销
  • 微信购物商城小程序怎么弄seo专家招聘
  • 企业门户网站解决方案广告投放
  • 公司网络用哪个比较好汕头seo网站建设
  • 网易 自助网站建设外链发布工具
  • 电子外贸网站建设旅游最新资讯 新闻
  • 搜索引擎网站推广可以自己做吗网站推广哪个好
  • 淘宝几百块钱做网站靠谱吗网络营销需要学什么
  • 做网站文字字号大小长沙seo霜天
  • 泌阳县住房建设局网站品牌网络推广外包
  • 网站做语言切换百度经验
  • 网站建设及维护涉及哪些内容百度搜索页面
  • 网站学什么国外免费ip地址
  • 做网站建议百度指数关键词工具
  • 中国500强企业排名一览表seo网站推广专员
  • 做网站导航今日热点新闻事件
  • 厦门做网站最好的公司怎么查找关键词排名
  • 网站设计代码案例java培训机构
  • 网站建设 网站优化培训机构排名全国十大教育机构排名