js之面向对象
2015-11-23 11:55
405 查看
面向对象特点继承,封装,多态
废话不多少,直接贴代码
//1.继承
function Person() {
this.title = "Person";
this.sayHello = function() {
console.log("hello " + this.name);
}
}
var person = new Person();
// 原型继承
function Teacher() {
this.name = "teacher";
}
Teacher.prototype = person;
var t = new Teacher();
t.sayHello();
// 伪继承
function Student() {
Person.call(this);// Person.apply(this);
this.name = "student";
}
var s = new Student();
s.sayHello();
// 拷贝
var _toCopy = {
name : "_toCopy"
}
for ( var key in person) {
_toCopy[key] = person[key];
}
_toCopy.sayHello();
// 2.多态
function multiformity(a, b, c, d, e, f, g) {
}
multiformity(1);
multiformity(1, 2);
multiformity(1, 2, "zhansan");
// 接口,JS真的需要接口吗??
// 模拟java迭代器
Array.prototype.iterator = function() {
var self = this, pos = 0;
return {
hasNext : function() {
return pos < self.length;
},
next : function() {
self[pos++];
}
}
}
var it = [ 12, 3, 4 ].iterator();
while (it.hasNext()) {
it.next();
}
废话不多少,直接贴代码
//1.继承
function Person() {
this.title = "Person";
this.sayHello = function() {
console.log("hello " + this.name);
}
}
var person = new Person();
// 原型继承
function Teacher() {
this.name = "teacher";
}
Teacher.prototype = person;
var t = new Teacher();
t.sayHello();
// 伪继承
function Student() {
Person.call(this);// Person.apply(this);
this.name = "student";
}
var s = new Student();
s.sayHello();
// 拷贝
var _toCopy = {
name : "_toCopy"
}
for ( var key in person) {
_toCopy[key] = person[key];
}
_toCopy.sayHello();
// 2.多态
function multiformity(a, b, c, d, e, f, g) {
}
multiformity(1);
multiformity(1, 2);
multiformity(1, 2, "zhansan");
// 接口,JS真的需要接口吗??
// 模拟java迭代器
Array.prototype.iterator = function() {
var self = this, pos = 0;
return {
hasNext : function() {
return pos < self.length;
},
next : function() {
self[pos++];
}
}
}
var it = [ 12, 3, 4 ].iterator();
while (it.hasNext()) {
it.next();
}
相关文章推荐
- json的运用
- 字符串转换JSON
- Javascript动态绑定
- JavaScript函数
- JSP中getParameter与getAttribute区别
- js函数的调用
- js中对时间的操作
- js为某个元素添加某个类,并为其他兄弟元素删除此类
- js检测是否为数组
- JSTL标签 参考手册(手动整理)
- javascript中style.left和offsetLeft的用法说明
- JSP基本指令
- js判断各个浏览器的方法
- 《Effective JavaScript》- 1.4 原始类型优于封装对象
- js prototype
- javascript实现uploadify上传格式以及个数限制
- 正则验证js大全
- jsoncpp使用方法
- JavaScript高级教程5.6之基本包装类型(详细)
- js在客户端控制上传图片的大小