- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
Json prototype 闭包 构造函数
?
Json,prototype,闭包,构造函数2010-07-08 19:53Json,prototype,闭包,构造函数2008年10月24日星期五上午11:34JSON已经说了许多了许多话题了,但有一个很基本的问题我们忘了讨论,那就是:怎样建立对象?在前面的示例中,我们已经涉及到了对象的建立了。我们使用了一种被称为JavaScript Object Notation(缩写JSON)的形式,翻译为中文就是JavaScript对象表示法。JSON为创建对象提供了非常简单的方法。例如,创建一个没有任何属性的对象:var o={};创建一个对象并设置属性及初始值:var person={name:Angel,age:18,married:false};创建一个对象并设置属性和方法:var speaker={text:Hello World,say:function(){alert(this.text)}};创建一个更复杂的对象,嵌套其他对象和对象数组等:var company={name:Microsoft,product:softwares,chairman:{name:Bill Gates,age:53,Married:true},employees:[{name:Angel,age:26,Married:false},{name:Hanson,age:32,Marred:true}],readme:function(){document.write(this.name+product+this.product);}};JSON的形式就是用大括{}号包括起来的项目列表,每一个项目间并用逗号,分隔,而项目就是用冒号:分隔的属性名和属性值。这是典型的字典表示形式,也再次表明了JavaScript里的对象就是字典结构。不管多么复杂的对象,都可以被一句JSON代码来创建并赋值。其实,JSON就是JavaScript对象最好的序列化形式,它比XML更简洁也更省空间。对象可以作为一个JSON形式的字符串,在网络间自由传递和交换信息。而当需要将这个JSON字符串变成一个JavaScript对象时,只需要使用eval函数这个强大的数码转换引擎,就立即能得到一个JavaScript内存对象。正是由于JSON的这种简单朴素的天生丽质,才使得她在AJAX舞台上成为璀璨夺目的明星。JavaScript就是这样,把面向对象那些看似复杂的东西,用及其简洁的形式表达出来。卸下对象浮华的浓妆,还对象一个眉目清晰!构造对象好了,接下我们来讨论一下对象的另一种创建方法。除JSON外,在JavaScript中我们可以使用new操作符结合一个函数的形式来创建对象。例如:function MyFunc(){};//定义一个空函数var anObj=new MyFunc();//使用new操作符,借助MyFun函数,就创建了一个对象JavaScript的这种创建对象的方式可真有意思,如何去理解这种写法呢?其实,可以把上面的代码改写成这种等价形式:function MyFunc(){};var anObj={};//创建一个对象MyFunc.call(anObj);//将anObj对象作为this指针调用MyFunc函数我们就可以这样理解,JavaScript先用new操作符创建了一个对象,紧接着就将这个对象作为this参数调用了后面的函数。其实,JavaScript内部就是这么做的,而且任何函数都可以被这样调用!但从anObj=new MyFunc()这种形式,我们又看到一个熟悉的身影,C++和C#不就是这样创建对象的吗?原来,条条大路通灵山,殊途同归啊!
请看下面的代码:
1 function Person(name)//带参数的构造函数2{3 this.name=name;//将参数值赋给给this对象的属性4 this.SayHello=function(){alert(Hello,Im+this.name);};//给this对象定义一个SayHello方法。5};6 7function Employee(name,salary)//子构造函数8{9 Person.call(this,name);//将this传给父构造函数10 this.salary=salary;//设置一个this的salary属性11 this.ShowMeTheMoney=function(){alert(this.name+$+this.salary);};//添加ShowMeTheMoney方法。12};13 14 var BillGates=new Person(Bill Gates);//用Person构造函数创建BillGate
您可能关注的文档
最近下载
- 1.4《研究二氧化碳的性质》实验教学说课 六年级上册科学 苏教版.pptx
- 1 小蝌蚪找妈妈 课件 2025-2026小学语文二年级上册 统编版.pptx VIP
- 针灸治疗肿瘤.pptx VIP
- 课题申报书:红色文化资源赋能高校“大思政课”体系建设研究.docx VIP
- 2024年中级经济师《经济基础》真题卷(1116下午).pdf VIP
- 我的祖国英语演讲稿2分钟.docx VIP
- 药品批发企业内审.docx VIP
- 【MOOC】中国电影经典影片鉴赏-北京师范大学 中国大学慕课MOOC答案.docx VIP
- 旋律的构成要素一、旋律线.pptx VIP
- 药品批发企业年度质量体系评审评审报告(供货单位).docx VIP
文档评论(0)