javascript --- 面向对象 --- 封装
javascript中有原型对象和实例对象
如有疑问请参考:http://www.ruanyifeng.com/blog/2010/05/object-oriented_javascript_encapsulation.html
下面的代码可以用Rhino解释,代码如下:
/** * Cat的对象 * name、color;猫科动物,吃老鼠 */ print("--- --- --- 生成对象的原始模式 --- ---"); /*var Cat = { name : '', color : '' };*/ var cat1 = {}; cat1.name = "mao1"; cat1.colr = "orange"; print("cat1 : name=" + cat1.name + ", color=" + cat1.colr); print(); print("--- --- --- 原始模式的改进 --- ---"); function Cat1(name,color){ return { name:name, color:color }; }; var cat2 = Cat1("mao2", "yellow"); print("cat2 : name=" + cat2.name + ", color=" + cat2.color); print(); print("--- --- --- 构造函数模式 --- ---"); function Cat2(name, color){ this.name = name; this.color = color; } var cat3 = new Cat2("mao3", "blue"); print("cat3 : name=" + cat3.name + ", color=" + cat3.color); print("cat3.constructor == Cat2 --- " + (cat3.constructor == Cat2)); print("cat3 instanceof Cat2 --- --- " + (cat3 instanceof Cat2)); print(); print("--- --- --- 构造函数模式的问题 --- ---"); function Cat3(name, color){ this.name = name; this.color = color; this.type = "猫科动物"; this.eat = function(){ print("吃老鼠"); }; } var cat4 = new Cat3("mao4", "red"); var cat5 = new Cat3("mao5", "pink"); print("cat4 : name=" + cat4.name + ", color=" + cat4.color + ", type=" + cat4.type); cat4.eat(); print("cat5 : name=" + cat5.name + ", color=" + cat5.color + ", type=" + cat5.type); cat5.eat(); print("cat4.type == cat5.type --- --- " + (cat4.type == cat5.type)); print("cat4.eat == cat5.eat() --- --- " + (cat4.eat == cat5.eat)); print(); print("--- --- --- Prototype模式 --- ---"); function Cat4(name,color){ this.name = name; this.color = color; } Cat4.prototype.type = "猫科动物"; Cat4.prototype.eat = function(){ print("吃老鼠"); }; var cat6 = new Cat4("mao6", "green"); var cat7 = new Cat4("mao7", "gray"); print("cat6 : name=" + cat6.name + ", color=" + cat6.color + ", type=" + cat6.type); cat6.eat(); print("cat7 : name=" + cat7.name + ", color=" + cat7.color + ", type=" + cat7.type); cat7.eat(); print("cat6.type == cat7.type --- --- " + (cat6.type == cat7.type)); print("cat6.eat == cat7.eat --- --- - " + (cat6.eat == cat7.eat)); print(); print("--- --- --- Prototype模式的验证方法 --- ---"); print("Cat4.prototype.isPrototypeOf(cat6) --- " + Cat4.prototype.isPrototypeOf(cat6)); print("Cat4.prototype.isPrototypeOf(cat5) --- " + Cat4.prototype.isPrototypeOf(cat5)); print('cat6.hasOwnProperty("name") --- --- ' + cat6.hasOwnProperty("name")); print('cat6.hasOwnProperty("type") --- --- ' + cat6.hasOwnProperty("type")); print('"name" in cat7 --- ---' + ("name" in cat7)); print('"colr" in cat7 --- ---' + ("colr" in cat7)); for(var prop in cat7) { print("\tcat7["+prop+"] = " + cat7[prop]); }
打印结果如下:
--- --- --- 生成对象的原始模式 --- --- cat1 : name=mao1, color=orange --- --- --- 原始模式的改进 --- --- cat2 : name=mao2, color=yellow --- --- --- 构造函数模式 --- --- cat3 : name=mao3, color=blue cat3.constructor == Cat2 --- true cat3 instanceof Cat2 --- --- true --- --- --- 构造函数模式的问题 --- --- cat4 : name=mao4, color=red, type=猫科动物 吃老鼠 cat5 : name=mao5, color=pink, type=猫科动物 吃老鼠 cat4.type == cat5.type --- --- true cat4.eat == cat5.eat() --- --- false --- --- --- Prototype模式 --- --- cat6 : name=mao6, color=green, type=猫科动物 吃老鼠 cat7 : name=mao7, color=gray, type=猫科动物 吃老鼠 cat6.type == cat7.type --- --- true cat6.eat == cat7.eat --- --- - true --- --- --- Prototype模式的验证方法 --- --- Cat4.prototype.isPrototypeOf(cat6) --- true Cat4.prototype.isPrototypeOf(cat5) --- false cat6.hasOwnProperty("name") --- --- true cat6.hasOwnProperty("type") --- --- false "name" in cat7 --- ---true "colr" in cat7 --- ---false cat7[name] = mao7 cat7[color] = gray cat7[type] = 猫科动物 cat7[eat] = function () { print("\u5403\u8001\u9f20"); }
javascript --- 面向对象 --- 封装的更多相关文章
- Javascript面向对象(封装、继承)
Javascript 面向对象编程(一):封装 作者:阮一峰 Javascript是一种基于对象(object-based)的语言,你遇到的所有东西几乎都是对象.但是,它又不是一种真正的面向对象编程( ...
- JavaScript面向对象--封装
一.封装的概念 面向对象的类包括两大成员,一种是暴露给外部的接口,另一种是只在类内部才能访问的私有属性.在这个类被实例化成对象后,用户只能通过操作给定的接口来访问该类内部的私有属性,这就被称为面向对象 ...
- Javascript面向对象特性实现封装、继承、接口详细案例——进级高手篇
Javascript面向对象特性实现(封装.继承.接口) Javascript作为弱类型语言,和Java.php等服务端脚本语言相比,拥有极强的灵活性.对于小型的web需求,在编写javascript ...
- javascript面向对象(一):封装
本文来自阮一峰 学习Javascript,最难的地方是什么? 我觉得,Object(对象)最难.因为Javascript的Object模型很独特,和其他语言都不一样,初学者不容易掌握. 下面就是我的学 ...
- 【转】Javascript 面向对象编程(一):封装
原文链接:http://www.ruanyifeng.com/blog/2010/05/object-oriented_javascript_encapsulation.html Javascript ...
- Javascript 面向对象编程(一):封装 by 阮一峰
<Javascript高级程序设计(第二版)>(Professional JavaScript for Web Developers, 2nd Edition) 它们都是非常优秀的Java ...
- JavaScript面向对象轻松入门之封装(demo by ES5、ES6、TypeScript)
本章默认大家已经看过作者的前一篇文章 <JavaScript面向对象轻松入门之抽象> 为什么要封装? 封装(Encapsulation)就是把对象的内部属性和方法隐藏起来,外部代码访问该对 ...
- Javascript 面向对象编程—封装
前 言 Javascript是一种基于对象(object-based)的语言,你遇到的所有东西几乎都是对象.但是,它又不是一种真正的面向对象编程(OOP)语言,因为它的语法中没有class(类) ...
- Javascript 面向对象编程—继承和封装
前 言 Javascript是一种基于对象(object-based)的语言,你遇到的所有东西几乎都是对象.但是,它又不是一种真正的面向对象编程(OOP)语言,因为它的语法中没有class(类) ...
随机推荐
- TCP三次握手和四次挥手过程及套接字在各个过程中的状态解析
说起TCP,我们一般都需要知道发起一个tcp连接和终止一个tcp连接是所发生的事情,下边,我将跟大家介绍下tcp的三次握手及四次挥手的过程. TCP三路握手 (1)服务器必须准备好接受外来的连接.这通 ...
- .net Windows服务程序和安装程序制作图解 及 VS 2010创建、安装、调试 windows服务(windows service)
.net Windows服务程序和安装程序制作 最近项目中用到window服务程序,以前没接触过,比较陌生,花了两天的时间学习了下,写了个简单的服务,但在制作安装程序的时候,参照网上很多资料,却都制作 ...
- Spring高级事务管理难点剖析
1Spring事务传播行为 所谓事务传播行为就是多个事务方法相互调用时,事务如何在这些方法间传播.Spring支持7种事务传播行为 PROPAGATION_REQUIRED(加入已有事务) 如果当前没 ...
- Javascript上下文
var User = { count: 1, getCount: function() { return this.count; } }; console.log(User.getCount()); ...
- hdu - 1242 Rescue && hdu - 2425 Hiking Trip (优先队列+bfs)
http://acm.hdu.edu.cn/showproblem.php?pid=1242 感觉题目没有表述清楚,angel的朋友应该不一定只有一个,那么正解就是a去搜索r,再用普通的bfs就能过了 ...
- How to: Write Object Data to an XML File
This example writes the object from a class to an XML file using the XmlSerializer class. Namespace: ...
- R语言数据类型转换
test for data type is.numeric(), is.character(), is.vector(), is.matrix(), is.data.frame() convert i ...
- 添加crontab为什么要重定向输出到/dev/null
如果crontab不重定向输出,并且crontab所执行的命令有输出内容的话,是一件非常危险的事情.因为该输出内容会以邮件的形式发送给用户,内容存储在邮件文件 /var/spool/mail/$use ...
- Spring+Hibernate配置多数据源
配置说明 在实际应用中,经常会用到读写分离,这里就这种情况进行Spring+Hibernate的多数据源配置.此处的配置只是让读的方法操作一个数据库,写的方法操作另外一个数据库. 注:我这里的配置JD ...
- bzoj2119
题意就是差分后求形如ABA的串的个数,B的长度为M 这是2011国家集训队互测的试题,是道好题,我直接给出出题人的题解吧: 对于这种在线性序列上的组合计数问题,我们很容易想到一个工具:分治!分治算法在 ...