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

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

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

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

require.js

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

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

 

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

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

//require 真正實(shí)現(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;

  //模塊逐個(gè)加載
  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)建一個(gè)script標(biāo)簽
function createScript(src, index) {
  var $script = document.createElement('script');

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

  return $script;
}

 然后寫了2個(gè)導(dǎo)出模塊的js文件, 只寫了最簡單的exports實(shí)現(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ī)淼囊粋€(gè)極為簡單的requirejs實(shí)現(xiàn)方法全部內(nèi)容了,希望大家多多支持腳本之家~

相關(guān)文章

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

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

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

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

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

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

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

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

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

    學(xué)習(xí)JavaScript設(shè)計(jì)模式之狀態(tài)模式

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

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

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

    JS層移支示例代碼

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

    javascript eval()用法

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

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

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

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

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

最新評論