DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> Javascript Memoization 緩存函數使用說明
Javascript Memoization 緩存函數使用說明
編輯:關於JavaScript     
舉個例子
復制代碼 代碼如下:
var flower= function(){
var t=0,i=0;
for(;i<5000000;i++){
t++;
}
return t;
}

flower 返回t的值
假設這個函數需要花費 2-3秒 。
通過 Memoization 函數,再次查找相同的值時,直接獲取事先緩存好的 value,立刻返回;
Memoization 函數
復制代碼 代碼如下:
var Memoize = function(fn, cache, refetch, obj){
cache = cache || {};//用來緩存結果
return function(){
var k = arguments[1] ? Array.prototype.join.call(arguments, '__') : arguments[0];//多個參數則有'__'分隔開
if (!(k in cache) || (refetch && cache[k] == refetch)) { //如果不在緩存列表中,並且和給定的refetch值相等,重新去運算
cache[k] = fn.apply(obj || fn, arguments); //obj參數可用來改變this指針
}
return cache[k];//返回結果
}
}

Demo:

[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved