位置: 编程技术 - 正文

javascript中的原型链深入理解(javascript的原型,原型链,有什么特点?)

编辑:rootadmin
要弄清楚原型链就要先弄清楚 function 类型,在javascript中没有类的概念,都是函数,所以它是一门函数式的编程语言。类有一个很重要的特性,就是它可以根据它的构造函数来创建以它为模板的对象。在javascript中,函数就有2个功能 第一、 作为一般函数调用 第二、 作为它原型对象的构造函数 也就new() 我们来看一个例子 当创建一个函数,它会发生什么呢? 第一、它会创建1个函数对象 也就是a 本身 第二、它会创建1个原型对象@a(用@来表示) 第三、函数对象会有一个prototype指针,它指向了对应的原型对象,这里就指向了@a 第四、@a对象中有一个construtor指针,指向它的构造函数,这里就指向了a 这个prototype属性究竟有什么用呢? 其实prototype 属性表示当前函数能够控制的范围(或者说它指明了当前函数是谁的构造函数),这里a就是@a原型对象的构造函数,所以我们会看见有这种写法 这就和其他常见语言相似了,new 就是调用原型对象(通过prototype指针)里面构造函数(constructor)创建一个新的对象实例。 那么修改了prototype指向对象里面的属性,也就影响了所有以它为模板创建的实例,我们可以这样来验证 结果:1 那为什么a1对象可以直接访问到age属性呢?a1对象里面我并没有定义age属性啊, 那是因为所有实例里面都会有一个引用_proto_(在firfox,chrome下可以直接访问,ie不支持)指向了这个原型,这里就是指向了@a, 结果:true 在访问属性的时候,会先在a1对象内部中寻找,如果没有,就会顺着_proto_指向的对象里面去寻找,这里会到@a中寻找,找到就返回值,没有找到就返回undefined,用个成语来形容,就是顺藤摸瓜嘛! 至此原型链的含义就出来了,由于原型对象也有一个_proto_指针,又指向了另一个原型,一个接一个,就形成了原型链。Object.prototype是最顶层的原型,所以如果修改了Object.prototype的属性,那么就影响了所有的对象。 在来看一段代码 我们显示的将b的原型指向了a的一个实例,然后,b的实例也可以访问a的属性了。这就是javascript的继承了,那为什么b.prototype 指向的是a的一个实例,而不是直接指向a.prototype 呢? 如果像上面这么写,修改p.prototype中的属性,那么a的原型也会改变了,相当于是子类修改了父类,并且子类和父类的属性糅合在了一起,这显然是不合适的。换句话说,b也成为了@a的构造函数,a,b成了平级的关系。 我们可以下一个定义: 函数a 继承函数b 也就是让函数a成为函数b原型的一个实例的构造函数,构造函数里面声明的属性是函数a自己的,原型实例里面的属性就是继承b的 这是jquery的一段源码,我们在使用jquery的时候,并没有使用new关键字,那它是如何构造对象的呢? 用上面的知识,可以解释,jquery这里只是一个一般函数的调用,它返回了jquery原型的另外一个构造函数创建的对象,也就是new init()

推荐整理分享javascript中的原型链深入理解(javascript的原型,原型链,有什么特点?),希望有所帮助,仅作参考,欢迎阅读内容。

javascript中的原型链深入理解(javascript的原型,原型链,有什么特点?)

文章相关热门搜索词:js中的原型是什么,javascript原型,js中的原型是什么,javascript中的原型和原型链,javascript的原型,原型链,有什么特点?,javascript中的原型和原型链,javascript中的原型和原型链,javascript原型,内容如对您有帮助,希望把文章链接给更多的朋友!

javascript对象的使用和属性操作示例详解 JavaScript中所有变量都是对象,除了两个例外null和undefined。false.toString();//'false'[1,2,3].toString();//'1,2,3'functionFoo(){}Foo.bar=1;Foo.bar;//1一个常见的误解是数字的

js的hasownproperty使用示例 例如:有这么一段代码:vararray=[];array.push(1);array.push(2);array.push(3);for(variinarray){console.log(i+":"+array[i]);}此时会输出什么呢?当然是0:::3但是如果在forin之

js函数在frame中的相互调用详解 框架间的互相引用一个页面中的所有框架以集合的形式作为window对象的属性提供,例如:window.frames就表示该页面内所有框架的集合,这和表单对象、链

标签: javascript的原型,原型链,有什么特点?

本文链接地址:https://www.jiuchutong.com/biancheng/373741.html 转载请保留说明!

上一篇:Javascript中引用示例介绍(js如何引用)

下一篇:javascript对象的使用和属性操作示例详解(javascript对象的种类)

  • 提供劳务代扣的发票
  • 公司租房代房东缴纳租房税金
  • 行政事业单位购买固定资产的流程
  • 建筑安装服务的发票
  • 印花税是按开票收入申报的吗
  • 企业级软件开发
  • 个人承包工程如何避税
  • 资产总额全年季度平均值怎么填写
  • 企业建设项目审批流程
  • 发票如何保存
  • 高速路费电子发票怎么打印
  • 最新出口退税申报流程
  • 汇票本票的区别
  • 进货发票未到怎么做账
  • 库存红字冲销
  • 个人所得税违规怎么处理
  • 跨期费用审计调整分录
  • 耳机插在电脑上有滋滋的声音
  • 固定资产清理和固定资产减值准备的区别
  • 企业原材料成本有哪些
  • 高新企业认定条件2019
  • 公司为员工购买社保流程
  • mac菜单栏如何调整位置
  • 航天税控服务费
  • 华硕win10笔记本如何恢复出厂设置
  • 筹建期间业务招待费的处理
  • 公司比赛奖金计入什么科目
  • 辞退补偿款怎么算
  • 超经营范围开具发票
  • codeignitor
  • 年终奖并入综合所得
  • 月底结转汇兑损益
  • vue3.0教程
  • gdal官方文档
  • php rtrim
  • 工程完工收到工程发票
  • 销售商品怎么做好宣传
  • 土地增值税扣除率怎样计算
  • 资产负债表净资产为负数
  • mongodb集群启动顺序
  • dedecms主页修改
  • 向境外机构支付的服务费税收政策
  • 其它应收款的处理程序
  • 销货清单要放凭证里吗
  • 劳务合同的特征有()
  • 文化建设税减免政策
  • 发票使用范围指什么
  • 支付利息的现金流
  • 以前年度损益调整是什么意思
  • 如何加强存货管理,提高存货周转率
  • 固定基金减少的理由
  • 做无票收入如何报税
  • 股东实收资本超额到位
  • 主营业务收入是含税还是不含税
  • 企业购买黄金如何入账
  • 以前年度调整要更正申报吗
  • mysql必知必会和sql基础教程
  • 不一样的萧先生
  • centos直接安装
  • ubuntu20.04升级21.04
  • linux修改密码认证令牌错误
  • win10自定义你的设备有什么用
  • 如何快速破局
  • win7系统快速关机快捷键
  • store与storage的区别
  • nodejs连接达梦数据库
  • 怎样用在js中使用css的内容
  • nodejsapi
  • 批处理程序删除文件夹中临时文件
  • centos安装完成后桌面没有图标
  • node发送邮箱
  • 运行shell脚本命令 sh
  • unity3d题库
  • angularjs input
  • android Intent Flags详解
  • jqueryui dialog
  • listview.items.add
  • 欠税务局税款的后果
  • 顺德中学校徽图片大全1998年
  • 财务制度备案表单怎么填
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设