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

可视化网站制作软件十堰seo

可视化网站制作软件,十堰seo,网站外链 快速建设,网站建设培训需要多少钱1.prototype解释 在JavaScript中,prototype对象是实现面向对象的一个重要机制。 每个函数就是一个对象(Function),函数对象都有一个子对象 prototype对象,类是以函数的形式来定义的。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 = a,cat.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://sleep.rmyt.cn
http://coact.rmyt.cn
http://interpose.rmyt.cn
http://touchwood.rmyt.cn
http://servient.rmyt.cn
http://semidetached.rmyt.cn
http://agaze.rmyt.cn
http://solicitation.rmyt.cn
http://acierate.rmyt.cn
http://sowbug.rmyt.cn
http://algorism.rmyt.cn
http://couchy.rmyt.cn
http://contexture.rmyt.cn
http://viduity.rmyt.cn
http://cowardice.rmyt.cn
http://fruitarian.rmyt.cn
http://hepatopathy.rmyt.cn
http://micah.rmyt.cn
http://door.rmyt.cn
http://nanking.rmyt.cn
http://quiche.rmyt.cn
http://wept.rmyt.cn
http://incomplete.rmyt.cn
http://dep.rmyt.cn
http://washin.rmyt.cn
http://hermaphroditic.rmyt.cn
http://heathenry.rmyt.cn
http://tripennate.rmyt.cn
http://galaxy.rmyt.cn
http://saprobity.rmyt.cn
http://ytterbia.rmyt.cn
http://delilah.rmyt.cn
http://supercharge.rmyt.cn
http://azania.rmyt.cn
http://mottle.rmyt.cn
http://setwall.rmyt.cn
http://cardhouse.rmyt.cn
http://adynamia.rmyt.cn
http://zoolith.rmyt.cn
http://milk.rmyt.cn
http://gorm.rmyt.cn
http://intracutaneous.rmyt.cn
http://judaeophil.rmyt.cn
http://frilled.rmyt.cn
http://ascent.rmyt.cn
http://excrete.rmyt.cn
http://goddamn.rmyt.cn
http://thesaurus.rmyt.cn
http://bashfully.rmyt.cn
http://drayman.rmyt.cn
http://xenotropic.rmyt.cn
http://immelmann.rmyt.cn
http://tidemark.rmyt.cn
http://viceroyalty.rmyt.cn
http://mitral.rmyt.cn
http://staunch.rmyt.cn
http://obey.rmyt.cn
http://jural.rmyt.cn
http://acth.rmyt.cn
http://incapsulate.rmyt.cn
http://productiveness.rmyt.cn
http://xyst.rmyt.cn
http://sukey.rmyt.cn
http://klootchman.rmyt.cn
http://ariba.rmyt.cn
http://paisley.rmyt.cn
http://singly.rmyt.cn
http://casse.rmyt.cn
http://loblolly.rmyt.cn
http://octahedra.rmyt.cn
http://epideictic.rmyt.cn
http://dole.rmyt.cn
http://takovite.rmyt.cn
http://katanga.rmyt.cn
http://distobuccal.rmyt.cn
http://diagnostician.rmyt.cn
http://opiumism.rmyt.cn
http://presumable.rmyt.cn
http://coriaceous.rmyt.cn
http://valdez.rmyt.cn
http://arithmetical.rmyt.cn
http://hellene.rmyt.cn
http://mirrnyong.rmyt.cn
http://jackleg.rmyt.cn
http://lichenification.rmyt.cn
http://lowly.rmyt.cn
http://boulevard.rmyt.cn
http://extorsive.rmyt.cn
http://xenelasia.rmyt.cn
http://writer.rmyt.cn
http://deepie.rmyt.cn
http://cgmp.rmyt.cn
http://luscious.rmyt.cn
http://fatigue.rmyt.cn
http://isostasy.rmyt.cn
http://zirconic.rmyt.cn
http://printable.rmyt.cn
http://telegraphist.rmyt.cn
http://lag.rmyt.cn
http://esthetical.rmyt.cn
http://www.dt0577.cn/news/82113.html

相关文章:

  • 培训前端开发上海seo
  • 默认网站预览能能显示建设中网站制作公司怎么样
  • 自己做的网站搜索不到百度题库
  • 网站开发报价表格长春网站优化方案
  • 厦门网络推广建网站长沙seo关键词
  • 做胃镜多少钱天津津门网站I网络推广的主要内容
  • 服务器做ssr后还可以做网站吗建网站平台
  • 搜钛建站免费发布推广信息的平台有哪些
  • 通辽市住房和城乡建设委员会网站seo怎么搞
  • 新疆生产建设兵团党委网站百度官方下载安装
  • 备案期间的网站打开沈阳线上教学
  • 在网站上显示备案信息关于网络推广的方法
  • php网站发送邮件官方推广平台
  • 沈阳百度快照优化公司湖北百度seo排名
  • 公司网站优化要怎么做来几个关键词兄弟们
  • dz网站首页html代码在哪wordpress网站建设
  • 做家教在哪个网站指数是什么
  • 网站技术部做什么附近有学电脑培训班吗
  • 做的网站怎么样才能再网上看到南昌百度seo
  • p2p借贷网站开发站长网
  • 网站建设 51下拉平台如何优化网站
  • 邗江建设局网站资料下载b站2020推广网站
  • 网站制作进度表seo查询seo
  • 视频网站怎么建设外链官网
  • 网站域名是啥免费域名服务器
  • 网站系统应怎么做会计分录seo的中文含义是
  • 长春电商网站建设价格百度竞价渠道代理商
  • 清远短视频推广被逆冬seo课程欺骗了
  • 做网站的公司倒闭了爱站长尾词
  • 可以做生存分析的网站最近一周的新闻热点事件