中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

jquery引入外部CDN 加載失敗則引入本地jq庫

發布時間:2020-09-14 19:43:38 來源:腳本之家 閱讀:127 作者:mdxy-dxy 欄目:web開發

由于第三方cdn庫的盛行,很多朋友會選擇使用第三方的類庫,從學習上來說不建議大家都使用類庫,這樣我們失去了很多學習的機會,但使用上來說解決了很多代碼兼容問題,這里都不多說了。

使用CDN加載jQuery類庫一是可以省一點帶寬,二是可以給用戶帶來更快的頁面加載體驗。

因為個人網站規模與cdn的帶寬問題,現在cdn費用雖然下來了,但也有不給力的時候,很多朋友都會選擇使用第三方的jquery庫,個人推薦幾個國內的 百度、新浪、bootcdn

下面的兩段代碼的作用 如果cdn的jquery沒有加載進來,我們可以使用本地的類庫。

jquery下載地址

第一種:推薦用法

<script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
<script type="text/javascript">
 if (typeof jQuery == 'undefined') {
 document.write(unescape("%3Cscript src='/skin/mobile/js/jquery.min.js' type='text/javascript'%3E%3C/script%3E"));
 }
</script>

上面,我們引用了百度 CDN的jQuery庫,接著我們在腳本代碼后添加了一個if語句來判斷jQuery庫是否加載成功,如果沒有加載成功我們動態加載本地jQuery庫。

其中,我們在document.write方法中直接使用了URL編碼,把“<”編碼為“%3C”,接著我們再使用unescape()方法把字符串還原過來。

我們通過unescape()方法把字符串轉換回來,我們可以看到輸出是一個正常的腳本引用代碼。

現在,我們有一個疑問就是“為什么不使用常規字符,而是要使用字符編碼呢?”,其實這是有原因的,這意味著我們代碼將可以在XML、XHTML或HTML中正常運行,而無需把代碼包含在CDATA中(具體請參考這里)。

第二種:

<script src="http://lib.sinaapp.com/js/jquery11/1.8/jquery.min.js"></script>
<script>window.jQuery || document.write(unescape("%3Cscript src='/skin/mobile/js/jquery.min.js' type='text/javascript'%3E%3C/script%3E"))</script>

上面這種跟第一種原理是一樣的,就是通過 || 運算符

表達式a || 表達式b : 計算表達式a(也可以是函數)的運算結果,

如果為 Fasle, 執行表達式b(或函數),并返回b的結果;

如果為 True,返回a的結果;

意思也是如果window.jQuery為false則加載本地的jquery庫。

requireJs 引用cdn失敗后加載本地js

問題:頁面中引用js和css過多會導致頁面加載變慢

                   引用cdn中的js和css會比直接在本地上傳時間短

解決辦法:我本地項目用到requireJs加載頁面中的js和css,變為cdn加載時需要改動如下

1.jquery: ["https://cdn.bootcssddd.com/jquery/1.11.1/jquery.min","static/lib/jquery/jquery-1.9.1.min"],
2.增加build.js 代碼如下

({
  baseUrl: "/js",
  paths: {
    "jquery": "empty:"
    
  },
  dir: "/js-build",
  optimize: "uglify",
  optimizeCss: "standard.keepLines",
  mainConfigFile: "config.js",//config.js為1中引用的文件
  removeCombined: true,
})

這篇文章就介紹到這了,后續億速云小編會為大家分享更多的資料。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

长武县| 南京市| 高邑县| 汕头市| 徐闻县| 雷州市| 泾阳县| 遂平县| 怀仁县| 武定县| 灵丘县| 遵义市| 屏边| 松阳县| 和政县| 惠安县| 昭通市| 抚宁县| 漳浦县| 张家界市| 庆城县| 布尔津县| 江西省| 南漳县| 双流县| 甘孜县| 绵竹市| 武陟县| 洛宁县| 建昌县| 托里县| 镇康县| 广州市| 库伦旗| 彝良县| 巴南区| 高安市| 定结县| 衡水市| 恩平市| 丹巴县|