面向对象——创建对象的方式
来源:互联网 发布:协同过滤推荐算法原理 编辑:程序博客网 时间:2024/06/15 17:13
创建对象的方式
2016/10/21 笔记
第一种创建对象的方式:
创建JSON对象
推荐使用的场合: 作为函数的参数,临时只用一次的场景。比如设置函数原型对象。
var object = { name: "Eric", age: 24, sayHi: function(){ console.log("My name is "+ this.name + " this year is " + this.age + "years old.") } };
第二种创建对象的方式:
创建一个Object对象
var object = new Object(); object.name = "Eric"; object.age = 24; object.sayHi = function(){....};
以上两种创建对象方式的缺点:不能作为对象创建的模板,也就是不能用new进行构造新对象。
=================================================================
第三种创建对象的方式:
function Person() { this.name = "Eric"; this.age = 24; this.sayHi = function(){ console.log(this.name); } } var object1 = new Person(); var object2 = new Person();
这种创建对象方式解决了前两种方式的缺点,可以作为对象创建的模板,可以一直复用创建出多个对象。
new运算符的作用:
- 执行构造函数(new后面的那个函数),在构造函数内部创建一个空对象
- 把上一部创建的空对象跟构造函数的原型对象进行关联
- 然后把this指向当前空对象
- 在构造函数执行结束后,如果没有return,把空对象返回给object
第三种方式有个缺点: 对象的内部的函数会在每个对象中都存一份如果创建的对象非常多的话,那么非常浪费内存。函数的行为是所有对象可以共有,不需要每个对象都保存一份。所以,可以把函数放到原型中进行声明,那么所有对象都有了公共的函数,而且内存中只保留一份。所有的属性写到对象的内部
第三种方式beta1:
function Person() { this.name = 'Eric'; this.age = 24; } Person.prototype = { sayHi: function() { }, }; var object1 = new Person(); var object2 = new Person();
继续升级 beta2 :
function Person(name,age) { this.name = name || ""; this.age = age || ""; } Person.prototype = { sayHi: function() { }, }; var object1 = new Person(name1,age1); var object2 = new Person(name2,age2);
问题:1、调用者如果传递参数的顺序发生变化,那么废了
问题:2、参数增减都会导致函数声明变化,调用的地方也可能发生变化。
如何解决:继续升级 beta3 :
function Person(option) { //用一个对象把所有参数覆盖 this.name = option.name || ""; this.age = option.age || ""; } Person.prototype = { sayHi: function() { }, }; var object1 = new Person({ name: "Eric", age: 24 }); var object2 = new Person({ name: "XXX", age: xx });
继续优化,把初始化的代码 放到init函数中
继续升级 beta4 :
function Person(option) { this._init(option); } Person.prototype = { _init: function (option){ this.name = option.name; this.age = option.age; }, sayHi: function(){ console.log("HI"); } }; var object1 = new Person({ name: "Eric"; age: 24 }); object1.sayHi();
0 0
- 面向对象——创建对象的方式
- 面向对象 创建对象的两种方式
- js中面向对象(创建对象的几种方式)
- 《JavaScript》——面向对象之对象的创建
- 《JavaScript》——面向对象之对象的创建
- 面向对象的程序设计——创建对象
- JavaScript面向对象程序设计—创建对象的模式
- JavaScript基础——面向对象的程序设计(一)创建对象的几种方式总结
- 面向对象的创建
- javascript——创建对象的方式
- javascript中面向对象特性、对象的创建方式及对象属性的特性
- 采用面向对象的方式创建window原生程序
- 创建对象的方式
- 创建对象的方式
- 面向对象的思维方式
- 面向对象的思维方式
- 面向对象的思维方式
- 面向对象的思维方式
- 插入排序伪代码与编程实现
- shiro ehcache
- 操作系统简介
- SDRAM理论篇之基础知识及操作时序讲解
- 盒子模型
- 面向对象——创建对象的方式
- 机器学习---kNN算法
- SQL表连接查询(inner join、full join、left join、right join)
- stock存储模板类指针
- Java难点解析(八)-接口
- MySQL数据库
- SDRAM驱动篇之简易SDRAM控制器的verilog代码实现
- DeepLearning tutorial(1)Softmax回归原理简介+代码详解
- Android Volley完全解析(一),初识Volley的基本用法