[js学习笔记] 原型链理解
js中只有对象,包括对象,函数,常量等。
prototype
- 只有函数里有这个属性。
- 对象里可以设置这个属性,但是没这个属性的意义
- prototype指向一个对象,可以添加想要的方法。
- 该对象里有一个constructor属性,默认指向了这个函数。
proto
- 对象里有这个属性。
- 功能: 如果要一个对象的属性,会先在这个对象里查找,如果这个对象里没有这个属性,则会在这个对象里__proto__的对象里查找这个属性
- 如果这个对象本身还有一个 proto 属性,则会继续在
__proto__.__proto__里找这个属性。 - 该属性无法在ie11以下,无法直接访问
new 对象
- new function 创建对象的时候,会首先创建一个空对象
- 传入这个fuction赋值给this对象
- 把该function里的prototype 赋值给这个对象的 __proto__属性。
- 所创建出来的对象,这是为什么创建出来的对象可以访问之前function里prototype设置属性
一些实例
proto
var a = {};
a.__proto__ = {
"show":function(){
document.write("show");
}
}
a.show()//show
function 里
function B(){ }
B.prototype.show1 = function(){
document.write("B:show1");
}
B.show = function(){
document.write("B:show");
}
new B().show1();// 对象只与方法里prototype 关联
new B().show();//B对象里直接设置的方法不会关联到方法里。
方法调用以及this理解
- this 其实就是调用方法 . 之前的对象。
- 如果使用call,apply方式调用,则this是用第一个参数赋的值。
function B(){ }
B.show = function(){
document.write(this);
} B.show();//打印结果为: function B
基础的东西都说完了,咱们来基于这些做一些拓展
继承封装
方式1
ext = function(child,parent)
{
var _proto = function(){};
_proto.prototype = parent.prototype;
child.prototype = new _proto();
child.prototype.constuctor = child;
child.super=parent;
}
Object.prototype.super = function(){};
方式2
ext = function(child,parent)
{
child.prototype.__proto__ = parent.prototype;//new _proto();
child.prototype.constuctor = child;
child.super=parent;
}
Object.prototype.super = function(){};
使用
//定义Person
function Person(name, age)
{
this.name = name;
this.age = age;
} Person.prototype.speak = function()
{
document.write("name = "+this.name + "<br/>");
} //定义学生,继承了Person
function Student(name,age)
{
Student.super.call(this,name,age);
this.score = 90;
}
ext(Student,Person) Student.prototype.show = function()
{
document.write("show name=" + this.name + ",score = "+this.score +"<br/>");
} //定义Academician 继承Student
function Academician(name, age){
Academician.super.call(this,name,age);
}
ext(Academician,Student); var academ = new Academician("狗蛋",20); academ.show();
academ.speak();
打印结果
show name=狗蛋,score = 90
name = 狗蛋
[js学习笔记] 原型链理解的更多相关文章
- 【学习笔记】深入理解js原型和闭包系列学习笔记——精华
深入理解js原型和闭包笔记: 1.“一切皆是对象”,对象是属性的集合. 丨 函数也是对象,但是使用typeof时为什么函数返回function而 丨 不是object呢,js为何要对函数做这样的区分 ...
- js原型链理解(2)--原型链继承
1.原型链继承 2.constructor stealing(构造借用) 3.组合继承 js中的原型链继承,运用的js原型链中的__proto__. function Super(){ this.se ...
- JS 学习笔记--9---变量-作用域-内存相关
JS 中变量和其它语言中变量最大的区别就是,JS 是松散型语言,决定了它只是在某一个特定时间保存某一特定的值的一个名字而已.由于在定义变量的时候不需要显示规定必须保存某种类型的值,故变量的值以及保存的 ...
- WebGL three.js学习笔记 使用粒子系统模拟时空隧道(虫洞)
WebGL three.js学习笔记 使用粒子系统模拟时空隧道 本例的运行结果如图: 时空隧道demo演示 Demo地址:https://nsytsqdtn.github.io/demo/sprite ...
- vue.js 学习笔记3——TypeScript
目录 vue.js 学习笔记3--TypeScript 工具 基础类型 数组 元组 枚举 字面量 接口 类类型 类类型要素 函数 函数参数 this对象和类型 重载 迭代器 Symbol.iterat ...
- 一点感悟:《Node.js学习笔记》star数突破1000+
写作背景 笔者前年开始撰写的<Node.js学习笔记> github star 数突破了1000,算是个里程碑吧. 从第一次提交(2016.11.03)到现在,1年半过去了.突然有些感慨, ...
- 【转】Backbone.js学习笔记(二)细说MVC
文章转自: http://segmentfault.com/a/1190000002666658 对于初学backbone.js的同学可以先参考我这篇文章:Backbone.js学习笔记(一) Bac ...
- js学习笔记:webpack基础入门(一)
之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...
- Vue.js学习笔记(2)vue-router
vue中vue-router的使用:
随机推荐
- Sql Server数据库使用触发器和sqlbulkcopy大批量数据插入更新
需要了解的知识 1.触发器 2.sqlbulkcopy 我的用途 开发数据库同步的工具,需要大批量数据插入和数据更新. 方式 使用SqlBulkCopy类对数据进行数据批量复制,将需要同步数据的表新建 ...
- spring boot / cloud (六) 开启CORS跨域访问
spring boot / cloud (六) 开启CORS跨域访问 前言 什么是CORS? Cross-origin resource sharing(跨域资源共享),是一个W3C标准,它允许你向一 ...
- 第二章 [分布式CMS]
结构系统:定义的后台 资源云:存在静态资源文件 文档云:文章内容 工具服务:模板.,公共类 Web服务:处理一下数据交互 为什么要做分布式了? 说实话,我也不太清楚,网上说在性能方面比较好,我的理解是 ...
- c++中find函数的用法
find函数主要实现的是在容器内查找指定的元素,并且这个元素必须是基本数据类型的.查找成功返回一个指向指定元素的迭代器,即元素在容器中的下标,查找失败返回end迭代器. 头文件 #include &l ...
- mybatis的延迟加载
1. 什么是延迟加载 举个例子: 如果查询订单并且关联查询用户信息.如果先查询订单信息即可满足要求,当我们需要查询用户信息时再查询用户信息.把对用户信息的按需去查询就是延迟加载. 所以延迟加载即先从单 ...
- 【Linux部署 · JDK】在linux系统安装jdk
1,检查是否安装jdk echo $JAVA_HOME 或者java -version 2,查看操作系统,很明显这是一个相当old的操作系统,i686是32位操作系统. 3,在oracle ...
- pythonl练习
练习:用户输入姓名.年龄.工作.爱好 ,然后打印成以下格式 ------------ info of Egon ----------- Name : Egon Age : 22 Sex : male ...
- Ubuntu 14.04 安装LNMP(nginx/1.12.1+php7.1.9+mysql5.7.19)环境
这篇教程中,我们将讨论怎样在Ubuntu 14.04搭建LNMP环境 1 安装Nginx 首先我们要更新apt源 sudo add-apt-repository ppa:nginx/stable s ...
- eval浅解
关于eval,你了解多少呢?来看看 eval() 函数可计算某个字符串,并执行其中的的 JavaScript 代码. 需要一个参数(string),切必需.要计算的字符串,其中含有要计算的 JavaS ...
- 边看MHA源码边学Perl语言之一开篇
边看MHA源码边学Perl语言之一开篇 自我简介 先简单介绍一下自己,到目前为此我已经做了7年左右的JAVA和3年左右php开发与管理,做java时主要开发物流行业的相关软件,对台湾快递,国际快递,国 ...