基于js中的原型、继承的一些想法


Posted in Javascript onAugust 10, 2016

最近看到一个别人写的js类库,突然对js中的原型及继承产生了一些想法,之前也看过其中的一些内容,但是总不是很清晰,这几天利用空闲时间,对这块理解了一下,感觉还是有不通之处,思路上没那么条理,仅作为分享,

一、instanceof

在JavaScript有instanceof运算符,是二元运算符,使用方法 instanceA instanceof A,返回值是布尔值(boolean),含义是判断instanceA是否是A的一个实例,其实质是判断A.prototype===instanceA.__proto__,如

function f2(){
  var f=function(){}
  var test=new f();
  console.log(test instanceof f);//true
  console.log((f.prototype===test.__proto__));//true
}

上边的两个打印都是true。说明test是f的一个实例;test的__proto__属性指向了f的prototype对象,即f的prototype属性是一个对象,且此对象是f的一个实例。

二、js中对象

在js中一切皆是对象,对象分为函数对象和普通对象,常用的函数其实是函数对象,如

//函数对象
  var f=function(){}
  var f2=new Function('str','console.log(str)')
  function f3(){}
  //普通对象
  var o=new Object();
  var o2={}
  var o3=new f()

上面看到f、f2、f3是函数对象,o、o2、o3是普通对象。

函数对象和普通对象的区别:

所有使用new Function()的方式创建的对象都是函数对象,f和f3两种方式,最终是也是使用new Function()方式创建的;

在定义一个对象时,对象中包含一些预定义的属性,如,prototype、__proto__,其中prototype属性只有函数对象才有,__proto__则是对所有的对象都有,所以可以通过对象的__proto__属性判断一个对象是函数对象还是普通对象,如

//函数对象
  var f=function(){}
  //普通对象
  var o=new Object();
  console.log(f.prototype);//Object {}
  console.log(o.prototype);//undefined

从上边可以得出函数对象存在prototype属性,而普通对象的prototype对象则是未定义。

三、原型链

从上边知道所有的对象都有一个__proto__属性,这个属性指向创建它的函数对象的原型对象prototype,我们把这种使用__proto__属性串起来的链叫做原型链,如下面是一个原型链,

基于js中的原型、继承的一些想法

上图,以person为例,说明原型链,

var person=function(){}
var person1=new person();

1、person是一个函数对象,person1是person的一个实例

2、person1的__proto__属性是person的原型对象person.prototype

3、由于person的原型对象person.prototype是一个对象,它也有一个__proto__属性,这个属性指向的Object的原型对象Object.prototype

4、Object的原型对象Object.prototype是一个对象,它也有一个__proto__属性,这个属性的原型对象为null。

四、一些继承

在js中我们会定义一个函数对象,如

var person=function(){}

上面我们定义了一个函数对象,它没有任何的属性,是一个空对象,由于它是一个对象,所以可以为它增加属性,

var person=function(){}
person.name1='js'
console.log(person.name1)//js

上面的代码为person新增了一个name属性,且赋值为js,且可以打印出name属性的值
但是当我们创建一个person的实例person1的时候,如下

var person= function(){};
  person.name1= 122;
  console.log(person.name1);
  var person1=new person();
  console.log(person1.name1);//undefined

可以看到person1没有name1这个属性,那么如何才能保证person的实例也有name1属性呢,

var person= function(){};
  person.name1= 122;
  //使用prototype对象为对象添加属性,这样所以的实例都会有此属性
  person.prototype.name1='12';
  console.log(person.name1);
  var person1=new person();
  console.log(person1.name1);//12

上面,使用了person.protoype.name1='12',这样所有的实例都有了name1属性,使用这种方式添加的属性,在生成实例的时候会把属性当作实例的共有属性。

以上这篇基于js中的原型、继承的一些想法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery 常见操作实现方式和常用函数方法总结
May 06 Javascript
jquery.ajax的url中传递中文乱码问题的解决方法
Feb 07 Javascript
jQuery中的pushStack实现原理和应用实例
Feb 03 Javascript
JavaScript实现iframe自动高度调整和不同主域名跨域
Feb 27 Javascript
js实现简单的计算器功能
Jan 16 Javascript
JavaScript判断浏览器及其版本信息
Jan 20 Javascript
vue项目tween方法实现返回顶部的示例代码
Mar 02 Javascript
vuejs实现ready函数加载完之后执行某个函数的方法
Aug 31 Javascript
vuex actions传递多参数的处理方法
Sep 18 Javascript
微信小程序实现点击空白隐藏的方法示例
Aug 13 Javascript
Vue 设置axios请求格式为form-data的操作步骤
Oct 29 Javascript
vue实现淘宝购物车功能
Apr 20 Javascript
新入门node.js必须要知道的概念(必看篇)
Aug 10 #Javascript
jQuery制作圣诞主题页面 更像是爱情影集
Aug 10 #Javascript
jquery实现拖动效果
Aug 10 #Javascript
JS弹出新窗口被拦截的解决方法
Aug 09 #Javascript
只要1K 纯JS脚本送你一朵3D红色玫瑰
Aug 09 #Javascript
JS获取一个未知DIV高度的方法
Aug 09 #Javascript
Bootstrap实现带动画过渡的弹出框
Aug 09 #Javascript
You might like
php 获取文件行数的方法总结
2016/10/11 PHP
laravel框架中路由设置,路由参数和路由命名实例分析
2019/11/23 PHP
由prototype_1.3.1进入javascript殿堂-类的初探
2006/11/06 Javascript
用cookies实现的可记忆的样式切换效果代码下载
2007/12/24 Javascript
jquery 插件学习(三)
2012/08/06 Javascript
IE中jquery.form中ajax提交没反应解决方法分享
2012/09/11 Javascript
js去除空格的12种实用方法
2013/11/08 Javascript
使用focus方法让光标默认停留在INPUT框
2014/07/29 Javascript
jquery插件推荐 jquery.cookie
2014/11/09 Javascript
JS实现的竖向折叠菜单代码
2015/10/21 Javascript
js生成随机数的过程解析
2015/11/24 Javascript
学习JavaScript设计模式(策略模式)
2015/11/26 Javascript
Vue.js实战之使用Vuex + axios发送请求详解
2017/04/04 Javascript
NodeJs中express框架的send()方法简介
2017/06/20 NodeJs
JavaScript判断浏览器和hack滚动条的写法
2017/07/23 Javascript
webpack 动态批量加载文件的实现方法
2020/03/19 Javascript
在vue中实现某一些路由页面隐藏导航栏的功能操作
2020/09/21 Javascript
详解vue-cli项目在IE浏览器打开报错解决方法
2020/12/10 Vue.js
python自动化测试实例解析
2014/09/28 Python
python遍历类中所有成员的方法
2015/03/18 Python
Python中unittest模块做UT(单元测试)使用实例
2015/06/12 Python
深入解析Python中的变量和赋值运算符
2015/10/12 Python
python 3.3 下载固定链接文件并保存的方法
2018/12/18 Python
Python给定一个句子倒序输出单词以及字母的方法
2018/12/20 Python
python GUI库图形界面开发之PyQt5打印控件QPrinter详细使用方法与实例
2020/02/28 Python
django orm模块中的 is_delete用法
2020/05/20 Python
python实现二分类和多分类的ROC曲线教程
2020/06/15 Python
python实现图片,视频人脸识别(dlib版)
2020/11/18 Python
HTML5 的新的表单元素(datalist/keygen/output)使用介绍
2013/07/19 HTML / CSS
英国高街奥特莱斯:Highstreet Outlet
2019/11/21 全球购物
拉丁舞学习者的自我评价
2013/10/27 职场文书
分厂厂长岗位职责
2013/12/29 职场文书
大二学生职业生涯规划书
2014/02/05 职场文书
《赶海》教学反思
2014/04/20 职场文书
四风问题对照检查整改措施思想报告
2014/10/05 职场文书
六查六看自查报告
2014/10/14 职场文书