1. 使用Object构造函数来创建一个对象,下面代码创建了一个person对象,并用两种方式打印出了Name的值。

  var person = new Object();
  person.name="kevin";
  person.age=31;
  alert(person.name);
  alert(person["name"])

2. 使用对象字面量的方式{}   创建一个对象(最简单,好理解,推荐使用)

  var Cat = {};//JSON

  Cat.name="kity";//添加属性并赋值
  Cat.age=2;
  Cat.sayHello=function(){
    alert("hello "+Cat.name+",今年"+Cat["age"]+"岁了");//可以使用“.”的方式访问属性,也可以使用HashMap的方式访问
  }
  Cat.sayHello();//调用对象的(方法)函数

3. 用function(函数)来模拟class (无参构造函数)

3.1  创建一个对象,相当于new一个类的实例

    function Person(){

    }
    var personOne=new Person();//定义一个function,如果有new关键字去"实例化",那么该function可以看作是一个类
    personOne.name="dylan";
    personOne.hobby="coding";
    personOne.work=function(){
      alert(personOne.name+" is coding now...");
    }

    personOne.work();

3.2 可以使用有参构造函数来实现,这样定义更方便,扩展性更强(推荐使用)

    function Pet(name,age,hobby){
      this.name=name;//this作用域:当前对象
      this.age=age;
      this.hobby=hobby;
      this.eat=function(){
        alert("我叫"+this.name+",我喜欢"+this.hobby+",也是个吃货");
      }
    }
    var maidou =new Pet("麦兜",5,"睡觉");//实例化/创建对象
    maidou.eat();//调用eat方法(函数)

4. 使用工厂方式来创建(Object关键字)

  var wcDog =new Object(); 

  wcDog.name="旺财";
  wcDog.age=3;
  wcDog.work=function(){
    alert("我是"+wcDog.name+",汪汪汪......");
  }

  wcDog.work();

5. 使用原型对象的方式  prototype关键字

  function Dog(){

  }
  Dog.prototype.name="旺财";
  Dog.prototype.eat=function(){
    alert(this.name+"是个吃货");
  }
  var wangcai =new Dog();
  wangcai.eat();

6. 混合模式(原型和构造函数)

  function Car(name,price){
    this.name=name;
    this.price=price;
  }
  Car.prototype.sell=function(){
    alert("我是"+this.name+",我现在卖"+this.price+"万元");
  }

  var camry =new Car("凯美瑞",27);
  camry.sell();

7. 动态原型的方式(可以看作是混合模式的一种特例)

  function Car(name,price){
    this.name=name;
    this.price=price;
    if(typeof Car.sell=="undefined"){
      Car.prototype.sell=function(){
        alert("我是"+this.name+",我现在卖"+this.price+"万元");
      }
    Car.sell=true;

    }

  }

  var camry =new Car("凯美瑞",27);
  camry.sell();


javascript中创建对象的几种方式的更多相关文章

  1. JavaScript中创建对象的三种方式!

    JavaScript中创建对象的三种方式! 第一种 利用对象字面量! // 创建对象的三种方式! // 1 对象字面量. var obj = { // 对象的属性和方法! name: 'lvhang' ...

  2. javascript中创建对象的几种不同方法

    javascript中创建对象的几种不同方法 方法一:最直白的方式:字面量模式创建 <script> var person={ name:"小明", age:20, s ...

  3. Java中创建对象的几种方式

    Java中创建对象的五种方式: 作为java开发者,我们每天创建很多对象,但是我们通常使用依赖注入的方式管理系统,比如:Spring去创建对象,然而这里有很多创建对象的方法:使用New关键字.使用Cl ...

  4. Java中创建对象的五种方式

    我们总是讨论没有对象就去new一个对象,创建对象的方式在我这里变成了根深蒂固的new方式创建,但是其实创建对象的方式还是有很多种的,不单单有new方式创建对象,还有使用反射机制创建对象,使用clone ...

  5. 【转】Java中创建对象的5种方式

    Java中创建对象的5种方式   作为Java开发者,我们每天创建很多对象,但我们通常使用依赖管理系统,比如Spring去创建对象.然而这里有很多创建对象的方法,我们会在这篇文章中学到. Java中有 ...

  6. 实现JavaScript中继承的三种方式

    在JavaScript中,继承可以通过三种手法实现原型链继承 使用apply.call方法 对象实例间的继承.     一.原型链继承 在原型链继承方面,JavaScript与java.c#等语言类似 ...

  7. javascript中构造函数的三种方式

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  8. Java中创建对象的5种方式

    作为Java开发者,我们每天创建很多对象,但我们通常使用依赖管理系统,比如Spring去创建对象.然而这里有很多创建对象的方法,我们会在这篇文章中学到. Java中有5种创建对象的方式,下面给出它们的 ...

  9. js中创建对象的几种方式

    创建对象指创建一个object并给这个对象添加属性和方法,有以下几个方式: 最基本的: var Person={}; Person.name='tom'; Person.age='20'; Perso ...

随机推荐

  1. idea项目部署

    idea新建项目: http://blog.csdn.net/wo541075754/article/details/46348135  详细 http://www.cnblogs.com/wql02 ...

  2. 如何在腾讯云快速构建一个Wordpress个人站点

    版权声明:本文由贺嘉原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/175 来源:腾云阁 https://www.qclou ...

  3. 打通B/S与C/S !让HTML5 WebSocket与.NET Socket公用同一个服务端!

    随着HTML5 WebSocket技术的日益成熟与普及,我们可以借助WebSocket来更加方便地打通BS与CS -- 因为B/S中的WebSocket可以直接连接到C/S的服务端,并进行双向通信.如 ...

  4. IE7局部滚动区域下绝对定位或相对定位元素不随滚动条滚动的bug

    尽管在项目中测试人员已经慢慢淡化了IE6的测试,但是IE7依然还是要纳入测试范围. 最近碰到一个IE7的蛋疼bug,在页面上设置了一个局部的滚动区域,在拖动滚动条的时候,滚动区域内设置了相对定位或绝对 ...

  5. [Hadoop 周边] 浅谈大数据(hadoop)和移动开发(Android、IOS)开发前景【转】

    原文链接:http://www.d1net.com/bigdata/news/345893.html 先简单的做个自我介绍,我是云6期的,黑马相比其它培训机构的好偶就不在这里说,想比大家都比我清楚: ...

  6. sqlserver 导出数据库表结构和数据生成脚本

  7. Pictures of Ascii Art

    简述 指尖上的艺术 - 通过键盘上韵律般的敲敲打打,一幅幅美轮美奂的艺术作品便跃然于屏. 这样的画作,包含了无穷的创意,糅合了现代计算机科技与传统绘画艺术,难道还有比这更令人陶醉的美妙事物吗? 简述 ...

  8. iOS开发 iOS10推送必看

    iOS10更新之后,推送也是做了一些小小的修改,下面我就给大家仔细说说.希望看完我的这篇文章,对大家有所帮助. 一.简单入门篇---看完就可以简单适配完了 相对简单的推送证书以及环境的问题,我就不在这 ...

  9. uva 11624(bfs)

    11624 - Fire! Time limit: 1.000 seconds Joe works in a maze. Unfortunately, portions of the maze hav ...

  10. 241. Different Ways to Add Parentheses——本质:DFS

    Given a string of numbers and operators, return all possible results from computing all the differen ...