非常にシンプルなrequirejsの実装方法

高洛峰
リリース: 2016-12-09 15:49:38
オリジナル
1493 人が閲覧しました

前回のブログでrequireとseaのソースコード解析について書きましたが、今日共有したいのはフォールトトレランス判定のない非常にシンプルなコアコード(コメントや空行なしの約60行)です。

require.js

require 関数の実装は、次の一文に要約できます:

require モジュールを順番にロードし、スクリプトの onload イベントを監視し、すべてのモジュールが正常にロードされたことを確認し、require If コールバックを実行します。パラメータは 1 つだけで、配列ではありません。正常にロードされた後にモジュールを返すことになります。

//标记已经加载成功的个数
var REQ_TOTAL = 0;
//模块导出
window.exports = {};
//记录各个模块的顺序
var exp_arr = [];
 
//判断是否数组
function isArray(param) {
  return param instanceof Array;
}
 
//require 真正实现
function require(arr, callback) {
 
  var req_list;
 
  if(isArray(arr)) {
    req_list = arr;
  } else {
    req_list = [arr];
  }
  var req_len = req_list.length;
 
  //模块逐个加载
  for(var i=0;i<req_len;i++) {
    var req_item = req_list[i];
 
    var $script = createScript(req_item, i);
 
    var $node = document.querySelector(&#39;head&#39;);
 
    (function($script) {
      //检测script 的onload事件
      $script.onload = function() {
        REQ_TOTAL++;
 
        var script_index = $script.getAttribute(&#39;index&#39;);
 
        exp_arr[script_index] = exports;
 
        window.exports = {};
 
        //所有链接加载成功后,执行callback
        if(REQ_TOTAL == req_len) {
          callback && callback.apply(exports, exp_arr);
 
        
        }
 
      }
 
      $node.appendChild($script);
    })($script);
 
  }
 
}
 
//创建一个script标签
function createScript(src, index) {
  var $script = document.createElement(&#39;script&#39;);
 
  $script.setAttribute(&#39;src&#39;, src);
  $script.setAttribute(&#39;index&#39;, index);
 
  return $script;
}
ログイン後にコピー

次に、モジュールをエクスポートするための js ファイルを 2 つ書き、最も単純なエクスポート実装だけを書きました

define.js

exports.define = {
  topic: &#39;my export&#39;,
  desc: &#39;this is other way to define &#39;,
  sayHello: function() {
    console.log(&#39;topic &#39; + this.topic + this.desc);
  }
}
ログイン後にコピー

define2.js

exports.define = {
  name: &#39;xm&#39;,
  age: 22,
  info: function() {
    console.log(&#39;topic &#39; + this.name + this.age);
  }
}
ログイン後にコピー

その後、デモをテストしますとても簡単です

//测试demo
 require([&#39;../res/define.js&#39;, &#39;../res/define2.js&#39;], function(def, def2) {
   def.define.sayHello();
  
   def2.define.info();
 });
ログイン後にコピー


関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート