本人常用的创建对象的方式,仅供参考,欢迎吐槽,谢谢!

创建对象
1、对象字面量,即使用大括号,如下:

  1. (function(){
  2.  
  3. var obj = {
  4. id: 1,
  5. desc: '创建对象测试开始啦!',
  6. show: function(){
  7. console.log("id=%d, desc=%s", this.id, this.desc);
  8. }
  9. };
  10.  
  11. obj.show();
  12. })();

2、构造函数

  1. (function(){
  2.  
  3. function Animal(name, age){
  4. this.name = name;
  5. this.age = age;
  6. this.show = function(){
  7. console.log("该动物是%s,今年%d岁", this.name, this.age);
  8. }
  9. }
  10.  
  11. var cat = new Animal('猫咪', 3);
  12. cat.show();
  13.  
  14. })();

一种错误:

  1. (function(){
  2.  
  3. function Animal(){
  4. }
  5.  
  6. Animal.prototype.name = '猫咪';
  7. Animal.prototype.age = 3;
  8. Animal.prototype.show = function(){
  9. console.log("该动物是%s,今年%d岁", this.name, this.age);
  10. };
  11.  
  12. animal = Animal();
  13. animal.show();//TypeError: animal is undefined
  14.  
  15. })();

解决方案

  1. (function(){
  2.  
  3. function Animal(){
  4. if( !(this instanceof Animal) ){
  5. return new Animal();
  6. }
  7. }
  8.  
  9. Animal.prototype.name = '猫咪';
  10. Animal.prototype.age = 3;
  11. Animal.prototype.show = function(){
  12. console.log("该动物是%s,今年%d岁", this.name, this.age);
  13. };
  14.  
  15. animal = Animal();
  16. animal.show();//该动物是猫咪,今年3岁
  17.  
  18. })();

3、原型模式

  1. (function(){
  2.  
  3. function Animal(){
  4.  
  5. }
  6.  
  7. Animal.prototype.name = '猫咪';
  8. Animal.prototype.age = 3;
  9. Animal.prototype.show = function(){
  10. console.log("该动物是%s,今年%d岁", this.name, this.age);
  11. };
  12.  
  13. var animal = new Animal();
  14. animal.show();//该动物是猫咪,今年3岁
  15.  
  16. animal.name = "狗熊";
  17. animal.age = 14;
  18. animal.show();//该动物是狗熊,今年14岁
  19.  
  20. delete animal.name;
  21. animal.show();//该动物是猫咪,今年14岁
  22.  
  23. })();

备注:当删除对象的属性时,为啥从该对象的name,从狗熊变成了猫咪了呢?这是跟JS中属性的查找有关!首先其先从该对象的属性中查找若有,则立即返回,当没有,再到其原型中查找,若有则立即返回,最后当找不到时,则返回undefined

什么是原型?

1、我们创建的每一个函数都有一个prototype属性,这个属性是一个对象,它的用途是包含有特定类型的所有实例共享的属性和方法。
2、只要创建了一个新函数,就会为该函数创建一个prototype属性。默认情况下,所有prototype属性都会自动获得一个constructor属性,这个属性包含一个指向prototype属性所在函数的指针。这样,函数以及函数原型之间就形成了循环指向了。
3、每当调用构造函数创建一个新实例后,该实例的内部将包含一个指针(一般指__proto__),指向构造函数的原型属性。

参考资料:

有图的,很有意思:http://www.cnblogs.com/maxupeng/archive/2010/12/28/1918480.html

JS创建对象的更多相关文章

  1. JS创建对象篇

    JS创建对象篇 Object构造函数创建 var person = new Object(); person.name = "Tom"; person.age = 10; pers ...

  2. 使用js创建对象

    1.js创建关键字 //使用 New 关键字 function person(name,age){ this.name=name; this.age=age; } $(function(){ var ...

  3. javascript(js)创建对象的模式与继承的几种方式

    1.js创建对象的几种方式 工厂模式 为什么会产生工厂模式,原因是使用同一个接口创建很多对象,会产生大量的重复代码,为了解决这个问题,产生了工厂模式. function createPerson(na ...

  4. JS 创建对象总结

    狭义:new 构造函数. (注:在JS中创建对象只有一种方式,就是new 构造函数.其中字面量的方式是一种语法糖,本质仍然是new 构造函数) 广义:工厂模式(解决复杂度) 构造函数模式(解决复杂度, ...

  5. JS创建对象的方式有几种

    相信但凡作为一个前端工程师,都被面试到过这个面试题目,HR考察的就是对oop思想的理解. 作为一个从后端转过来的怂逼,oop一直是心中的永远的痛啊. 这几天一直在通读js高级程序设计,重复理解js创建 ...

  6. JS 创建对象(常见的几种方法)

    贴个代码先: function O(user,pwd){ //use constructor this.user=user; this.pwd=pwd; this.get=get; return th ...

  7. js 创建对象的多种方式

    参考: javascript 高级程序设计第三版 工厂模式 12345678910 function (name) { var obj = new Object() obj.name = name o ...

  8. 基础2:js创建对象的多种方式

    js创建对象的多种方式 1. 工厂模式 function createPerson(name) { var o = new Object() 0.name = name return o } var ...

  9. 浅谈 JS 创建对象的 8 种模式

    1.Object 模式 var o1 = {};//字面量的表现形式 var o2 = new Object; var o3 = new Object(); var o4 = new Object(n ...

  10. JS创建对象、继承原型、ES6中class继承

    面向对象编程:java中对象的两个基本概念:1.类:类是对象的模板,比如说Leader 这个是泛称领导,并不特指谁.2:实例:实例是根据类创建的对象,根据类Leader可以创建出很多实例:liyi,y ...

随机推荐

  1. Ubuntu 14.04下java开发环境的搭建--3--Tomcat及MySQL的安装

    前面两篇文章,已经说明了JDK和Eclipse 的安装方法,下面简单说一下,Tomcat及MySQL的安装方法. Tomcat的安装. 在合适的地方解压apache-tomcat-6.0.39.tar ...

  2. VMware Workstation中linux(centos)与windows7共享文件夹

    引用网站有: http://www.jb51.net/LINUXjishu/161994.html http://www.cnblogs.com/xiehy/archive/2011/12/19/22 ...

  3. 【Qt】Qt Assistant介绍【转】

    简介 Qt Assistant也就是我们常说的Qt助手,是一款用于呈现在线文档的工具. 简介 一分钟学会使用 Qt参考文档 Qt Assistant详解 命令行选项 工具窗口 文档窗口 工具栏 菜单 ...

  4. VirtrualBox 搭建本地lamp环境

    1.VirtrualBox安装Centos6.8 minimal VirtrualBox新建个虚拟机配置好内存以及硬盘大小,安装即可: 网络方式是 NAT(默认)和桥接方式来实现,最好在安装前设置好, ...

  5. 关于SQLite的创建以及使用相关说明

    关于SQLite的创建以及使用相关说明 没有给出具体的程序,但看完这后可能对你有所帮助. 数据库操作基本知识: execSQL(String sql): 执行一个数据库语句 insert(table, ...

  6. COUNT(*),count(1),COUNT(ALL expression),COUNT(DISTINCT expression)

    创建一个测试表 IF OBJECT_ID( 'dbo.T1' , 'U' )IS NOT NULL BEGIN DROP TABLE dbo.T1; END; GO )); GO INSERT INT ...

  7. hdu 2837 Calculation 指数循环节套路题

    Calculation Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  8. oracle11g关于表空间的问题

    1.oracle11g默认的块大小为8K  每个表空间里面的单个数据文件最大为32G   (2^22-1) *4k   最多可以放1024个单个文件    SQL> show parameter ...

  9. Python标准库 urllib2 的使用

    1.Proxy 的设置 urllib2 默认会使用环境变量 http_proxy 来设置 HTTP Proxy. 如果想在程序中明确控制 Proxy,而不受环境变量的影响,可以使用下面的方式 impo ...

  10. Mysql数据库中的计数器表实时更新

    如果某个应用中存在计数器,例如网站的总访问量.用户的粉丝数.文件下载数等等.如果相关应用在Mysql数据库的表中保存计数器,在更新计数器的时候可能会碰到并发问题.例如在web应用中,记录网站的点击次数 ...