本篇文章給大家分享的是有關(guān)jQuery的實(shí)施方案是怎樣的,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說(shuō),跟著小編一起來(lái)看看吧。
創(chuàng)新互聯(lián)公司是一家專業(yè)提供額敏企業(yè)網(wǎng)站建設(shè),專注與網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站制作、H5開發(fā)、小程序制作等業(yè)務(wù)。10年已為額敏眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專業(yè)網(wǎng)站設(shè)計(jì)公司優(yōu)惠進(jìn)行中。
jQuery實(shí)施方案.
每個(gè)公司的情況都不同.比如我們公司的頁(yè)面文件都為用戶控件, 物理路徑和虛擬路徑?jīng)]有絕對(duì)的關(guān)系, 所以無(wú)法使用相對(duì)路徑(否則生產(chǎn)環(huán)境中會(huì)找不到文件). 項(xiàng)目繁多, 同一個(gè)虛擬目錄的不同文件夾對(duì)應(yīng)不同項(xiàng)目工程等等.
此方案并不是通用的, 但是有些方法可以借鑒, 同時(shí)也是希望能和大家一起討論幫忙指正.
一.類庫(kù)文件管理方案
存放根路徑: src\Assembly\resource.eLong.Web.Files\Resource\JSLib\jquery\
引用根路徑: http://resource.elong.com/JSLib/jquery/
壓縮版本引用路徑: http://resource.elong.com/JSLib/jquery/jquery-min-lastest.js
根路徑文件列表:
在每一個(gè)Web工程項(xiàng)目下面建立js文件夾, 放置 jquery-vsdoc-lastest.js 文件:
說(shuō)明:
首先將所有版本的jQuery類庫(kù)放到靜態(tài)服務(wù)器上, 并且按照文件夾存放類庫(kù)文件. 但是會(huì)選出來(lái)一個(gè)***版本作為引用并且放置在根目錄.
根目錄下面包含如下文件:
名稱 | 內(nèi)容 | 說(shuō)明 |
文件夾1.3.2 | 按照版本號(hào)組織的jQuery類庫(kù). | 對(duì)于1.3.2即以后的每個(gè)jquery版本, 會(huì)按照文件夾存放類庫(kù)文件. 但是會(huì)用***的穩(wěn)定版本覆蓋各lastest名稱的js文件. |
文件夾plugin | 存放插件的文件夾 | 將各種插件以文件夾的形式存放到此路徑下 |
jquery.extend-lastest.js | elong自己擴(kuò)展的jQuery方法 | 未來(lái)我們將打造自己的javascript類庫(kù).其中有一些核心的類庫(kù)放在此文件中. 相當(dāng)于我們自己的工具類庫(kù). 通過擴(kuò)展jQuery實(shí)現(xiàn). 主要分為工具函數(shù)和包裝集函數(shù)兩類. |
jquery-lastest.js | jQuery未壓縮類庫(kù)***版本 | ***的穩(wěn)定版本的jQuery原始類庫(kù). |
jquery-min-lastest.js | jQuery壓縮類庫(kù)***版本 | ***的穩(wěn)定版本的jQuery壓縮類庫(kù). |
jquery-vsdoc-lastest.js | jQuery智能提示類庫(kù)***版本 | ***的穩(wěn)定版本的jQuery智能提示類庫(kù). |
為了在開發(fā)時(shí)實(shí)現(xiàn)智能感知, 還需要將智能感知版本放置在每個(gè)web項(xiàng)目的js文件夾中. 因?yàn)閃eb項(xiàng)目眾多所以請(qǐng)以后***個(gè)使用者建立此文件夾并放入文件.
二. 類庫(kù)引用方案
在所有的頁(yè)面head中, ***引用jQuery的類庫(kù), 使用絕對(duì)路徑:
http://resource.elong.com/JSLib/jquery/jquery-min-lastest.js
然后通過if(fasle)引入智能提示版本的腳本塊. 路徑使用"~"從根目錄開始查找. 我在各個(gè)頻道的項(xiàng)目源代碼中統(tǒng)一建立js文件夾并且放置jquery-vsdoc-lastest.js***的智能感知版本類庫(kù). 注意此文件不需要打包上傳, 僅用于開發(fā)時(shí)的智能提示.
這樣可以確保編譯后的頁(yè)面只引入了壓縮版本的jQuery類庫(kù).
示例代碼:
jQuery 引用方案 <% if (false){%> <% }%>
說(shuō)明:
在我們的網(wǎng)站中, 靜態(tài)文件存儲(chǔ)在另外一個(gè)二級(jí)域名resource.elong.com下, 使用了cdn. 為了保證測(cè)試環(huán)境和正式環(huán)境一致只能使用絕對(duì)路徑引用jQuery庫(kù). 但是使用絕對(duì)路徑引用jQuery智能提示版本后不會(huì)出現(xiàn)腳本智能提示.所以我們通過此特性直接引用絕對(duì)路徑的壓縮版本jQuery類庫(kù), 從而巧妙的解決了1.3.2壓縮版本引入后智能提示系統(tǒng)出錯(cuò)的問題.
雖然動(dòng)態(tài)頁(yè)面可以通過 if(false) 取消引入智能提示版本類庫(kù), 但是在HTML頁(yè)面上就無(wú)法使用服務(wù)器語(yǔ)句塊.所以對(duì)于HTML頁(yè)面需要在開發(fā)完畢程序發(fā)布前手工刪除智能提示版本的引用.
三. 開發(fā)使用方案
jQuery是腳本庫(kù)而不是腳本框架, 無(wú)法限制使用者如何使用, 所以很容易讓頁(yè)面上的腳本變得混亂.
在沒有找到何時(shí)的腳本管理框架前, 使用如下方式在頁(yè)面上使用腳本:
1. 在頁(yè)面底部添加 <% if (false){%> <% }%>