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

桐梓县工程建设交易网站旅游网站设计论文摘要

桐梓县工程建设交易网站,旅游网站设计论文摘要,wordpress菜单分页,全球做的比较好的网站有哪些1.prototype解释 在JavaScript中#xff0c;prototype对象是实现面向对象的一个重要机制。 每个函数就是一个对象#xff08;Function#xff09;#xff0c;函数对象都有一个子对象 prototype对象#xff0c;类是以函数的形式来定义的。prototype表示该函数的原型#x…1.prototype解释 在JavaScript中prototype对象是实现面向对象的一个重要机制。 每个函数就是一个对象Function函数对象都有一个子对象 prototype对象类是以函数的形式来定义的。prototype表示该函数的原型也表示一个类的成员的集合。 在通过new创建一个类的实例对象的时候prototype对象的成员都成为实例化对象的成员。 1、该对象被类所引用只有函数对象才可引用 2、在new实例化后其成员被实例化实例对象方可调用。 同时函数是一个对象函数对象若直接声明成员不用被实例化即可调用。 上面两点很重要第一点(该对象被类所引用只有函数对象才可引用) 只有当一个对象被定义为函数对象时才拥有对prototype对象引用的prototype属性这点必须知道因为这牵涉到了new一个对象的过程中js引擎要完成对prototype进行一系列操作而普通的js对象由于并不能被new即使拥有prototype也是无意义的第二点在我之前的文章中已讨论过 改变this的引用为实例对象直接定义成员属性所以若直接在函数对象中声明成员无法被实例对象访问。 2.prototype作用 上面说了prototype的一些定义那么prototype有什么作用。上一段落中其中解释了prototype的作用“ 通过new创建一个类的实例对象时prototype对象的成员都成为实例化对象的成员”意思就是我们可以为new创建的实例对象动态添加成员变量而无需在函数对象中定义所有的属性和方法。如下代码 function animal(){}animal.prototype.name animal; animal.prototype.move function(){alert(i can move); }var animalObj new animal(); alert(animalObj.name); animalObj.move(); 运行结果 通过new创建一个函数对象的实例对象时该函数对象的prototype原型对象的成员都能被实例对象访问。之前在我的前一篇文章中《 js中this关键字探讨》就模拟了一下new一个对象的过程但是当时我们并没有涉及到prototype对象那么涉及到了prototype对象这个过程又到底是怎么实现的呢 3.new过程中对prototype对象的操作 一个函数对象被new实例化成为实例对象时可以分解为以下三步用上面的animal对象作为例子 第一步定义animalObj {} 第二步animalObj .__proto__ animal.prototype 第三步animal.call(animalObj ); OK这里需要解释一下__proto__ 每个对象都在其内部初始化一个属性就是__proto__当访问一个对象属性时如果内部不存在这就会去__proto__里找__proto__又会有自己的__proto__于是一直找下去这就是原型链的概念。 当访问animalObj 的name和move属性时animalObj并没有这些属性就会去__proto__中找在第二步中__proto__指向了animal.prototype,所以animal.prototype定义了name和move属性所以就可以访问这些属性。那么到底怎么验证我们对于__proto__的结论呢 按照标准__proto__不对外公开是个私有属性但chrome的引擎将其暴露出来成一个共有的属性可对外访问和设置IE不能直接访问如下 alert(animalObj.__proto__ animal.prototype); 运行结果 总结当一个函数对象被被new为一个实例对象时函数对象的prototype对象中的属性并没有直接成为实例对象的成员属性而是成为实例对象的__proto__对象中的属性而函数对象中的成员需要使用this关键字会被改变引用直接成为实例对象的成员属性 4.prototype扩展实现js对象的继承 上面说到当访问一个对象的成员属性时如果对象本身没有该属性时会去它的__proto__对象中找如果找不到继续找__proto__的__proto__对象中的属性一直往下找。可以利用这一特性实现类似于java中的继承如下代码 // 动物类构造函数 function animal(){}animal.prototype.name animal; animal.prototype.move function(){alert(i can move); }// 定义一个cat对象继承animal中的成员 function cat(){}//prototype实现继承 cat.prototype new animal();// 为cat.prototype增加成员 cat.prototype.detail I am a cat , I am also an animal;// cat的实例对象访问成员属性 var c new cat(); alert(c.detail); alert(c.name); c.move(); 运行结果 过程拆分 1.var a new animal(); 得出a.__proto__ animal.prototype 2.cat.prototype acat.prototype.__proto__ a.__proto__ 3.var c new cat(),得出c.__proto__ cat.prototype,所以c.__proto__.__proto__ animal.prototype; 所以当访问c的detail时本身找不到该属性会找__proto__(即cat.prototype)中是否有该属性找到了该属性同理访问name和move属性时会继续往下遍历__proto__中是否有该属性。 这也就是原型链的实现原理。本质上prototype只是一个假象在实现原型链中只起到辅助作用只是在new的时候有价值原型链的本质其实在于__proto__ 自己搭建的租房网站全网租房助手m.kuairent.com每天新增 500房源
http://www.dnsts.com.cn/news/157449.html

相关文章:

  • 自己如何在网上做网站电脑怎么打不开建设银行网站
  • 移动营销做手机网站南京建设工程质量监督站网站
  • 受欢迎的扬中网站建设wordpress 分页显示
  • 无锡网站建设在哪里梅林 做服务器 网站
  • 网站建设 市场规模wordpress主题woocomece
  • 广东做网站公司房产信息网查不到楼盘信息
  • 网站制作公司 全贵州北京建站的
  • 江西赣州网站最好看免费观看高清大全新员工
  • 手机版网站怎么做的做玩网站怎么上传图片
  • 深圳网站建设自己人项目网络图用什么软件
  • 怎样创建网站快捷方式到桌面京东联盟网站推广位怎么做
  • 宁波市鄞州区建设局网站网站logo怎么做才清晰
  • 揭阳网站如何制作做网站需要
  • 烟台网站建设首推企汇互联见效付款wordpress 5编辑器使用
  • 网站收录量是什么意思公司logo设计免费
  • 教育培训机构网站建设阳泉软件定制网站建设
  • 网站开发最好用什么软件办公室工作绩效 网站建设
  • 做网站头视频md5 wordpress
  • 不同域名一样的网站wordpress评论互动
  • 转笔教学网站seo李守洪排名大师
  • 做招聘网站需要什么资质功能型pc端网站框架
  • 网站突然没有收录seo怎么读
  • 济南网站怎么做工业企业网站建设费
  • 免备案网站主机单页销售网站模板
  • 成都网站建设新闻大型小程序软件开发
  • 服装公司网站建设规划方案wordpress移动端广告添加
  • 大型网站建设优化排名建设网站几钱
  • 在线建设网站制作韩国男女直接做的视频网站
  • 定制网站和模板建站哪个好用网站 封锁右键
  • 美食网站开发天津网站设计服务公司