- JavaScript:Moving to ES2015
- Ved Antani Simon Timms Narayan Prusty
- 201字
- 2021-07-09 19:07:33
Private variables
Closures are frequently used to encapsulate some information as private variables. JavaScript does not allow such encapsulation found in programming languages such as Java or C++, but by using closures, we can achieve similar encapsulation:
function privateTest(){
var points=0;
this.getPoints=function(){
return points;
};
this.score=function(){
points++;
};
}
var private = new privateTest();
private.score();
console.log(private.points); // undefined
console.log(private.getPoints());
In the preceding example, we are creating a function that we intend to call as a constructor. In this privateTest()
function, we are creating a var points=0
variable as a function-scoped variable. This variable is available only in privateTest()
. Additionally, we create an accessor function (also called a getter)—getPoints()
—this method allows us to read the value of only the points variable from outside privateTest()
, making this variable private to the function. However, another method, score()
, allows us to modify the value of the private point variable without directly accessing it from outside. This makes it possible for us to write code where a private variable is updated in a controlled fashion. This pattern can be very useful when you are writing libraries where you want to control how variables are accessed based on a contract and pre-established interface.
- ExtGWT Rich Internet Application Cookbook
- Progressive Web Apps with React
- Linux核心技術從小白到大牛
- MATLAB 2020 從入門到精通
- Programming ArcGIS 10.1 with Python Cookbook
- Learning ELK Stack
- JAVA程序設計實驗教程
- Oracle 18c 必須掌握的新特性:管理與實戰
- PHP+Ajax+jQuery網站開發項目式教程
- Orchestrating Docker
- Effective C++:改善程序與設計的55個具體做法(第三版)中文版(雙色)
- 從零開始學UI設計·基礎篇
- Splunk Developer's Guide(Second Edition)
- Java Web程序員面試筆試寶典
- Getting Started with SpriteKit