当前位置: 代码迷 >> JavaScript >> [基础]JavaScript中的面向对象(个人学习札记) 一
  详细解决方案

[基础]JavaScript中的面向对象(个人学习札记) 一

热度:358   发布时间:2012-11-08 08:48:11.0
[基础]JavaScript中的面向对象(个人学习笔记) 一
   最近总是遇见JavaScript中对象和类的问题,于是重新学习JavaScript,也把它当作自己的第一篇学习笔记,如果有理解错误的地方,请大家指出,谢谢。
    首先说明一下ECMAScript,它是在一个叫做ECMA-262的标准中定义的,ECMAScript
一个重要的标准,它可以为不同的宿主环境提供核心的脚本编程能力,是一个JavaScript的核心。通常一个完整的JavaScript实现是由以下三个不同部分组成:
?  核心(ECMAScript)
?  文档对象模型(DOM)
?  浏览器对象模型(BOM)
*以下内容正式开始,一切还是从对象入手

1、面向对象术语
对象(Object)
    ECMA-262把‘对象’定义为“属性的无序组合,每个属性存放一个原始值、对象或函数”。‘对象’由特性(attribute)构成,特性可以使原始值,也可以是引用值。如果特性存放的是函数,它被看作对象的方法(method),否则该特性被看作属性(property)。

类(Class)
   ECMAScript并没有正式的类。其实对象的定义就是类的定义。类定义了一个对象的属性和方法,还有一些相关业务的代码。对象的定义放在类的构造函数中。

2、对象的声明和实例化
对象是用关键字new后跟要实例化的类名创建:
    var oObject = new Object();
    var sString = new String();

   上面的代码就分别创建了一个Object对象和一个String对象。如果类的构造函数没有参数,括号是不必需的。所以上面的代码可以改写成:
    var oObject = new Object;
    var sString = new String;

3、对象的废除
    先说概念,当再没有对对象的引用时,就称该对象被废除(dereference)了。说到对象的废除,就不得不说无用储存单元收集程序,每当程序执行完它的代码,无用储存单元收集程序都会运行,释放所有局部变量,还有一些不可知的情况它也会运行。
把对象的所有引用都设置成null,可以强制性的废除对象。比如:
    var oObject = new Objcet;
    //do something here
    oObject = null;


   当变量oObject设置成null后,就没有任何对对象的引用了。这意味着下次运行无用储存单元收集程序时,该对象将被销毁。
*每用完一个对象后,就将其废除,来释放内存,这是一个好习惯。
*废除对象的引用时要当心。如果一个对象有两个或多个引用,要废除该对象,则需要将对象的所有引用都设置成null!

   最后还要补充一个问题,说一下为什么javascript中没有重载。在ECMAScript中函数实际上是功能完整的对象,实际上是创建了一个Function类的实例对象。用Function类直接创建函数的语法如下:
    var function_name = new Function(argument1,argument2, …,argument,function_body);

先来看一段简单的代码:
  function sayHello(name,msg){
	alert("Hello" + name + "you are very " + msg);
  }

通过Function类可以将原代码改写成:
  var sayHello = new Function("name","msg","alert(\"Hello  \" + name + \", you are very\" + msg );");
  sayHello("yzl","handsome"); 

以上的两段代码都实现的相同的功能,实际上更应该说成是第一段代码最后都会被计算机理解为第二段,个人感觉跟高级语言被转换为机器语言一样,所以很容易可以看出在定义函数时无法实现重载,因为在第二次定义函数的时候已经把函数的引用指向了新的引用,就好像你对同一个变量new了两次一个道理,第一个函数已经“不在”了。
*Function中有个很重要的东西arguments放到了类的初始化那里说明


  相关解决方案