日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 前端技术 > javascript >内容正文

javascript

菜鸟requireJS教程---2、基本知识

發(fā)布時(shí)間:2025/7/14 javascript 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 菜鸟requireJS教程---2、基本知识 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

菜鳥requireJS教程---2、基本知識(shí)

一、總結(jié)

一句話總結(jié):

1、requireJS中的api就define(比如定義自己的函數(shù))和require
2、requireJS使用的話就是配置require.config(main.js中)和調(diào)用:require(['jquery', 'angular'], function ($, angular) {
app目錄中定義自己的函數(shù)util.js define(['bootstrap'], function () {return {change: function () {$('body').css({'backgroundColor': 'red'});},show: function () {alert('后盾人')},message: function () {alert('houdunren.com')}} });

?

?

1、require會(huì)定義三個(gè)變量:define,require,requirejs(其中require === requirejs,一般使用require更簡(jiǎn)短),他們 分別是干嘛的?

define:從名字就可以看出這個(gè)api是用來(lái)定義一個(gè)模塊
require:加載依賴模塊,并執(zhí)行加載完后的回調(diào)函數(shù)

?

2、require加載模塊需要注意的?

|||-begin

require(["js/a"],function(){alert("load finished"); })

|||-end

require中的依賴是一個(gè)數(shù)組,即使只有一個(gè)依賴,你也必須使用數(shù)組來(lái)定義

?

3、require的第二個(gè)參數(shù)callback(一個(gè)function)的作用是什么?

|||-begin

require(["js/a"],function(){alert("load finished"); })

|||-end

是用來(lái)處理加載完畢后的邏輯

?

4、require.config中paths配置多個(gè)路徑作用以及實(shí)例?

作用:如果遠(yuǎn)程cdn庫(kù)沒(méi)有加載成功,可以加載本地的庫(kù)
實(shí)例:"jquery" : ["http://libs.baidu.com/jquery/2.0.3/jquery", "js/jquery"],
require.config({paths : {"jquery" : ["http://libs.baidu.com/jquery/2.0.3/jquery", "js/jquery"],"a" : "js/a" } }) require(["jquery","a"],function($){$(function(){alert("load finished"); }) })

?

?

5、requireJS的全局配置在哪個(gè)文件中?

main.js:requirejs提供了一種叫"主數(shù)據(jù)"的功能,main.js,在里面配置

?

6、requireJS中的main.js的作用是什么?

全局配置,也就是用來(lái)存放require.config
require.config({baseUrl: '../resource/app',paths: {'hd': 'hd','css': '../lib/css.min','jquery': '../lib/jquery.min','angular': '../lib/angular.min','bootstrap': '../lib/bootstrap.min',},shim: {'hd': {// exports: 'modal',init: function () {return {modal: modal,success: success,}}},//houdunren.com'bootstrap': {'deps': ['jquery', 'css!../css/bootstrap.min.css', 'css!../css/font-awesome.min.css']}} });

?

?

7、script data-main="js/main" src="js/require.js"中data-main的作用是什么?

data-main屬性指定的 js 將在加載完 require.js 后處理,也就是先加載requireJS然后配置

?

8、requireJS中如何定義自己的函數(shù)?

比如app目錄中定義自己的函數(shù)util.js:define(['bootstrap'], function () {
define(['bootstrap'], function () {return {change: function () {$('body').css({'backgroundColor': 'red'});},show: function () {alert('后盾人')},message: function () {alert('houdunren.com')}} });

?

?

?

二、requirejs基本知識(shí)

轉(zhuǎn)自或參考:JS模塊化工具requirejs教程(二):基本知識(shí) | 菜鳥教程
https://www.runoob.com/w3cnote/requirejs-tutorial-2.html

?

基本API

require會(huì)定義三個(gè)變量:define,require,requirejs,其中require === requirejs,一般使用require更簡(jiǎn)短

  • define 從名字就可以看出這個(gè)api是用來(lái)定義一個(gè)模塊
  • require 加載依賴模塊,并執(zhí)行加載完后的回調(diào)函數(shù)

前一篇中的a.js:

define(function(){function fun1(){ alert("it works"); } fun1(); })

通過(guò)define函數(shù)定義了一個(gè)模塊,然后再頁(yè)面中使用:

require(["js/a"]);

來(lái)加載該模塊(注意require中的依賴是一個(gè)數(shù)組,即使只有一個(gè)依賴,你也必須使用數(shù)組來(lái)定義),require API的第二個(gè)參數(shù)是callback,一個(gè)function,是用來(lái)處理加載完畢后的邏輯,如:

require(["js/a"],function(){ alert("load finished"); })

加載文件

之前的例子中加載模塊都是本地js,但是大部分情況下網(wǎng)頁(yè)需要加載的JS可能來(lái)自本地服務(wù)器、其他網(wǎng)站或CDN,這樣就不能通過(guò)這種方式來(lái)加載了,我們以加載一個(gè)jquery庫(kù)為例:

require.config({paths : { "jquery" : ["http://libs.baidu.com/jquery/2.0.3/jquery"] } }) require(["jquery","js/a"],function($){ $(function(){ alert("load finished"); }) })

這邊涉及了require.config,require.config是用來(lái)配置模塊加載位置,簡(jiǎn)單點(diǎn)說(shuō)就是給模塊起一個(gè)更短更好記的名字,比如將百度的jquery庫(kù)地址標(biāo)記為jquery,這樣在require時(shí)只需要寫["jquery"]就可以加載該js,本地的js我們也可以這樣配置:

require.config({paths : { "jquery" : ["http://libs.baidu.com/jquery/2.0.3/jquery"], "a" : "js/a" } }) require(["jquery","a"],function($){ $(function(){ alert("load finished"); }) })

通過(guò)paths的配置會(huì)使我們的模塊名字更精煉,paths還有一個(gè)重要的功能,就是可以配置多個(gè)路徑,如果遠(yuǎn)程cdn庫(kù)沒(méi)有加載成功,可以加載本地的庫(kù),如:

require.config({paths : { "jquery" : ["http://libs.baidu.com/jquery/2.0.3/jquery", "js/jquery"], "a" : "js/a" } }) require(["jquery","a"],function($){ $(function(){ alert("load finished"); }) })

這樣配置后,當(dāng)百度的jquery沒(méi)有加載成功后,會(huì)加載本地js目錄下的jquery

  • 在使用requirejs時(shí),加載模塊時(shí)不用寫.js后綴的,當(dāng)然也是不能寫后綴
  • 上面例子中的callback函數(shù)中發(fā)現(xiàn)有$參數(shù),這個(gè)就是依賴的jquery模塊的輸出變量,如果你依賴多個(gè)模塊,可以依次寫入多個(gè)參數(shù)來(lái)使用:
  • require(["jquery","underscore"],function($, _){ $(function(){ _.each([1,2,3],alert); }) })

    如果某個(gè)模塊不輸出變量值,則沒(méi)有,所以盡量將輸出的模塊寫在前面,防止位置錯(cuò)亂引發(fā)誤解

    全局配置

    上面的例子中重復(fù)出現(xiàn)了require.config配置,如果每個(gè)頁(yè)面中都加入配置,必然顯得十分不雅,requirejs提供了一種叫"主數(shù)據(jù)"的功能,我們首先創(chuàng)建一個(gè)main.js:

    require.config({paths : { "jquery" : ["http://libs.baidu.com/jquery/2.0.3/jquery", "js/jquery"], "a" : "js/a" } })

    然后再頁(yè)面中使用下面的方式來(lái)使用requirejs:

    <script data-main="js/main" src="js/require.js"></script>

    解釋一下,加載 requirejs 腳本的 script 標(biāo)簽加入了data-main屬性,這個(gè)屬性指定的 js 將在加載完 require.js 后處理,我們把require.config的配置加入到data-main后,就可以使每一個(gè)頁(yè)面都使用這個(gè)配置,然后頁(yè)面中就可以直接使用require來(lái)加載所有的短模塊名

    data-main還有一個(gè)重要的功能,當(dāng)script標(biāo)簽指定data-main屬性時(shí),require會(huì)默認(rèn)的將data-main指定的js為根路徑,是什么意思呢?如上面的data-main="js/main"設(shè)定后,我們?cè)谑褂胷equire(['jquery'])后(不配置jquery的paths),require會(huì)自動(dòng)加載js/jquery.js這個(gè)文件,而不是jquery.js,相當(dāng)于默認(rèn)配置了:

    require.config({baseUrl : "js" })

    第三方模塊

    通過(guò)require加載的模塊一般都需要符合AMD規(guī)范即使用define來(lái)申明模塊,但是部分時(shí)候需要加載非AMD規(guī)范的js,這時(shí)候就需要用到另一個(gè)功能:shim,shim解釋起來(lái)也比較難理解,shim直接翻譯為"墊",其實(shí)也是有這層意思的,目前我主要用在兩個(gè)地方
    1. 非AMD模塊輸出,將非標(biāo)準(zhǔn)的AMD模塊"墊"成可用的模塊,例如:在老版本的jquery中,是沒(méi)有繼承AMD規(guī)范的,所以不能直接require["jquery"],這時(shí)候就需要shim,比如我要是用underscore類庫(kù),但是他并沒(méi)有實(shí)現(xiàn)AMD規(guī)范,那我們可以這樣配置

    require.config({shim: { "underscore" : { exports : "_"; } } })

    這樣配置后,我們就可以在其他模塊中引用underscore模塊:

    require(["underscore"], function(_){ _.each([1,2,3], alert); })
  • 插件形式的非AMD模塊,我們經(jīng)常會(huì)用到j(luò)query插件,而且這些插件基本都不符合AMD規(guī)范,比如jquery.form插件,這時(shí)候就需要將form插件"墊"到j(luò)query中:
  • require.config({shim: { "underscore" : { exports : "_"; }, "jquery.form" : { deps : ["jquery"] } } })

    也可以簡(jiǎn)寫為:

    require.config({shim: { "underscore" : { exports : "_"; }, "jquery.form" : ["jquery"] } })

    這樣配置之后我們就可以使用加載插件后的jquery了

    require.config(["jquery", "jquery.form"], function($){ $(function(){ $("#form").ajaxSubmit({...}); }) })

    ?

    文章來(lái)源:https://github.com/liuxey/blog/issues/2

    ?

    ?

    ?

    轉(zhuǎn)載于:https://www.cnblogs.com/Renyi-Fan/p/11590784.html

    總結(jié)

    以上是生活随笔為你收集整理的菜鸟requireJS教程---2、基本知识的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。