プロキシ パターンは、オブジェクトへのアクセスを制御するためにオブジェクトのサロゲートまたはプレースホルダーを提供することです
プロキシ パターンの使用 (個人的な理解): 現在のオブジェクトの単一の責任 (相対的な独立性) を保証するために、コードの効率、ステータスの判断、等
最も一般的に使用されるプロキシ モードは、仮想プロキシ および キャッシュ プロキシ
1. 仮想エージェント
仮想エージェントは、実際に必要になるまで、一部の高価なオブジェクトの作成と実行を遅らせます
例: 仮想エージェントはイメージのプリロードを実装します
// 图片加载函数 var myImage = (function(){ var imgNode = document.createElement("img"); document.body.appendChild(imgNode); return { setSrc: function(src) { imgNode.src = src; } } })(); // 引入代理对象 var proxyImage = (function(){ var img = new Image; img.onload = function(){ // 图片加载完成,正式加载图片 myImage.setSrc( this.src ); }; return { setSrc: function(src){ // 图片未被载入时,加载一张提示图片 myImage.setSrc("file://c:/loading.png"); img.src = src; } } })(); // 调用代理对象加载图片 proxyImage.setSrc( "http://images/qq.jpg");
例: 仮想プロキシは HTTP リクエストをマージします
ある機能が頻繁なネットワーク リクエストを必要とする場合、これによりかなりのオーバーヘッドが発生します。解決策は、プロキシ機能を使用して一定期間内にリクエストを収集し、それらを一度にサーバーに送信することです。
例: ファイル同期機能。ファイルを選択すると、別のバックアップ サーバーに同期されます
// 文件同步函数 var synchronousFile = function( id ){ console.log( "开始同步文件,id为:" + id ); } // 使用代理合并请求 var proxySynchronousFile = (function(){ var cache = [], // 保存一段时间内需要同步的ID timer; // 定时器指针 return function( id ){ cache[cache.length] = id; if( timer ){ return; } timer = setTimeout( function(){ proxySynchronousFile( cache.join( "," ) ); // 2s 后向本体发送需要同步的ID集合 clearTimeout( timer ); // 清空定时器 timer = null; cache = []; // 晴空定时器 },2000 ); } })(); // 绑定点击事件 var checkbox = document.getElementsByTagName( "input" ); for(var i= 0, c; c = checkbox[i++]; ){ c.onclick = function(){ if( this.checked === true ){ // 使用代理进行文件同步 proxySynchronousFile( this.id ); } } }
2. キャッシングプロキシ
キャッシュ プロキシは、一部の高価な操作結果を一時的に保存できます。次の操作では、渡されたパラメーターが前の操作と一致する場合、前の操作結果を返すことができます。
例: 乗算、加算などのキャッシュ プロキシを作成します
// 计算乘积 var mult = function(){ var a = 1; for( var i = 0, l = arguments.length; i < l; i++){ a = a * arguments[i]; } return a; }; // 计算加和 var plus = function () { var a = 0; for( var i = 0, l = arguments.length; i < l; i++ ){ a += arguments[i]; } return a; }; // 创建缓存代理的工厂 var createProxyFactory = function( fn ){ var cache = {}; // 缓存 - 存放参数和计算后的值 return function(){ var args = Array.prototype.join.call(arguments, "-"); if( args in cache ){ // 判断出入的参数是否被计算过 console.log( "使用缓存代理" ); return cache[args]; } return cache[args] = fn.apply( this, arguments ); } }; // 创建代理 var proxyMult = createProxyFactory( mult ), proxyPlus = createProxyFactory( plus ); console.log( proxyMult( 1, 2, 3, 4 ) ); // 输出: 24 console.log( proxyMult( 1, 2, 3, 4 ) ); // 输出: 缓存代理 24 console.log( proxyPlus( 1, 2, 3, 4 ) ); // 输出: 10 console.log( proxyPlus( 1, 2, 3, 4 ) ); // 输出: 缓存代理 10
上記の 3 つの例では、JavaScript プロキシ モードを詳しく紹介しています。学習に役立つことを願っています。