如何將 jQuery 從你的 Bootstrap 項(xiàng)目中移除(取而代之使用Vue.js)
Bootstrap是網(wǎng)上最流行的前端開(kāi)發(fā)框架. 除了用它,我不知道還有其他更快的方法去構(gòu)建一個(gè)響應(yīng)式的網(wǎng)站。
但是自從我向網(wǎng)頁(yè)添加動(dòng)態(tài)功能的工具變成vue.js后。適應(yīng)bootstrap變得困難起來(lái)。因?yàn)檫@帶來(lái)了一些技術(shù)包袱。沒(méi)錯(cuò)。我說(shuō)的就是jquery。
這并不是在抨擊jquery,我只是意識(shí)到,當(dāng)你已經(jīng)在項(xiàng)目里使用一些像Vue的框架后,再引入jQuery就會(huì)出現(xiàn)一些顯著的缺點(diǎn):
增加開(kāi)銷。jQuery將會(huì)使你的網(wǎng)頁(yè)增加30KB。
在使用諸如webpack一類的打包工具時(shí),jquery也會(huì)很難與之進(jìn)行配置。
當(dāng)你使用Vue負(fù)責(zé)DOM操作時(shí),你不會(huì)愿意Jquery再來(lái)將DOM搞的一團(tuán)糟。
徹底移除jQuery和Bootstrap的javascript插件
這里有一個(gè)很棒的項(xiàng)目 vue-strap ,它使用Vue.js 內(nèi)置的插件來(lái)替換Bootstrap中的Javascript插件。因此你可以使用你項(xiàng)目中原有的Bootstrap插件,比如 modals, carousel, tabs, etc. 他們都是基于 Vue 提供支持.
但是如果你只是用一小部分的Bootstrap插件的話, 我覺(jué)得自己定制Vue.js的插件也很容易,那樣的話你也不需要將整個(gè)vue-strap都引用進(jìn)來(lái)(譯者注:我就是只用了Vue.js和幾個(gè)其他需要的plugin :)
下面讓我展示一下怎么使用vue,從零開(kāi)始設(shè)置一些常用的Bootstrap 插件
自己動(dòng)手做由vue.js驅(qū)動(dòng)的Bootstrap小部件
選項(xiàng)卡
我們將從選項(xiàng)卡開(kāi)始。每一個(gè)選項(xiàng)卡都附帶著他的面板. 選項(xiàng)卡的顯示/隱藏是通過(guò)添加/移除選項(xiàng)卡與面板的class屬性中的active來(lái)實(shí)現(xiàn)的,而這就是Vue將要處理的工作。
<div id="tabs"> <ul class="nav nav-tabs"> <li><a>Tab 1</a></li> <li><a>Tab 2</a></li> </ul> <div class="tab-content"> <div class="tab-pane">Pane 1</div> <div class="tab-pane">Pane 2</div> </div> </div>
我們用一個(gè)變量tab來(lái)跟蹤當(dāng)前被選中的選項(xiàng)卡,并用這個(gè)變量來(lái)添加/移除選項(xiàng)卡與其對(duì)應(yīng)面板的Class屬性中的active:
<div id="tabs"> <ul class="nav nav-tabs"> <li v-bind:class="{ active: tab === 1}"><a>Tab 1</a></li> <li v-bind:class="{ active: tab === 2}"><a>Tab 2</a></li> </ul> <div class="tab-content"> <div class="tab-pane" v-bind:class="{ active: tab === 1}"> Pane 1</div> <div class="tab-pane" v-bind:class="{ active: tab === 2}"> Pane 2</div> </div> </div>
我們還需要在所有的選項(xiàng)卡上監(jiān)聽(tīng)點(diǎn)擊事件,用來(lái)更新我們的tab變量
<div id="tabs"> <ul class="nav nav-tabs"> <li v-bind:class="{ active: tab === 1}" v-on:click="tab = 1"> <a>Tab 1</a> </li> <li v-bind:class="{ active: tab === 2}" v-on:click="tab = 2"> <a>Tab 2</a> </li> </ul> <div class="tab-content"> <div class="tab-pane" v-bind:class="{ active: tab === 1}"> Pane 1</div> <div class="tab-pane" v-bind:class="{ active: tab === 2}"> Pane 2</div> </div> </div>
最后,js代碼:
new Vue({ el: '#tabs', data: { // Tab 1 is selected by default tab: 1 } });
這里還有一些我們可以進(jìn)行的改進(jìn)與優(yōu)化,但為了使本文簡(jiǎn)介的緣故就不展開(kāi)了:
將JavaScript代表包裝成一個(gè)Vue組件,以便我們能在整個(gè)網(wǎng)站重用這個(gè)選項(xiàng)卡代碼。
作為一個(gè)真正緊湊的模板。將選項(xiàng)卡和對(duì)應(yīng)的面板內(nèi)容放入一個(gè)數(shù)組屬性中,然后用 v-for來(lái)打印出選項(xiàng)卡與面板的列表來(lái)。
模態(tài)框
模態(tài)對(duì)話框是我最喜歡的Bootstrap 插件之一。與選項(xiàng)卡類似,我們通過(guò)添加/移除一個(gè)in的類來(lái)控制模態(tài)框的顯示/隱藏。而這些通過(guò)一個(gè)打開(kāi)和關(guān)閉按鈕來(lái)觸發(fā),
<div id="app" v-bind:class=" { 'modal-open': show }"> <button class="btn btn-primary" v-on:click="toggle"> Open </button> <div class="modal" tabindex="-1" v-bind:class="{ in: show }" v-bind:style="modalStyle"> <div class="modal-dialog"> <div class="modal-content"> <div class="modal-body"> <p>Vue-powered modal!</p> </div> <div class="modal-footer"> <button class="btn" v-on:click="toggle">Close</button> </div> </div> </div> </div> </div>
對(duì)于一個(gè)Bootstrap 的模態(tài)框,我們需要在對(duì)話框上有一個(gè)動(dòng)態(tài)的內(nèi)聯(lián)樣式。 我們通過(guò) v-bind:style 指令來(lái)實(shí)現(xiàn),這個(gè)指令通過(guò)從一個(gè)計(jì)算屬性中接收一個(gè)“對(duì)象樣式”進(jìn)行的。每次計(jì)算屬性所依賴的變量變化時(shí),他自己都會(huì)重新計(jì)算一遍:
new Vue({ el: '#app', data: { show: false }, methods: { toggle() { this.show = !this.show; } }, computed: { modalStyle() { return this.show ? { 'padding-left': '0px;', display: 'block' } : {}; } } });
你也可以通過(guò)使用Vue的過(guò)渡動(dòng)畫(huà)在模態(tài)框進(jìn)入和離開(kāi)DOM時(shí)漸變,來(lái)增強(qiáng)你的模態(tài)框。
讓jQuery退休吧,考慮下在下一個(gè)Bootstrap 項(xiàng)目中使用Vue.js
不是說(shuō)你可以在Bootstrap中用vue.js代替jquery,而是說(shuō)你的確應(yīng)該這么做。因?yàn)椴还苣闶鞘褂胿ue-strap或自己封裝插件,你都可以感到Vue的如下誘人的優(yōu)勢(shì):
與jQuery對(duì)比,vue的DOM操作系統(tǒng)允許較高的UI性能和響應(yīng)性。
Vue是被設(shè)計(jì)用來(lái)建立小型,孤立的UI塊的。所以vue編寫(xiě)的小部件將比jquery的更容易擴(kuò)展,可維護(hù)性更好。
Bootstrap的小部件有著臭名昭著的混亂模板, 所以vue可以使用他靈活的模板選項(xiàng)來(lái)緩解這個(gè)問(wèn)題,如jsx,單頁(yè)應(yīng)用組件,渲染功能,類與樣式綁定,等等。
請(qǐng)記住,Vue不支持IE8,但是你可能會(huì)考慮在下一個(gè)bootstrap項(xiàng)目中使用他。
以上所述是本文的全部?jī)?nèi)容,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)歡迎給我留言,小編會(huì)及時(shí)回復(fù)大家的,在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
jquery中頁(yè)面Ajax方法$.load的功能使用介紹
load可以做到加載一個(gè)頁(yè)面的時(shí)候,如果發(fā)生錯(cuò)誤,根據(jù)statusText給出的狀態(tài),顯示對(duì)應(yīng)的提示,這對(duì)用戶來(lái)說(shuō)非常重要2014-10-10Jquery AJAX POST與GET之間的區(qū)別詳細(xì)介紹
這篇文章主要介紹了Jquery AJAX POST與GET之間的區(qū)別詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下2016-10-10jQuery實(shí)現(xiàn)web頁(yè)面櫻花墜落的特效
這篇文章主要介紹了jQuery實(shí)現(xiàn)web頁(yè)面櫻花墜落的特效,效果非常棒,需要的朋友可以參考下2017-06-06jquery實(shí)現(xiàn)input框獲取焦點(diǎn)的簡(jiǎn)單實(shí)例
下面小編就為大家?guī)?lái)一篇jquery實(shí)現(xiàn)input框獲取焦點(diǎn)的簡(jiǎn)單實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-01-01jquery無(wú)法為動(dòng)態(tài)生成的元素添加點(diǎn)擊事件的解決方法(推薦)
下面小編就為大家?guī)?lái)一篇jquery無(wú)法為動(dòng)態(tài)生成的元素添加點(diǎn)擊事件的解決方法(推薦)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧,祝大家游戲愉快哦2016-12-12使用異步controller與jQuery實(shí)現(xiàn)卷簾式分頁(yè)
這篇文章主要介紹了使用異步controller與jQuery實(shí)現(xiàn)卷簾式分頁(yè),使用異步controller與jQuery按需加載內(nèi)容,當(dāng)用戶開(kāi)始通過(guò)網(wǎng)站的內(nèi)容滾動(dòng)時(shí)進(jìn)一步加載內(nèi)容。,需要的朋友可以參考下2019-06-06