闭包原理个人理解
function A(){var s=10;function B(){alert(s); }return B;}var result=A();result(); // 10
B函數,就是閉包。如果一個函數訪問了它的外部變量,那么它就是一個閉包。
特性:
1、定義在一個函數內部的函數
2、能夠讀取其他函數內部變量的函數
3、可以將函數內部和函數外部連接起來
作用(用途):
1、避免全局變量污染
2、匿名自執行函數
var data= { table : [], tree : {} }; (function(dm){ for(var i = 0; i < dm.table.rows; i++){ var row = dm.table.rows[i]; for(var j = 0; j < row.cells; i++){ drawCell(i, j); } } })(data);3、封裝
var person = function(){ //變量作用域為函數內部,外部無法訪問 var name = "default"; return { getName : function(){ return name; }, setName : function(newName){ name = newName; } } }(); print(person.name);//直接訪問,結果為undefined print(person.getName()); person.setName("abruzzi"); print(person.getName()); 得到結果如下: undefined default abruzzi?
4、實現類和繼承
function Person(){ var name = "default"; return { getName : function(){ return name; }, setName : function(newName){ name = newName; } } }; var p = new Person();p.setName("Tom");alert(p.getName());var Jack = function(){};//繼承自PersonJack.prototype = new Person();//添加私有方法Jack.prototype.Say = function(){alert("Hello,my name is Jack");};var j = new Jack();j.setName("Jack");j.Say();alert(j.getName());?
5、結果緩存
var CachedSearchBox = (function(){ var cache = {}, count = []; return { attachSearchBox : function(dsid){ if(dsid in cache){//如果結果在緩存中 return cache[dsid];//直接返回緩存中的對象 } var fsb = new uikit.webctrl.SearchBox(dsid);//新建 cache[dsid] = fsb;//更新緩存 if(count.length > 100){//保正緩存的大小<=100 delete cache[count.shift()]; } return fsb; }, clearSearchBox : function(dsid){ if(dsid in cache){ cache[dsid].clearSelection(); } } }; })(); CachedSearchBox.attachSearchBox("input");?
轉載于:https://www.cnblogs.com/lhl66/p/7486157.html
總結
- 上一篇: Java基础——Servlet(六)分页
- 下一篇: elasticsearch 复杂查询小记