Private Members in JavaScript

Private Members in JavaScript

Douglas Crockford

www.crockford.com

JavaScript is the
world‘s most misunderstood programming language
. Some believe
that it lacks the property of information hiding because
objects cannot have private instance variables and methods. But this
is a misunderstanding. JavaScript objects can have private members.
Here‘s how.

Objects

JavaScript is fundamentally about objects. Arrays are
objects. Functions are objects. Objects are objects. So what are
objects? Objects are collections of name-value pairs. The names are
strings, and the values are strings, numbers, booleans, and objects
(including arrays and functions). Objects are usually implemented as
hashtables so values can be retrieved quickly.

If a value is a function, we can consider it a method. When
a method of an object is invoked, the this variable is set
to the object. The method can then access the instance variables
through the this variable.

Objects can be produced by constructors, which are
functions which initialize objects. Constructors provide the features
that classes provide in other languages, including static variables
and methods.

Public

The members of an object are all public members. Any
function can access, modify, or delete those members, or add new
members. There are two main ways of putting members in a new
object:

In the constructor

This technique is usually used to initialize public instance
variables. The constructor‘s this variable is used to add
members to the object.

function Container(param) {
    this.member = param;
}

So, if we construct a new object

var myContainer = new Container(‘abc‘);

then myContainer.member contains ‘abc‘.

In the prototype

This technique is usually used to add public methods. When a member is sought and it isn‘t found in the object itself, then it is taken from the object‘s constructor‘s prototype member. The prototype mechanism is used for inheritance. It also conserves memory. To add a method to all objects made by a constructor, add a function to the constructor‘s prototype:

Container.prototype.stamp = function (string) {
    return this.member + string;
}

So, we can invoke the method

myContainer.stamp(‘def‘)

which produces ‘abcdef‘.

Private

Private members are made by the constructor. Ordinary vars and parameters of the constructor becomes the private members.

function Container(param) {
    this.member = param;
    var secret = 3;
    var that = this;
}

This constructor makes three private instance variables: param, secret, and that. They are attached to the object, but they are not accessible to the outside, nor are they accessible to the object‘s own public methods. They are accessible to private methods. Private methods are inner functions of the constructor.

function Container(param) {

    function dec() {
        if (secret > 0) {
            secret -= 1;
            return true;
        } else {
            return false;
        }
    }

    this.member = param;
    var secret = 3;
    var that = this;
}

The private method dec examines the secret instance variable. If it is greater than zero, it decrements secret and returns true. Otherwise it returns false. It can be used to make this object limited to three uses.

By convention, we make a private that variable. This is used to make the object available to the private methods. This is a workaround for an error in the ECMAScript Language Specification which causes this to be set incorrectly for inner functions.

Private methods cannot be called by public methods. To make private methods useful, we need to introduce a privileged method.

Privileged

A privileged method is able to access the private variables and methods, and is itself accessible to the public methods and the outside. It is possible to delete or replace a privileged method, but it is not possible to alter it, or to force it to give up its secrets.

Privileged methods are assigned with this within the constructor.

function Container(param) {

    function dec() {
        if (secret > 0) {
            secret -= 1;
            return true;
        } else {
            return false;
        }
    }

    this.member = param;
    var secret = 3;
    var that = this;

    this.service = function () {
        return dec() ? that.member : null;
    };
}

service is a privileged method. Calling myContainer.service() will return ‘abc‘ the first three times it is called. After that, it will return null. service calls the private dec method which accesses the private secret variable. service is available to other objects and methods, but it does not allow direct access to the private members.

Closures

This pattern of public, private, and privileged members is possible because JavaScript has closures. What this means is that an inner function always has access to the vars and parameters of its outer function, even after the outer function has returned. This is an extremely powerful property of the language. There is no book currently available on JavaScript programming that shows how to exploit it. Most don‘t even mention it.

Private and privileged members can only be made when an object is constructed. Public members can be added at any time.

Patterns

Public

function Constructor(...) {

this.membername = value;

}

Constructor.prototype.membername =
value;

Private

function Constructor(...)
{

var that = this;

var membername = value;

function membername(...) {...}

}

Note: The function statement

function
membername(...) {...}

is shorthand for

var membername = function membername(...)
{
...};

Privileged

function Constructor(...)
{

this.membername = function (...) {...};

}

Copyright 2001 Douglas
Crockford. All
Rights Reserved Wrrrldwide.

时间: 2024-12-08 02:34:11

Private Members in JavaScript的相关文章

Use Private Members from Base Class

最近看了一段代码:在导出类中调用继承自基类的某个public函数,该函数中对基类中的private数据成员 进行了赋值并将结果打印.看到程序的运行结果后,顿时感觉自己之前(我之前的理解这里就不说明了)对于 基类/导出类中私有数据成员的理解并不是很准确.所以写了下面的这个程序,进行简单的验证并加深理解: class Insect { private int i = 9; Insect() { System.out.println("Insect."); } private int x1

全面理解面向对象的JavaScript

转载:http://justcoding.iteye.com/blog/2019293 原文:http://www.ibm.com/developerworks/cn/web/1304_zengyz_jsoo/index.html?ca=drs-#major6 前言 当今 JavaScript 大行其道,各种应用对其依赖日深.web 程序员已逐渐习惯使用各种优秀的 JavaScript 框架快速开发 Web 应用,从而忽略了对原生 JavaScript 的学习和深入理解.所以,经常出现的情况是,

深入全面理解面向对象的 JavaScript

深入全面理解面向对象的 JavaScript (原著: 曾 滢, 软件工程师, IBM,2013 年 4 月 17 日) JavaScript 函数式脚本语言特性以及其看似随意的编写风格,导致长期以来人们对这一门语言的误解,即认为 JavaScript 不是一门面向对象的语言,或者只是部分具备一些面向对象的特征.本文将回归面向对象本意,从对语言感悟的角度阐述为什么 JavaScript 是一门彻底的面向对象的语言,以及如何正确地使用这一特性. 前言 当今 JavaScript 大行其道,各种应用

【JavaScript】Registering JavaScript object methods as callbacks

The registration of callback functions is very common in JavaScript web programming, for example to attach user interface event handlers (such as onclick), or to provide a function to handle an XHR response. Registering an object method as a callback

转载:全面理解面向对象的 JavaScript

来源:DeveloperWorks – 曾滢著 简介: JavaScript 函数式脚本语言特性以及其看似随意的编写风格,导致长期以来人们对这一门语言的误解,即认为 JavaScript 不是一门面向对象的语言,或者只是部分具备一些面向对象的特征.本文将回归面向对象本意,从对语言感悟的角度阐述为什么 JavaScript 是一门彻底的面向对象的语言,以及如何正确地使用这一特性. 前言 当今 JavaScript 大行其道,各种应用对其依赖日深.web 程序员已逐渐习惯使用各种优秀的 JavaSc

A Simple Example About Privileged Methods in JavaScript

Douglas Crockford classified the "class methods" in JavaScript into three types: private, privileged and public. Public methods have an obvious meaning: they can be accessed by the public. Private methods' meaning are also clear: they cannot be

IT忍者神龟之理解回顾面向对象的 JavaScript

JavaScript 函数式脚本语言特性以及其看似随意的编写风格,导致长期以来人们对这一门语言的误解,即认为 JavaScript 不是一门面向对象的语言,或者只是部分具备一些面向对象的特征.本文将回归面向对象本意,从对语言感悟的角度阐述为什么 JavaScript 是一门彻底的面向对象的语言,以及如何正确地使用这一特性. 适合阅读人群 当今 JavaScript 大行其道,各种应用对其依赖日深.web 程序员已逐渐习惯使用各种优秀的 JavaScript 框架快速开发 Web 应用,从而忽略了

Javascript Closures

Introduction The Resolution of Property Names on Objects Assignment of Values Reading of Values Identifier Resolution, Execution Contexts and Scope Chains The Execution Context Scope chains and [[scope]] Identifier Resolution Closures Automatic Garba

通过示例学习JavaScript闭包

译者按: 在上一篇博客,我们通过实现一个计数器,了解了如何使用闭包(Closure)**,这篇博客将提供一些代码示例,帮助大家理解闭包. 原文: JavaScript Closures for Dummies 译者: Fundebug 为了保证可读性,本文采用意译而非直译.另外,本文版权归原作者所有,翻译仅用于学习. 闭包并不神奇 其实,只要你领会了闭包的关键概念,一切就非常简单了.作为JavaScript开发者,你应该可以理解以下代码: Example 1 function sayHello(