欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

一個極為簡單的requirejs實現(xiàn)方法

 更新時間:2016年10月20日 08:29:29   投稿:jingxian  
下面小編就為大家?guī)硪黄粋€極為簡單的requirejs實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

require和 sea的源碼分析,我之前的博客有寫過, 今天我想分享的是一個很簡單的核心代碼(不帶注釋和空行大概60行), 沒有容錯判斷。

require.js

require函數(shù)實現(xiàn)用一句話概括:

依次加載require的模塊,然后監(jiān)測script的onload事件,判斷所有模塊加載成功,執(zhí)行require的callback, 如果只帶一個參數(shù)且不是數(shù)組,就是加載成功后return 模塊。

 

//標記已經(jīng)加載成功的個數(shù)
var REQ_TOTAL = 0;
//模塊導出
window.exports = {};
//記錄各個模塊的順序
var exp_arr = [];

//判斷是否數(shù)組
function isArray(param) {
  return param instanceof Array;
}

//require 真正實現(xiàn)
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('head');

    (function($script) {
      //檢測script 的onload事件
      $script.onload = function() {
        REQ_TOTAL++;

        var script_index = $script.getAttribute('index');

        exp_arr[script_index] = exports;

        window.exports = {};

        //所有鏈接加載成功后,執(zhí)行callback
        if(REQ_TOTAL == req_len) {
          callback && callback.apply(exports, exp_arr);

       
        }

      }

      $node.appendChild($script);
    })($script);

  }

}

//創(chuàng)建一個script標簽
function createScript(src, index) {
  var $script = document.createElement('script');

  $script.setAttribute('src', src);
  $script.setAttribute('index', index);

  return $script;
}

 然后寫了2個導出模塊的js文件, 只寫了最簡單的exports實現(xiàn)

define.js

exports.define = {
  topic: 'my export',
  desc: 'this is other way to define ',
  sayHello: function() {
    console.log('topic ' + this.topic + this.desc);
  }
}

define2.js

exports.define = {
  name: 'xm',
  age: 22,
  info: function() {
    console.log('topic ' + this.name + this.age);
  }
}

然后測試demo很簡單

//測試demo
 require(['../res/define.js', '../res/define2.js'], function(def, def2) {
   def.define.sayHello();
 
   def2.define.info();
 });

以上就是小編為大家?guī)淼囊粋€極為簡單的requirejs實現(xiàn)方法全部內(nèi)容了,希望大家多多支持腳本之家~

相關(guān)文章

  • JS判斷是否為JSON對象及是否存在某字段的方法(推薦)

    JS判斷是否為JSON對象及是否存在某字段的方法(推薦)

    下面小編就為大家?guī)硪黄狫S判斷是否為JSON對象及是否存在某字段的方法(推薦)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-11-11
  • TypeScript字符串的常用操作總結(jié)

    TypeScript字符串的常用操作總結(jié)

    這篇文章主要為大家詳細介紹了TypeScript中字符串的常用操作,例如substring、indexOf、slice、replace等,感興趣的小伙伴可以跟隨小編一起學習一下
    2023-08-08
  • JS中FormData類實現(xiàn)文件上傳

    JS中FormData類實現(xiàn)文件上傳

    這篇文章主要為大家詳細介紹了JS中FormData類實現(xiàn)文件上傳功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • TypeScript中Array(數(shù)組)聲明與簡單使用方法

    TypeScript中Array(數(shù)組)聲明與簡單使用方法

    這篇文章主要給大家介紹了關(guān)于TypeScript中Array(數(shù)組)聲明與簡單使用的相關(guān)資料,TypeScript Array(數(shù)組)數(shù)組對象是使用單獨的變量名來存儲一系列的值,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-12-12
  • 學習JavaScript設(shè)計模式之狀態(tài)模式

    學習JavaScript設(shè)計模式之狀態(tài)模式

    這篇文章主要為大家介紹了JavaScript設(shè)計模式中的狀態(tài)模式,對JavaScript設(shè)計模式感興趣的小伙伴們可以參考一下
    2016-01-01
  • JS密碼生成與強度檢測完整實例(附demo源碼下載)

    JS密碼生成與強度檢測完整實例(附demo源碼下載)

    這篇文章主要介紹了JS密碼生成與強度檢測完整實例,涉及JavaScript密碼的生成,破解時間計算,密碼安全監(jiān)測及大小寫鎖定判斷等功能的實現(xiàn)技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下
    2016-04-04
  • JS層移支示例代碼

    JS層移支示例代碼

    JS層移支示例代碼...
    2007-03-03
  • javascript eval()用法

    javascript eval()用法

    實例分析eval的一些使用方法與技巧。
    2009-03-03
  • JS 自執(zhí)行函數(shù)原理及用法

    JS 自執(zhí)行函數(shù)原理及用法

    這篇文章主要介紹了JS 自執(zhí)行函數(shù)原理及技巧,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-08-08
  • js修改table中Td的值(定義td的單擊事件)

    js修改table中Td的值(定義td的單擊事件)

    單擊事件,將Td內(nèi)容更新為一個Div,其中裝載了一個Text,用于用戶輸入新的Td的值,一個確定按鈕,一個取消按鈕,用于保存或取消用戶的輸入內(nèi)容
    2013-01-01

最新評論