zoukankan      html  css  js  c++  java
  • javascript创建对象的几种方式

    javascript创建对象简单的说,无非就是使用内置对象或各种自定义对象,当然还可以用JSON;但写法有很多种,也能混合使用。主要为下面几种:
    1、对象字面量的方式

    person={firstname:"Mark",lastname:"Yun",age:25,eyecolor:"black"};

    2、用function来模拟无参的构造函数

    function Person(){} 
    var person=new Person();//定义一个function,如果使用new"实例化",该function可以看作是一个Class 
    person.name="Mark"; 
    person.age="25"; 
    person.work=function(){ 
    alert(person.name+" hello..."); 
    } 
    person.work();

    3、用function来模拟参构造函数来实现(用this关键字定义构造的上下文属性)

    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("麦兜",25,"coding");//实例化、创建对象 
    maidou.eat();//调用eat方法

    4、用工厂方式来创建(内置对象)

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

    5、用原型方式来创建

    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();
  • 相关阅读:
    go学习笔记day01
    go学习笔记day02
    SQLSERVER SQL性能优化
    Javascript面向对象编程(二):构造函数的继承
    Net 下采用GET/POST/SOAP方式动态调用WebService
    Asp.Net下采用GET/POST/SOAP方式动态调用WebService
    crontab用法(例子)
    Javascript面向对象编程(三):非构造函数的继承
    学习Javascript闭包(Closure)
    js 模拟队列类
  • 原文地址:https://www.cnblogs.com/lqzweb/p/6215699.html
Copyright © 2011-2022 走看看