最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

JavaScript学习笔记(六)_javascript技巧

来源:动视网 责编:小采 时间:2020-11-27 20:46:35
文档

JavaScript学习笔记(六)_javascript技巧

JavaScript学习笔记(六)_javascript技巧:一、 工厂方式 自己的理解:要创建很多个对象的实例,这些实例有相同的属性,但是有不同的属性值。这个时候就需要创个工厂函数(factory function)。 工厂函数(factory function):创建并返回特定类型的对象。 工厂函数中如果一个属性是方法的话,可以在工
推荐度:
导读JavaScript学习笔记(六)_javascript技巧:一、 工厂方式 自己的理解:要创建很多个对象的实例,这些实例有相同的属性,但是有不同的属性值。这个时候就需要创个工厂函数(factory function)。 工厂函数(factory function):创建并返回特定类型的对象。 工厂函数中如果一个属性是方法的话,可以在工


一、 工厂方式
自己的理解:要创建很多个对象的实例,这些实例有相同的属性,但是有不同的属性值。这个时候就需要创个工厂函数(factory function)。
工厂函数(factory function):创建并返回特定类型的对象。
工厂函数中如果一个属性是方法的话,可以在工厂函数的外面定义对象的方法,然后通过属性指向该方法,从而可以避开每次都调用自己的属性方法,这样做使得每个对象都共享了同一个函数。
示例:
代码如下:
输出“小三,小四,小五”

四、 混合的构造函数/原型方式
联合使用构造函数和原型方式,就可以像其他语言一样的创建对象。
构造函数定义对象的所有非函数属性,原型方式定义对象的函数属性(方法)。
示例:
代码如下:
function BOStudent(name,age) {
this.姓名 = name;
this.年龄 = age;
this.课程 = new Array("语文","数学");
}
BOStudent.prototype.ShowName = function() {
alert(this.姓名);
};
//点击按钮调试
function Admixture() {
var stu1 = new BOStudent("张三", 20); //new第一个BO
var stu2 = new BOStudent("李四", 22); //new第二个BO
stu1.课程.push("物理"); //给对象1 添加物理课程项
alert(stu1.课程);
alert(stu2.课程);
}

混合的构造函数/原型方式是ECMAScript采用的主要方式,他具有其他方式的特性,却没有他们的副作用。
五、 动态原型方法
大多数的面向对象语言,定义类时,属性和方法都打包在一起。而上面的混合构造函数/原型方式属性和方法是分开的,有些人认为在构造函数内部找属性,在外面找方法的做法不合逻辑,因此也就产生了动态原型方法。
区别在于:赋予对象的方法的位置不同。动态原型方法是在构造函数的内部,而上面的第四种是在构造函数外部。
示例:
代码如下:
function BODynamicPrototype(name, age) {
this.姓名 = name;
this.年龄 = age;
this.课程 = new Array("111", "222");
//_initialized标识判断是否已经初始化过,即是否已给原型赋予了任何方法,该方法只创建并赋值一次
if (typeof BODynamicPrototype._initialized == "undefined") {
BODynamicPrototype.prototype.ShowName = function() {
alert(this.姓名);
};
BODynamicPrototype._initialized = true;
}
}

//点击按钮调试
function DynamicPrototype() {
var stu1 = new BODynamicPrototype("aaa", 20); //new第一个BO
var stu2 = new BODynamicPrototype("bbb", 22); //new第二个BO
stu1.课程.push("333"); //给对象1 添加物理课程项
alert(stu1.课程);
alert(stu2.课程);
}

六、 混合工厂方式
目的是创建假构造函数,只返回另一种对象的新实例。这种方式在对象方法内部管理方面与经典方式有着相同的问题。强烈建议:除非万不得已避免使用!

文档

JavaScript学习笔记(六)_javascript技巧

JavaScript学习笔记(六)_javascript技巧:一、 工厂方式 自己的理解:要创建很多个对象的实例,这些实例有相同的属性,但是有不同的属性值。这个时候就需要创个工厂函数(factory function)。 工厂函数(factory function):创建并返回特定类型的对象。 工厂函数中如果一个属性是方法的话,可以在工
推荐度:
标签: 学习 js javascript
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top