JS面向对象之类的创建
2018-02-23 10:57
134 查看
<!DOCTYPE html>
<html>
<head>
<title>JS面向对象之类的创建</title>
</head>
<body>
<script type="text/javascript">
/* 对象*/
/*var obj = new obj();
obj.name = "z3";
obj.sex = "男";
obj.age = 20;*/
/* 模拟类*/
// 1.工厂模型
/* function createPerson(name,sex,age)
{
var obj = new Object();
obj.name = name;
obj.sex = sex;
obj.age = age;
obj.sayName = function() {
alert("我是"+this.name);
}
return obj;
}
var p1 = createPerson("z3","男",20);
var p2 = createPerson("z4","女",25);*/
// 2.构造函数式
function Person(name, sex, age) {
this.name = name;
this.sex = sex;
this.age = age;
this.sayName = function() {
alert(this.name);
}
}
// 创造对象的方式
// (1) 当做构造函数使用
// 构造一个对象 需要new关键字,传递参数,执行函数模板,返回对象
/* var p1 = new Person("z3","男",20);
var p2 = new Person("z2","女",25);*/
// (2) 作为普通函数调用
//var p2 = Person("z3","男",20);//Person()执行完就是给windows对象加属性,this总是指向当前调用对象
// (3) 在另一个对象的作用域中使用 --> 使用call() ,apply()
var o = new Object();
Person.call(o,"z3","男",20);
alert(o instanceof Person);//false 此时 o的构造器是object
</script>
</body>
</html>
<html>
<head>
<title>JS面向对象之类的创建</title>
</head>
<body>
<script type="text/javascript">
/* 对象*/
/*var obj = new obj();
obj.name = "z3";
obj.sex = "男";
obj.age = 20;*/
/* 模拟类*/
// 1.工厂模型
/* function createPerson(name,sex,age)
{
var obj = new Object();
obj.name = name;
obj.sex = sex;
obj.age = age;
obj.sayName = function() {
alert("我是"+this.name);
}
return obj;
}
var p1 = createPerson("z3","男",20);
var p2 = createPerson("z4","女",25);*/
// 2.构造函数式
function Person(name, sex, age) {
this.name = name;
this.sex = sex;
this.age = age;
this.sayName = function() {
alert(this.name);
}
}
// 创造对象的方式
// (1) 当做构造函数使用
// 构造一个对象 需要new关键字,传递参数,执行函数模板,返回对象
/* var p1 = new Person("z3","男",20);
var p2 = new Person("z2","女",25);*/
// (2) 作为普通函数调用
//var p2 = Person("z3","男",20);//Person()执行完就是给windows对象加属性,this总是指向当前调用对象
// (3) 在另一个对象的作用域中使用 --> 使用call() ,apply()
var o = new Object();
Person.call(o,"z3","男",20);
alert(o instanceof Person);//false 此时 o的构造器是object
</script>
</body>
</html>
相关文章推荐
- js面向对象 多种创建对象方法小结
- [js高手之路]搞清楚面向对象,必须要理解对象在创建过程中的内存表示
- 深入理解js面向对象——创建对象
- JavaScript面向对象之类的创建
- JS面向对象,创建,继承
- JS面向对象之创建对象模式
- JavaScript面向对象之类的创建
- js面向对象,多种创建对象方法!
- js面向对象,多种创建对象方法!
- JS面向对象的几种创建方式:工厂模式、构造函数模式、原型模式、混合模式、动态原型模式
- js面向对象,多种创建对象方法!
- js面向对象,多种创建对象方法!
- 前端-JS基于原型面向对象(对象创建,继承,构造等)
- JS面向对象,创建,继承
- js 面向对象的技术创建高级 Web 应用程序
- js基础进阶2-2 面向对象(类与对象的创建与使用)
- JS面向对象(二)------------创建对象
- php面向对象之类的创建
- [js高手之路]搞清楚面向对象,必须要理解对象在创建过程中的内存表示
- JS面向对象,从创建对象到对象继承