位置: 编程技术 - 正文

从面试题学习Javascript 面向对象(创建对象)(面试java基础知识)

编辑:rootadmin
题目: 知识点: (1)JS面向对象基础:ECMA-把对象定义为:“无序属性的集合,其属性可以包含基本值、对象或者函数”。 (2)JS创建对象的方法:   (a)工厂模式:用函数来封装以特定接口创建对象的细节。       function createPerson(name, age, job){           var o = new Object();           o.name = name;           o.age = age;           o.job = job;           o.sayName = function(){           alert(this.name);           };       return o;       }     var person1 = createPerson(“Nicholas”, , “Software Engineer”);     var person2 = createPerson(“Greg”, , “Doctor”);     缺点:工厂模式虽然解决了创建多个相识对象的问题,但却没有解决对象识别的问题(即怎样知道一个对象的类型)。   (b)构造函数模式:ECMAScript中的构造函数可以用来创建特定类型的对象。可以创建自定义的构造函数,从而定义自定义对象类型的属性和方法。       function Person(name, age, job){         this.name = name;         this.age = age;         this.job = job;         this.sayName = function(){         alert(this.name);         };       }       var person1 = new Person(“Nicholas”, , “Software Engineer”);       var person2 = new Person(“Greg”, , “Doctor”);     缺点:使用构造函数的主要问题,就是每个方法都要在每个实例上重新创建一遍。不要忘了——ECMAScript中的函数是对象,因此每定义一个函数,     就是实例化一个对象。   (c)原型模式:我们创建的每个函数都有一个prototype(原型)属性,这个属性是一个指针,指向一个对象,而这个对象的用途是包含可以由特定类型     的所有实例共享的属性和方法。使用原型对象的好处是可以让所有对象共享它包含的属性和方法       function Person(){       }       Person.prototype.name = “Nicholas”;       Person.prototype.age = ;       Person.prototype.job = “Software Engineer”;       Person.prototype.sayName = function(){         alert(this.name);       };       var person1 = new Person();       person1.sayName(); //”Nicholas”       var person2 = new Person();       person2.sayName(); //”Nicholas”       alert(person1.sayName == person2.sayName); //true     缺点:原型中所有属性是被很多实例共享的,这种共享对于函数非常合适。但是对于引用类型值的属性来说,问题就比较突出了。     (d)组合使用构造函数模式和原型模式:创建自定义类型的最常见方式,就是使用组合使用构造函数模式和原型模式。构造函数模式用于定义实例属性,       而原型模式用于定义方法和共享的属性。       function Person(name, age, job){         this.name = name;         this.age = age;         this.job = job;         this.friends = [“Shelby”, “Court”];       }       Person.prototype = {         constructor: Person,         sayName : function () {         alert(this.name);         }       };       var person1 = new Person(“Nicholas”, , “Software Engineer”);       var person2 = new Person(“Greg”, , “Doctor”);       person1.friends.push(“Van”);       alert(person1.friends); //”Shelby,Court,Van”       alert(person2.friends); //”Shelby,Court”       alert(person1.friends === person2.friends); //false       alert(person1.sayName === person2.sayName); //true 答案:

推荐整理分享从面试题学习Javascript 面向对象(创建对象)(面试java基础知识),希望有所帮助,仅作参考,欢迎阅读内容。

从面试题学习Javascript 面向对象(创建对象)(面试java基础知识)

文章相关热门搜索词:面试java基础题,面试jvm,面试题java,面试java基础知识,面试题库java,java面试题视频讲解,面试java基础知识,面试题java,内容如对您有帮助,希望把文章链接给更多的朋友!

js面向对象 多种创建对象方法小结 开始创建对象:1.对象字面量。varclock={hour:,minute:,second:,showTime:function(){alert(this.hour+":"+this.minute+":"+this.second);}}clock.showTime();//调用2.创建Object实例varcl

Javascript 面向对象(一)(共有方法,私有方法,特权方法) 私有方法:私有方法本身是可以访问类内部的所有属性的,即私有属性和公有属性。但是私有方法是不可以在类的外部被调用。私有方法写法:functionmyC

Javascript 面向对象(二)封装代码 写个小例子:第一步:做一个手机的类"varMobilePhone=(function(){…………})()第二步:考虑这个类,里需要那些类的私有属性,这里我想定义的是实例出来手

本文链接地址:https://www.jiuchutong.com/biancheng/385677.html 转载请保留说明!

上一篇:Javascript面向对象扩展库代码分享(javascript面向对象吗)

下一篇:js面向对象 多种创建对象方法小结(js面向对象的三大特性)

免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

鄂ICP备2023003026号

网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

友情链接: 武汉网站建设 电脑维修 湖南楚通运网络