对象定义:无序属性的集合,属性包含基本值、对象、函数,相当于一组没有特定顺序的值。

   创建自定义对象最简单的方式就是:

 var movie=new Object();
movie.name="Interstellar";
movie.year=2014;
movie.country="American";
movie.playMovie=function(){
alert(this.name);
};

当然还可以写成对象自变量的方式:

var movie={
name:"Interstellar",
year:2014,
country:"American",
playMovie:function(){
alert(this.name);
}
};

上面两种都有明显的缺点:如果使用同一个接口创建很多对象,那么会产生大量的重复代码

 所以出现了工程模式,还是以前面的例子来修改:

function showMovie(name,year,country){
var p=new Object();
p.name=name;
p.year=year;
p.country=country;
p.playMovie=function(){
alert(this.name);
};
return p;
}

用的时候直接赋给一个变量:

var movie1=showMovie("Interstellar",2014,"American");

var movie2=showMovie("FleetofTime",2014,"China");

工厂模式虽然解决了创建多个相似对象的问题,但是没有解决对象识别的问题(怎样知道一个对象的类型),

于是构造函数出现,接着前面例子修改:

function Movie(name,year,country){
this.name=name;
this.year=year;
this.country=country; this.playMovie=function(){
alert(this.name);
};
}
//注意:
//这里没有return,没有显示的创建对象,把方法和属性都赋给了this对象;
//构造函数始终应该以一个大写字母开头,而非构造函数则以小写开头;

这里有几种调用构造函数的方式:

第一种通过new操作符:

var movie1=new Movie("Interstellar",2014,"American");

var movie2=new Movie("FleetofTime",2014,"China");

movie1、movie2都有一个constructor属性,指向Movie

alert(movie1.constructor==Movie);//true
alert(movie2.constructor==Movie);//true;

当然检测对象类型instanceof操作符要更可靠一些

alert(movie1 instanceof Movie);//true
alert(movie2 instanceof Movie);//true
alert(movie1 instanceof Object);//true
alert(movie2 instanceof Object);//true

注意的是所有对象都继承自Object;

第二种调用是把它作为普通的函数来调用,那么属性和方法都被添加到window对象了撒:

Movie("Interstellar",2014,"American");
window.playName();// "Interstellar"

第三种就是通过call()(apply())来到另一个对象的作用域中调用:

var p=new Object();
Movie.call(p,"FleetOfTime",2014,"China");
p.playMovie();//FleetOfTime

  以上就是调用构造函数的三种方式了,那么构造函数有什么问题呢,可以试着执行下面代码发现不同实例上的同名函数不相等

alert(movie1.playMovie==movie2.playMovie)//false

//构造函数主要的问题就是每个方法都要在每个实例上重新创建一遍

 我们可以通过把函数定义转移到构造函数外面来解决这个问题,如下:

function Movie(name,year,country){
this.name=name;
this.year=year;
this.country=country;
this.playMovie=playMovie;
}
funciton playMovie(){ alert(this.name);
}
//这里构造函数里面的playMovie包含一个指向函数的指针

  但是如果对象需要定义很多方法,那么就需要定义很多个全局函数了。所以出现了原型模式,当然原型模式也会存在问题,目前一般是运用构造函数+原型的组合方法来创建对象。见下节。。

最后:1937年12月13日,侵华日军野蛮侵入南京,制造了惨绝人寰的南京大屠杀惨案,30万同胞惨遭杀戮,无数妇女遭到蹂躏残害,无数儿童死于非命,三分之一建筑遭到毁坏,大量财物遭到掠夺。侵华日军一手制造的这一灭绝人性的大屠杀惨案,是第二次世界大战史上“三大惨案”之一,是骇人听闻的反人类罪行,是人类历史上十分黑暗的一页,勿忘国耻。

  

  

 

  

  

javascript创建对象(一)的更多相关文章

  1. Javascript 创建对象方法的总结

    最近看了一下<Javascript高级程序设计(第三版)>,这本书很多人都推荐,我也再次郑重推荐一下.看过之后总得总结一下吧,于是我选了这么一个主题分享给大家. 使用Javascript创 ...

  2. javascript创建对象的几种方式

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

  3. javascript创建对象的方法总结

    Javascript创建对象 最简单的方法:创建object实例. var person=new Object(); person.name="Joey";person.age=2 ...

  4. javascript创建对象的相关问题

    javascript创建对象的方法有很多种,一般来说,推荐使用对象字面量来创建对象. 对象构造函数捕捉 使用new Object来创建对象,可能会带来一些问题: var o = new Object( ...

  5. JavaScript创建对象(三)——原型模式

    在JavaScript创建对象(二)——构造函数模式中提到,构造函数模式存在相同功能的函数定义多次的问题.本篇文章就来讨论一下该问题的解决方案——原型模式. 首先我们来看下什么是原型.我们在创建一个函 ...

  6. Javascript 创建对象的三种方法及比较【转载+整理】

    https://developer.mozilla.org/zh-CN/docs/JavaScript/Guide/Inheritance_and_the_prototype_chain 本文内容 引 ...

  7. JavaScript创建对象的6种方式

    JavaScript创建对象简单的说,无非就是使用内置对象(Object)或各种自定义对象,当然还可以用JSON,但写法有很多种,也能混合使用. 1.对象字面量的方式 person = {name : ...

  8. JavaScript 创建对象的七种方式

    转自:xxxgitone.github.io/2017/06/10/JavaScript创建对象的七种方式/ JavaScript创建对象的方式有很多,通过Object构造函数或对象字面量的方式也可以 ...

  9. Javascript创建对象几种方法解析

    Javascript创建对象几种方法解析 Javascript面向对象编程一直是面试中的重点,将自己的理解整理如下,主要参考<Javascript高级程序设计 第三版>,欢迎批评指正. 通 ...

  10. JavaScript创建对象的几种 方式

    //JavaScript创建对象的七种方式 //https://xxxgitone.github.io/2017/06/10/JavaScript%E5%88%9B%E5%BB%BA%E5%AF%B9 ...

随机推荐

  1. 【Android 复习】:从Activity中返回数据

    在实际的应用中,我们不仅仅要向Activity传递数据,而且要从Activity中返回数据,虽然返回数据和传递类似,也可以采用上一讲中的四种方式来传递数据,但是一般建议采用Intent对象的方式的来返 ...

  2. 如何实现批处理文件传参数给SQLPLUS

    原文地址:http://www.cnblogs.com/HondaHsu/archive/2012/11/23/2784094.html 第一:批处理文件drop_table.bat 说明: 批处理中 ...

  3. js数组如何去掉逗号

    技术水平比较差,有错误的地方或者大神们有好的方法在介绍下,可以指点出来我加以改正! 1.join去掉逗号',' var a = ['1', '2', '3', '4', '5']; var c = a ...

  4. 搜狗一道java题目 关于对象 synchronized 关键字作用在 int, integer

      第一次见到这个题目,我觉得自己没学到java,太浅了,其实这个问题没有考synchronized关键字,只是考什么是对象? 1.在java编程思想的第二章有一句话; 一切都是对象,很可惜int,c ...

  5. (转载)VC/MFC 工具栏上动态添加组合框等控件的方法

    引言 工具条作为大多数标准的Windows应用程序的 一个重要组成部分,使其成为促进人机界面友好的一个重要工具.通过工具条极大方便了用户对程序的操作,但是在由Microsoft Visual C++开 ...

  6. JavaScript高级程序设计27.pdf

    第11章 DOM扩展 W3C将一些已经成为事实标准的专有扩展标准化并写入规范当中.对DOM的两个主要扩展是SelectorsAPI(选择符API)和HTML5 选择符API 就是根据CSS选择符选择与 ...

  7. Python默认编码错误SyntaxError: Non-ASCII character '\xe5'之解决方法

    在编写Python时,当使用中文输出或注释时运行脚本,会提示错误信息: SyntaxError: Non-ASCII character '\xe5' in file ******* 解决方法: py ...

  8. hdoj 2063 过山车【匈牙利算法+邻接矩阵or邻接表】

    过山车 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...

  9. 【bzoj3172】 [Tjoi2013]单词

    题目描述 某人读论文,一篇论文是由许多单词组成.但他发现一个单词会在论文中出现很多次,现在想知道每个单词分别在论文中出现多少次. 输入 第一个一个整数N,表示有多少个单词,接下来N行每行一个单词.每个 ...

  10. shell查找文件并删除

    -mtime 0 表示文件改动时间距离当前为0天的文件.即距离当前时间不到1天(24小时)以内的文件. -mtime 1 表示文件改动时间距离当前为1天的文件,即距离当前时间1天(24小时-48小时) ...