Javascript高级编程学习笔记(26)—— 函数表达式(4)私有变量
私有变量
严格来讲,JS中没有私有成员的概念,所有对象属性都是公有的。
但是JS中有私有变量的概念
所有在函数中定义的变量都可以认为是私有变量,因为不能在函数外部进行访问
私有变量包括
1.函数参数
2.局部变量
3.函数内部定义的其他函数
还有一个概念叫 特权方法
特权方法指的就是有权能够访问私有变量的方法
私有变量和特权方法主要用来隐藏不应该被直接修改的数据
function Person(name){
this.getName = function(){
return name;
}
this.setName = function(newName){
name = newName;
}
}
比如上述构造函数,在创建对象传入一个 name
而这个 name 只能通过每个对象的两个方法进行访问和修改
有些时候比如一个特殊的对象,每次对它某个属性值的操作只能加一和减一
这种情况下,如果我们将这个值不作为私有变量,所有情况都能访问,那么它被意外修改的可能性就很高了
这就是JS中私有变量的主要作用
静态私有变量
上面的方法我们创建了一个私有变量 name
但是通过该构造函数构造的每个实例的 name 都是独立的
如果我们希望像其他的语言那样创建一个所有实例共用的私有变量怎么办呢?
(function(){
// 私有变量
var privateValue = 10;
var privateMethod = function(){
return false;
}
// 构造函数
Public = function(){};
// 公有方法
Public.prototype.publicMethod(){
private++;
return privateMethod();
}
}
上方的代码在一个自执行的函数中,创建了两个私有变量和一个构造函数
由于我们没有使用 var 进行声明,所以 Public 会默认添加到全局作用域(当然这种方法在严格模式下无法使用)
然后我们给这个构造函数的原型添加了一个公有方法
由于这个公有方法是自执行函数的闭包,所以可以访问到我们之前创建的私有变量
并且因为我们将这个公有方法添加在这个构造函数的原型上,所以这个构造函数的所有实例,都使用的这个公有方法
自然访问到的私有变量也是同一个
模块模式
前面的内容主要是为自定义对象创建私有变量的
那么模块模式又是什么意思呢?
模块模式指的就是为单例创建私有变量和特权方法
所谓单例就是只有一个实例对象
按照惯例,JS中创建单例一般都是用字面量的形式来创建的
模块模式如下:
var singleton = function(){
// 创建私有变量
var privateValue = 10;
return {
getValue:function(){
return privateValue;
}
}
}();
这种模式适用于,当需要对对象进行初始化,并且需要公开一些访问私有变量的公共方法,就可以使用模块模式
增强模块模式
刚才的模块模式存在一个问题
那就是无法判断生成单例的类型,一般来说也用不着判断一个单例的类型
但难免有些情况需要让单例是某个类型的实例
所以就有了增强模块模式
var singleton = function(){
var privateValue = 10;
var object = new CustomType();
//添加特权
object.publicMethod = function(){
privateValue++;
return privateValue;
}
return object;
}();
以上就是和函数表达式相关的内容啦,明天开始更BOM
Javascript高级编程学习笔记(26)—— 函数表达式(4)私有变量的更多相关文章
- Javascript高级编程学习笔记(25)—— 函数表达式(3)模仿块级作用域
昨天写了闭包 今天就来聊聊块级作用域的事情 在绝大多数编程语言中,都有块级作用域这个概念 什么是块级作用域呢? 前面我们在刚开始讲的时候说过,JS中的大括号(不在赋值运算符的后面)表示代码块 块级作用 ...
- Javascript高级编程学习笔记(23)—— 函数表达式(1)递归
前面的文章中,我在介绍JS中引用类型的时候提过,JS中函数有两种定义方式 第一种是声明函数,即使用function关键字来声明 第二种就是使用函数表达式,将函数以表达式的形式赋值给一个变量,这个变量就 ...
- Javascript高级编程学习笔记(24)—— 函数表达式(2)闭包
昨天的文章中主要记录了,函数表达式与函数声明的区别 以及在JS中如何安全地使用递归 那么既然要深入地理解JS中的函数,闭包就是一个绕不开的概念 闭包 JS高编一书中对闭包的概念定义如下: 闭包是指有权 ...
- 《JavaScript高级程序设计》笔记:函数表达式(七)
递归 function factorial(num){ if(num<=1){ return 1; }else { return num * arguments.callee(num-1); } ...
- Javascript高级编程学习笔记(16)—— 引用类型(5) Function类型
JS中许多有趣的地方都和函数脱不了联系 那么是什么让JS中的函数这么有趣呢? 我们一起来看看吧 Function类型 在JS中函数实际上就是对象,每个函数都是Function类型的实例,和JS的其他引 ...
- Javascript高级编程学习笔记(9)—— 执行环境
今天主要讲一下,JS底层的一些东西,这些东西不太好举例(应该是我水平不够) 望大家多多海涵,比心心 执行环境 执行环境(执行上下文,全文使用执行环境 )是JS中最为重要的一个概念,执行环境决定了,变量 ...
- Javascript高级编程学习笔记(7)—— 函数
前几天有事耽搁了,今天继续更新 今天的主要内容是JS中的函数 这一篇主要讲函数的定义等内容,至于变量提升.执行环境.闭包.内存回收等内容在后面讲,高玩们可以不用看下面的正文了. 函数 首先来讲,函数对 ...
- JavaScript高级编程学习笔记(第三章之一)
继续记笔记,JavaScript越来越有意思了. 继续... 第三章:JavaScript基础 ECMAScript语法在很大程度上借鉴了C和其它类似于C的语言,比如Java和Perl. 大小写敏感: ...
- Javascript高级编程学习笔记(6)—— 流程控制语句
话不多说,我们直接开始进入今天的主题 流程控制语句 首先什么是流程控制语句呢? 顾名思义,就是控制流程的语句. 在JS中语句定义了ECMAScript中的主要语法,让我们可以使用一系列的关键字来完成指 ...
随机推荐
- ABP框架记录
1.先在Core项目中建立模型Models>Model.cs/ModelManager.cs 2.在Application中建立接口和具体类:IModelAppService.csModelAp ...
- Flask 单元测试 unittest
import unittest 单元测试 app = Flask(__name__) -------------------------------------------- import unite ...
- hbase-读操作
(学习笔记) client和regionServer连接,通过rowkey查找对应的region 多个列簇生成多个storeScaner 每个storeScaner生成一个MemstoreScanne ...
- Servlet中的转发与重定向
Sevlet 的转发与重定向都可以使得浏览器指向另一个资源文件,但它们的运行机制不相同. 一.Servlet的转发 有两种方式获得转发对象(RequestDispathcer): HttpServle ...
- srs之深入浅出看流媒体
本文转载:https://blog.csdn.net/zjqlovell/article/details/50786040 CDN这几年爆炸式增长,带宽提速是根源,而HTTP始终还是那个屌样,因此目前 ...
- virtualbox装个 ubuntu
好久没弄 虚拟机了,感觉好不习惯 根据网上的步骤装了一ubuntu 启动报错 virtualbox intel_rapl: no valid rapl domains ...... 搜索到了一片中文博 ...
- TCP/IP数据加密传输及CA简述
TCP/IP跨主机之间的通信数据封装发送的都是明文数据,现代通讯中会有安全问题. 三个安全问题 如:A发送消息给B的三个安全问题机密性:明文传输如:ftp,http,smtp,telnet等完整性:数 ...
- hbase_存储模型
Hbase 是按列存储,所以每个列族存储在一个HDFS文件上. Hbase表中的行是按照rowkey字典序进行排列的,并且表格在行的方向上被分割为多个region(按照行进行分割的) region 是 ...
- Docker学习笔记:基础
docker的概念 :docker是一个可供开发者在容器中 开发 部署 运行 应用的一个平台.通过使用Linux容器去部署应用的方式称为容器化. 基础概念 Images and Container i ...
- 记录mysql安装过程遇到问题
1. 远程连接授权 登陆mysql数据库 (如果安装在系统盘可以直接命令, 否则要切换到安装目录..bin/) mysql -u root -p mysql> use mysql; - ...