javascript 保护变量不被随意修改------优雅的编程

/*
* 1.如果在renderTitle,renderContent里面,这样总数据谁都能修改,不安全
* 改进
* 1.规定一个专门修改数据的方法,如果想修改数据只能走这个方法
*
* action代表一个命令对象,就是一个普通的js对象,起码需要一个字段控制命令类型type,其他字段随意
*
* */
const CHANGE_FONT_SILE=‘CHANGE_FONT_SILE‘;
//设置一个闭包,把变量保护起来,通过返回值调用
function createStore() {
    let appState={
        fontSize:‘26px‘,
        title:{
            text:‘标题‘,
            color:‘red‘
        },
        content:{
            text:‘类容‘,
            color:‘green‘
        }
    }
    //保护变量被修改,深克隆
    let getState=()=>JSON.parse(JSON.stringify(appState));
    //改变变量的方法
    let dispatch=(action)=>{
        switch(action.type){
            case CHANGE_FONT_SILE:
                appState.fontSize=action.fontSize;
            default:
                return;
        }
    }
    //返回出去的修改和取值的接口
  return{
      getState,
      dispatch
  }
}

let store=createStore();
//取值函数
function renderTitle() {
    let titleEle = document.querySelector(‘#title‘);

    titleEle.innerHTML = store.getState().title.text;
    titleEle.style.color = store.getState().title.color;
    titleEle.style.fontSize = store.getState().fontSize;
}
function renderContent() {
    let titleEle=document.querySelector("#content");
    titleEle.innerHTML=store.getState().content.text;
    titleEle.style.color=store.getState().content.color;
    titleEle.style.fontSize=store.getState().fontSize;
}
function renderApp() {
    renderTitle();
    renderContent()
}
//修改appState里面初始值,单独一个修改文件
store.dispatch({type:CHANGE_FONT_SILE,fontSize:‘30px‘})
renderApp();
时间: 2024-08-17 11:22:56

javascript 保护变量不被随意修改------优雅的编程的相关文章

自学JavaScript(一) 变量-作用域

JavaScript 作用域 作用域—可访问变量的集合. 全局变量或者函数可以覆盖window对象的变量或者函数: 局部变量和window对象可以覆盖全局变量和函数. JavaScript 作用域 在 JavaScript 中, 对象和函数同样也是变量. 在 JavaScript 中, 作用域为可访问变量,对象,函数的集合. JavaScript 函数作用域: 作用域在函数内修改. 注:因为局部变量只作用于函数内,所以不同的函数可以使用相同名称的变量. 局部变量在函数开始执行时创建,函数执行完后

JavaScript的变量及作用域

JavaScript 的变量与其他语言的变量有很大区别. JavaScript 变量是松散型的(不强制类型)本质,决定了它只是在特定时间用于保存特定值的一个名字而已. 由于不存在定义某个变量必须要保存何种数据类型值的规则,变量的值及其数据类型可以在脚本的生命周期内改变. 一.基本类型和引用类型的值 1.ECMAScript 变量可能包含两种不同的数据类型的值:基本类型值和引用类型值. 2.基本类型值指的是那些保存在栈内存中的简单数据段,即这种值完全保存在内存中的一个位置. 3.而引用类型值则是指

JavaScript基础——变量、作用域和内存问题

按照ECMA-262的定义,JavaScript的变量与其他语言的变量有很大区别.JavaScript变量松散类型的本质,决定了它只是在特定时间用于保存特定值的一个名字而已.由于不存在定义某个变量必须要保存何种数据类型值的规则,变量的值即其数据类型可以在脚本的声明周期内改变.尽管从某种角度看,这可能是一个既有趣又强大,但同时又容易出问题的特性,但JavaScript变量实际的复杂程度远不止如此. 基本类型和引用类型的值 ECMAScript变量可能包含两种不同数据类型的值:基本类型和引用类型值.

JavaScript面向对象—变量及作用域和内存问题

基本类型和引用类型的值 ECMAScript 变量可能包含两种不同的数据类型的值:基本类型值和引用类型值. 基本类型值指的是那些保存在栈内存中的简单数据段,即这种值完全保存在内存中的一个位置. 而引用类型值则是指那些保存在堆内存中的对象,意思是变量中保存的实际上只是一个指针,这个指针指向内存中的另一个位置,该位置保存对象. 将一个值赋给变量时,解析器必须确定这个值是基本类型值,还是引用类型值. 基本类型值: 有以下几种:Undefined.Null.Boolean.Number 和 String

0131 JavaScript数组中新增元素:修改数组索引、修改 length 长度、数组翻转

? 数组中可以通过以下方式在数组的末尾插入新元素: 数组[ 数组.length ] = 新数据; 1.5.1 通过修改 length 长度新增数组元素 可以通过修改 length 长度来实现数组扩容的目的 length 属性是可读写的 var arr = ['red', 'green', 'blue', 'pink']; arr.length = 7; console.log(arr); console.log(arr[4]); // undefined console.log(arr[5]);

轻松学习JavaScript五:JavaScript的变量和数据类型

对于一们编程语言,肯定包含变量和数据类型.今天我们就来看看JavaScript脚本语言的变量和数据类型.相对 于其他的Java,C++等高级程序语言,JavaScript显得很简单. 一变量 JavaScript的变量是松散类型的,所谓松散就是用来保存任何类型的数据.变量是存储信息的容器.定义变量时 要使用var操作符(var是关键字),后面跟一个变量名(变量名是标识符).变量也就是初始化后可以再次改变的量. 那么我们来看看实例: <span style="font-size:18px;&

[转]深入理解JavaScript的变量作用域

1.JavaScript的作用域链 2.函数体内部,局部变量的优先级比同名的全局变量高. 3.JavaScript没有块级作用域. 4.函数中声明的变量在整个函数中都有定义. 5.未使用var关键字定义的变量都是全局变量. 6.全局变量都是window对象的属性 在学习JavaScript的变量作用域之前,我们应当明确几点: JavaScript的变量作用域是基于其特有的作用域链的. JavaScript没有块级作用域. 函数中声明的变量在整个函数中都有定义. 1.JavaScript的作用域链

javascript中变量声明要早于赋值

javascript中变量声明要早于赋值:这里只做简单的现象介绍,具体不做深究,先看一段代码实例: var webName="蚂蚁部落"; document.write(webName); 对于这段代码应该没有任何问题,输出结果是:蚂蚁部落.再来看一段代码: document.write(webName); var webName="蚂蚁部落"; 按照代码是顺序执行的理论,以上代码应该会报错才对,但是这里输出结果却是:undefined.这说明在执行输出之前,变量已

javascript 释放变量

JavaScript 释放变量 在Javascript是可以使用"delete"来手动删除变量,通过这样的方法让GC(Garbage collection)来回收内存,但在JS中并不是所有的变量都可以被删除的. 1.var 声明的 全局变量"a" 在使用 "delete a" 后 输出值依然为 "1". 2.未使用var 声明的全局变量"b" 成为了  "window"的属性,在使用 &