`

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

分享到:
评论

相关推荐

    Javascript面向对象编程.

    在提供的资源中,《代码之美》PDF文件可能包含了关于编程实践和代码风格的指导,而《Javascript面向对象编程》PPT可能更具体地阐述了JavaScript OOP的细节和示例。学习这些材料将有助于深入理解JavaScript的面向对象...

    面向对象JavaScript精要(英文原版pdf)

    ### 面向对象JavaScript精要 #### 一、书籍概览 本书《面向对象JavaScript精要》由Nicholas C. Zakas编写,是面向对象编程领域中的权威指南之一,尤其针对JavaScript这门语言。作者深入浅出地介绍了面向对象编程的...

    JavaScript面向对象编程指南(第2版).rar

    JavaScript是一种广泛...通过深入学习这本《JavaScript面向对象编程指南(第2版)》,开发者不仅能掌握JavaScript的面向对象编程基础,还能了解到实际项目中如何有效地运用这些知识,提升编程技巧和解决问题的能力。

    Javascript 面向对象的JavaScript进阶

    ### JavaScript面向对象进阶知识点详解 #### 8.1 面向对象编程的基本特性 在探讨面向对象的JavaScript之前,我们首先需要了解面向对象编程(Object-Oriented Programming, OOP)的基本特性:封装性、抽象性、继承...

    JAVASCRIPT 面向对象编程精要

    本文介绍了JavaScript面向对象编程的基本概念和技术细节,包括变量和对象的基础用法、函数的作用以及如何通过封装和继承来构建复杂的对象层次结构。JavaScript的独特之处在于它的灵活性和动态性,这使得它成为了一种...

    Javascript之面向对象--封装

    接下来,我们将结合给出的文件内容,详细解析JavaScript中面向对象封装的知识点。 首先,文件中提到了如何通过闭包来实现私有属性的概念。私有属性是指在对象内部定义的变量和方法,外部代码无法直接访问。在...

    JavaScript面向对象编程指南 pdf

    下面将详细探讨JavaScript面向对象编程的基本原理、特性以及实际应用。 1. **类与对象** - 在JavaScript中,对象是键值对的集合,可以通过字面量语法或构造函数创建。例如: ```javascript const person = { ...

    axios 面向对象封装

    标题“axios 面向对象封装”表明我们将创建一个自定义的 Axios 实例,它可以作为一个独立的对象在多个模块或组件之间复用。这种封装通常包括创建一个构造函数,用于初始化配置,以及定义一些方法,如发送GET、POST等...

    JavaScript面向对象编程指南.pdf

    JavaScript面向对象编程是指在JavaScript语言中使用面向对象的方法来编写程序。JavaScript是一种高级的、解释型的编程语言,它支持面向对象的编程范式,允许开发者创建对象、使用继承和多态等面向对象的特性。以下是...

    javascript面向对象编程(中文).pdf

    ### JavaScript面向对象编程知识点概述 #### 一、现代JavaScript编程概览 - **JavaScript的演进**:自诞生以来,JavaScript经历了从一个简单的脚本语言到现今被广泛应用于构建复杂应用的强大编程语言的过程。它的...

    javascript面向对象编程.pdf

    总而言之,学习现代JavaScript面向对象编程,有助于开发者在认识这门语言演化的基础上,运用面向对象的设计和编程模式来构建更加健壮和可维护的JavaScript应用程序。同时,测试和调试是保证代码质量不可或缺的环节,...

    JavaScript面向对象编程指南

    这些只是JavaScript面向对象编程的一些基本概念和技巧,实际应用中还有更深入的模式和策略,如模块化、设计模式等。理解并熟练运用这些概念,将有助于你编写出更加高效、可维护的JavaScript代码。

    JavaScript面向对象-动力节点共7页.pdf.z

    JavaScript面向对象是编程语言JavaScript中的核心概念之一,它在实际开发中扮演着至关重要的角色。JavaScript,虽然最初设计为一种轻量级的脚本语言,但随着其发展,逐渐引入了面向对象的特性,使得它能够支持更复杂...

    JavaScript面向对象精要(英文版)

    ### JavaScript面向对象精要 #### 一、概述 《JavaScript面向对象精要》是一本深入讲解JavaScript面向对象编程原理的专业书籍。本书由知名的前端开发者Nicholas C. Zakas撰写,全面介绍了JavaScript作为一种动态...

    02-js面向对象考核-tab栏案例.zip

    在这个"02-js面向对象考核-tab栏案例"中,我们可以深入探讨JavaScript面向对象编程在实际项目中的应用,尤其是如何使用它来实现tab栏切换功能。 首先,让我们理解面向对象的基本概念。在JavaScript中,对象是键值对...

    面向对象JavaScript开发

    JavaScript,作为一种广泛应用...JavaScript 面向对象程序设计——继承与多态.pdf 和 JavaScript 面向对象程序设计——封装.pdf 这两个文档可能深入探讨了这些主题,帮助读者深入理解并掌握JavaScript的面向对象开发。

    javascript面向对象框架

    "javascript面向对象框架"这一主题涵盖了JavaScript中实现面向对象编程的框架,特别是Prototype和MooTools这两个优秀的库。 Prototype是JavaScript的一个开源库,它扩展了JavaScript的基本对象和函数,提供了强大的...

    javascript面向对象

    本文旨在深入解析JavaScript面向对象编程的基础,包括对象的基本概念、类与对象的关系、对象的属性与方法、封装、继承与多态,以及JavaScript中对象的实现方式。 #### 对象的基本概念 面向对象编程的核心在于对...

Global site tag (gtag.js) - Google Analytics