`

Javascript面向对象 2 -- 【封装】

 
阅读更多

 1. javascript类的静态属性和方法

静态方法是可以使用类名称直接调用的方法(无需创造类的实例).

静态属性是可以使用类名称直接引用的属性(无需创造类的实例).

在javascript中,类使用function定义.所以类名称就是定义的function名称.

其实,在定义function的时候,也是在创建一个对象,这样,下面代码中

 

Person.cry = function() {
    alert(‘Wa wa wa …’);
};
 这种方式,为Person添加一个静态方法,就是为Person这个function对象添加一个属性而已.

 

这样可调用Person.cry().看起来就相当于调用静态方法了.

 

注1: 

类似于me.teeth这样的访问非静态属性(对象实例.属性方式访问的),这里的teeth可以是prototype对象中的属性.当调用me.teeth时,javascript先搜索me对象是否包含teeth这个属性,如果不包含,则搜索me.prototype这个对象是否包含teeth,如果还不包含,则搜索me.prototype.prototype,这样沿着原型链一直搜索.

 

注2:

Person.prototype.teeth = 32;

 

这种方式设置属性值后,

加入再次new一个Person对象 you = new Person('Lisi');

则you.teeth也被设置为32了.

但是也可以在定义Person这个function的时候,设置this.teeth=30,这样就覆盖了Person.prototype.teeth.

当然,如果不在Person定义的function覆盖teeth属性,则所有Person对象实例都共享一份Person.prototype.teeth属性值.

 

参考下面代码:

 

/****************************************
* 方法一
* 类、方法、属性都为静态类型
* 不能创建实例
*****************************************/
var Time = {
    today: ‘2009-3-8′,
    weather: ‘rain’,
    show: function() {
        alert(‘Today is ‘ + this.today);
    }
};
 
//静态对象可直接使用,无需创建实例
alert(‘It is ‘ + Time.weather + ‘ today.’);
Time.show();
 
//下面的代码会出错,因为静态类不能创建实例
//var t = new Time();
//t.show();
 
/****************************************
* 方法二
* 普通对象,同时拥有静态和非静态属性、方法
* 可以用实例化
* 注意:
*   1.静态方法/属性使用类名访问
*   2.非静态方法/属性使用实例名访问
*****************************************/
function Person(name) {
    //非静态属性
    this.name = name;
    //非静态方法
    this.show = function() {
        alert(‘My name is ‘ + this.name + ‘.’);
    }
}
//添加静态属性,人都是一张嘴
Person.mouth = 1;
//添加静态方法,哇哇大哭
Person.cry = function() {
    alert(‘Wa wa wa …’);
};
//使用prototype关键字添加非静态属性,每个人的牙可能不一样多
Person.prototype.teeth = 32;
 
//非静态方法必须通过类的实例来访问
var me = new Person(‘Zhangsan’);
//使用非静态方法、属性
me.show();
alert(‘I have ‘ + me.teeth + ‘ teeth.’);
//使用静态方法、属性
Person.cry();
alert(‘I have ‘ + Person.mouth + ‘ mouth.’);
 参考:http://blog.tugai.net/2009/03/07/javascript-static-class-mothed-property/

 

2. 私有属性

    实现私有属性之前,需要先理解闭包.

    闭包涉及到javascript的变量的作用域,下面这篇文章讲的特别好.

    参考 http://www.ruanyifeng.com/blog/2009/08/learning_javascript_closures.html

    ,里面总结的闭包用途:

    一个是前面提到的可以读取函数内部的变量,另一个就是让这些变量的值始终保持在内存中。

    下面是一个例子,想象一个场景:

     在一个页面中,我们需要一个函数,返回一个index值,每次调用都返回一个整数,第一次返回0,第二次返回1,以此类推.

     可以用下面代码实现:

     

var myGetIndex = function()
{
  var temp = 0; //局部变量
  
  var tempGetIndex = function() //内部函数,一个闭包,每次调用,temp值保留在   //内存中
  {
    return temp++; 
  }
  return tempGetIndex; //返回内部函数对象
}

var getIndex = myGetIndex();//getIndex 实际上是一个function

alert(getIndex());//返回0
alert(getIndex());//返回1
alert(getIndex());//返回2

 

     这样,可以用下面的代码说明javascript类的私有变量

    

function Person(name,age)
{
  this.name=name; //公有变量
  this.age=age;   //公有变量
  
  var salary = 0; //私有变量,因为这个是Person这个function的内部(局部)变量,外部无法访问
  
  this.setSalary =  function(newSalary){salary=newSalary};//setSalary是公有属性,外部可调用//,但是这个setSalary是一个函数,外部需要用setSalary(100)这个方式调用
  this.getSalary = function(){return salary};
}

var jack = new Person('jack',29);
jack.setSalary(1000);
alert(jack.getSalary()); //返回1000

 

 

参考: http://www.ruanyifeng.com/blog/2010/05/object-oriented_javascript_encapsulation.html

分享到:
评论

相关推荐

    JAVA面向对象基础测试题-继承-封装-多态等测试题.docx

    JAVA面向对象基础测试题-继承-封装-多态等测试题.docx

    Javascript之面向对象--封装

    本篇文章通过具体实例,对Javascript的封装过程进行案例分析,有助于对其代码实现的理解与学习。下面就随小编一起来看看吧

    JavaScript面向对象程序设计

    JavaScript面向对象程序设计(2): 数组 JavaScript面向对象程序设计(3): 对象 JavaScript面向对象程序设计(4): 函数 JavaScript面向对象程序设计(5): 类 JavaScript面向对象程序设计(6): 封装 JavaScript面向对象程序...

    JavaScript程序设计课件:面向对象概述.pptx

    2、面向过程与面向对象的优缺点 优点 缺点 面向过程 性能比面向对象高。 代码结构混乱,不易维护,不易复用,不易扩展。 面向对象 面向对象有封装、继承、多态性的特性,所以具有易维护、易复用、易扩展的特点。 类...

    Javascript面向对象特性实现(封装、继承、接口).doc

    Javascript面向对象特性实现(封装、继承、接口 Javascript面向对象特性实现(封装、继承、接口

    Javascript 面向对象编程

    但是,它又不是一种真正的面向对象编程(OOP)语言,因为它的语法中没有class(类)。 那么,如果我们要把"属性"(property)和"方法"(method),封装成一个对象,甚至要从原型对象生成一个实例对象,我们应该怎么...

    javascript面向对象包装类Class封装类库剖析.docx

    javascript面向对象包装类Class封装类库剖析.docx

    JavaScript面向对象实现简单工厂模式

    本文件使用JavaScript已面向对象方式封装类来演示简单工厂模式的实现代码。以实例介绍了简单功能模式的用途,简单分析了实现的要件。mhtl文件里有实例代码的全部内容和分析简述。

    JavaScript面向对象编程指南

    JavaScript面向对象编程指南,关于对象,属性,方法,类,封装,继承,多态的详细讲解和介绍

    Javascript面向对象编程

    javascript的特点 简单 动态 基于对象(面向对象) Javascript面向对象概述 Javascript是一种面向(基于)对象的动态脚本语言,是一种基于对象(Object)和事件驱动(EventDriven)并具有安全性能的脚本语言。他具有面向...

    .net_面试题_javascript面向对象编程

    要求: 用javascript封装一个类,实现动态构造导航菜单功能,数据格式为data.xml 要求: 1.运用面向对象的思想设计该类(如继承)。 2.实现效果参考 "示例.bmp",菜单样式整洁即可。 3.两天内完成。

    JavaScript面向对象编程

    本电子书包括专业JavaScript 编程的基础:编写面向对象代码,测试代码,为分发而进行封装。随后你看到了 Unobtrusive DOM 脚本编程的主要方面,包括一个关于文档对象模型,事件,JavaScript 与CSS 交互的简短的总览...

    js面向对象封装拖拽移动功能,兼容pc和移动端

    采用JavaScript面向对象思想封装拖拽移动功能,兼容pc端和移动端,适合JavaScript初学者进阶学习。

    面向对象的JavaScript包装类

    自己封装的一个面向对象的JavaScript类。

    JavaScript面向对象技术实现树形控件

    树形控件具有独特的扩展和折叠分支的能力,能够以较小的空间显示出大量的信息,一目了然地传达出数据之间的层次关系。凡是熟悉图形用户界面的用户,都能够自如地运用树形控件。

    javascript面向对象三大特征之封装实例详解

    本文实例讲述了javascript面向对象三大特征之封装。分享给大家供大家参考,具体如下:封装封装(Encapsulation):就是把对象内部数据和操作细节进行隐藏。很多面向对象语言都支持封装特性,提供关键字如private来隐藏...

    纯javascript日历,农历,根据网上流传的日历面向对象封装

    纯javascript,面向对象,可多次调用。由于时间仓促,没有过多的修改。支持农历,节气,节假日,班假图标。

    Javascript 面向对象编程(一) 封装

    《面向对象的Javascript》(Object-Oriented JavaScript) 《Javascript高级程序设计(第二版)》(Professional JavaScript for Web Developers, 2nd Edition) 它们都是非常优秀的Javascript读物,推荐阅读。 笔记...

    javascript 面向对象编程基础:封装

    “在面向对象的思想中,最核心的概念之一就是类。一个类表示了具有相似性质的一类事物的抽象,通过实例化一个类,可以获得属于该类的一个实例(即对象)”。

    JavaScript面向对象三个基本特征实例详解【封装、继承与多态】

    本文实例讲述了JavaScript面向对象三个基本特征。分享给大家供大家参考,具体如下: 了解过面向对象的同学应该都知道,面向对象三个基本特征是:封装、继承、多态,但是对于这三个词具体可能不太了解。对于前端来讲...

Global site tag (gtag.js) - Google Analytics