• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當前位置: 首頁 - 科技 - 知識百科 - 正文

    全面介紹vue 全家桶和項目實例

    來源:懂視網(wǎng) 責編:小采 時間:2020-11-27 22:22:35
    文檔

    全面介紹vue 全家桶和項目實例

    全面介紹vue 全家桶和項目實例:簡介 簡單卻不失優(yōu)雅,小巧而不乏大匠。 2016年最火的前端框架當屬Vue.js了,很多使用過vue的程序員這樣評價它,vue.js兼具angular.js和react.js的優(yōu)點,并剔除了它們的缺點。授予了這么高的評價的vue.js,也是開源世界華人的驕傲,因為它的作者
    推薦度:
    導讀全面介紹vue 全家桶和項目實例:簡介 簡單卻不失優(yōu)雅,小巧而不乏大匠。 2016年最火的前端框架當屬Vue.js了,很多使用過vue的程序員這樣評價它,vue.js兼具angular.js和react.js的優(yōu)點,并剔除了它們的缺點。授予了這么高的評價的vue.js,也是開源世界華人的驕傲,因為它的作者

    簡介

    “簡單卻不失優(yōu)雅,小巧而不乏大匠”。

    2016年最火的前端框架當屬Vue.js了,很多使用過vue的程序員這樣評價它,“vue.js兼具angular.js和react.js的優(yōu)點,并剔除了它們的缺點”。授予了這么高的評價的vue.js,也是開源世界華人的驕傲,因為它的作者是位中國人–尤雨溪(Evan You)。

    Vue.js 是一個JavaScriptMVVM庫,是一套構建用戶界面的漸進式框架。它是以數(shù)據(jù)驅(qū)動和組件化的思想構建的,采用自底向上增量開發(fā)的設計。相比于Angular.js,Vue.js提供了更加簡潔、更易于理解的API,使得我們能夠快速地上手并使用Vue.js;同時比起 React + Redux 相對復雜的架構,Vue.js 更加輕量級也更加容易上手,是初創(chuàng)項目的首選前端框架。Vue 的核心庫只關注視圖層,它不僅易于上手,還便于與第三方庫或既有項目整合。并且作者是華人的關系,Vue擁有著對華人開發(fā)者最友好的api文檔和官方教程。

    調(diào)試插件

    在vue調(diào)試方面,可以選擇安裝chrome插件vue Devtools。打開vue項目,在console控制臺選擇vue面板。在Devtools工具中,可以選擇組件,查看對應組件內(nèi)的數(shù)據(jù)信息。也可以選擇Vuex選項,查看該項目內(nèi)Vuex的狀態(tài)變量信息。

     

    UI組件庫

    在vue組件庫方面,個人不推薦使用UI組件庫,畢竟自己造輪子的過程還是很有成就感的。當然,如果更重視開發(fā)效率,并且選擇了vue2.0作為前端框架,那么餓了么推出的Element組件就是一個很不錯的選擇。其github項目(https://github.com/ElemeFE/element)更新比較頻繁,雖然項目會有些不穩(wěn)定,但是目前為止element就是最好的支持vue2.0的UI組件。就像它的口號一樣,“快速成型,就為讓你少加班”。

    vue、React、Angular1對比

    性能對比

    在Angular1中,在scope作用域中每一次數(shù)據(jù)變化,會觸發(fā)watcher的重新計算,angular對常用的dom事件,xhr事件等做了封裝, 在里面觸發(fā)進入angular的digest流程。在digest流程里面,會從rootscope開始遍歷, 檢查所有的watcher。并且,如果一些 watcher 觸發(fā)另一個更新,臟檢查循環(huán)(digest cycle)可能要運行多次。Vue則沒有這個問題,因為它使用基于依賴追蹤的觀察系統(tǒng)并且異步隊列更新,數(shù)據(jù)的變化都是獨立處罰的,除非數(shù)據(jù)之間有明確的依賴關系。
    vue官方宣稱vue的渲染性能優(yōu)于react。為了有理有據(jù)讓人信服,vue開發(fā)團隊建立了一個簡單的對比性能的項目(https://github.com/chrisvfritz/vue-render-performance-comparisons),它負責渲染10000個列表項100次。Vue官方將每一個參照項目都分別運行 20 次并取最好的結(jié)果結(jié)果如下圖:

     

    由此可見,Vue的性能是遠好于Angular1,并且稍微優(yōu)于React的。

    社區(qū)拓展對比

    Angular1的背后是Google,所以社區(qū)基礎是不需要擔心的,從Tutorial到StackOverflow的問題數(shù)量都可以反映出生態(tài)系統(tǒng)很完整。Angular1之后的2.0版本幾乎是一個推翻重做的框架,對于使用了1.X版本的項目,想要平滑的升級過渡到2.0版本應該是非常困難的。現(xiàn)在Angular2的線上應用數(shù)量還不算太多,主流編碼還是以1.X版本居多。這個版本化巨大的差異也間接影響到了開發(fā)者對于angular的信心。

    Vue和React都有強大的社區(qū)支持。React有狀態(tài)管理庫Flux、ReduxVue,相應的,Vue有vuex。Vue 和 React 都提供了強大的路由庫來應對大型應用。然而Vue的路由庫和狀態(tài)管理庫都是由官方維護支持的。React 則是選擇把這些問題交給社區(qū)維護,因此創(chuàng)建了一個更分散的生態(tài)系統(tǒng)。但相對的,React 的生態(tài)系統(tǒng)相比 Vue 更加繁榮。此外,Vue 提供了Vue-cli 腳手架,包括了Webpack,Browserify,甚至路由庫,能讓你非常容易地構建項目。

    學習陡峭度對比

    在指令與組件方面,Vue中將指令和組件分得更清晰。指令只封裝 DOM 操作,而組件代表一個自給自足的獨立單元,有自己的視圖和數(shù)據(jù)邏輯。在 Angular1 中兩者有不少相混的地方。在API與框架設計方面,angular1都比vue要復雜的多。就個人感覺而言,angular1和React的學習曲線會相對陡峭一些,而vue的編碼方式會更趨近于前端開發(fā)者的編程習慣。
    因為vue的作者是中國人,vue的官方網(wǎng)站、教程和api肯定是最完善、最易懂的。此外,每次大版本的發(fā)布,都會伴隨著詳盡的遷移說明文檔,包含了很多詳盡的闡述以及許多遷移的例子,甚至還有遷移工具。Angular的開發(fā)團隊你們就不覺得臉紅么…

    Vue的使用非常的簡單,創(chuàng)建一個本地的 .html 文件,然后通過如下方式引入 Vue:

     

    這樣就生成了vue的hello world應用。

    渲染能力對比

    ReactNative能使你用相同的組件模型編寫有本地渲染能力的 APP(iOS 和 Android)。能同時跨多平臺開發(fā),對開發(fā)者是非常棒的。為了彌補這方面的不足,在2016年9月舉辦的JSConf2016期間,vue.js的作者尤雨溪宣布加盟Weex團隊擔任技術顧問,雙方將進行更緊密的合作,共建開發(fā)生態(tài)圈。Weex 是阿里的跨平臺用戶界面開發(fā)框架,Weex 的 JavaScript 框架運行時用的就是 Vue。在此之后,在 Weex 的幫助下,使用 Vue 語法開發(fā)的組件不僅僅可以運行在瀏覽器端,還能被用于開發(fā) iOS 和 Android 上的原生應用。

    Vue.js 的作者尤雨溪表示:“Weex選擇Vue作為其JavaScript運行時框架是讓我非常高興的一件事。Vue的組件開發(fā)模式已經(jīng)被web開發(fā)者社區(qū)廣泛 認可,而把Vue的開發(fā)體驗拓展到原生平臺則是我一直想做但沒有余力去做的事情。一想到Weex將能讓開發(fā)者們用Vue的語法去寫跨 Web/Android/iOS三端的通用組件,就讓我很興奮。”

    vue的缺點

    Vue就這么好,難道沒有缺點嗎?當然有,vue雖然在16年非常火爆,但是相比于angular和react,不論是成熟度還是社區(qū)活躍度都還不是對手。此外,Vue明確聲明了自己放棄了對IE8的支持。再看看現(xiàn)在的招聘網(wǎng)站上,有多少寫了需要有angular經(jīng)驗,而又有多少寫了需要vue經(jīng)驗,就可見vue的影響力相比于angular和react還差的很遠。

    vue全家桶及項目架構

    Vue有著名的全家桶系列,包含了vue-router(http://router.vuejs.org),vuex(http://vuex.vuejs.org), vue-resource(https://github.com/pagekit/vue-resource)。再加上構建工具vue-cli,就是一個完整的vue項目的核心構成。

    vue-router路由

    推薦使用npm工具來安裝vue-router

    npm install vue-router 

    通過import導入并定義Vue模塊、vue-router模塊和需要使用的組件,在本例中,分別是Goods、Ratings和Seller組件。最后,如果在一個模塊化工程中使用它,必須要通過 Vue.use() 明確地安裝路由功能。

    import Vue from'vue' 
    importRouter from'vue-router'
    
    import Goods from ‘@/components/goods/goods'; 
    import Ratings from ‘@/components/ratings/ratings'; 
    import Seller from ‘@/components/seller/seller';
    
    Vue.use(Router); // 需要import Vue和Router,不然會報錯undefined 
    

    通過const router= new VueRouter()來定義一個路由,并傳入對應的配置,包括路徑path和組件components。

     

    最后,在使用newVue來創(chuàng)建和掛載vue根實例的時候,記得要通過 router配置參數(shù)注入路由,即在router中export出來的路由對象,從而讓整個應用都有路由功能。

    vuex狀態(tài)管理

    Vuex 是一個專為 Vue.js 應用程序開發(fā)的狀態(tài)管理模式。它采用集中式存儲管理應用的所有組件的狀態(tài),并以相應的規(guī)則保證狀態(tài)以一種可預測的方式發(fā)生變化。如前面所提到的,Vuex 已經(jīng)集成到 Vue 的官方調(diào)試工具vue Devtools,可以輕松的查看項目中的Vuex狀態(tài)變化情況。

    假設有這樣一個場景:我們的項目規(guī)模比較大,有多個父組件,每個父組件同時又包含多個子組件。如何保持對所有時間的追蹤將變得很困難。到底哪個事件是哪個組件派發(fā)的,哪個組件該監(jiān)聽哪個事件?父組件將變得和子組件耦合越來越嚴重,因為它需要明確的派發(fā)和監(jiān)聽子組件的某些事件。項目邏輯分散在各個組件當中,很容易導致邏輯的混亂,不利于我們項目的維護。

    這就是 Vuex 用來解決的問題。 Vuex 的四個核心概念分別是:

    The state tree:Vuex 使用單一狀態(tài)樹,用一個對象就包含了全部的應用層級狀態(tài)。至此它便作為一個『唯一數(shù)據(jù)源(SSOT)』而存在。這也意味著,每個應用將僅僅包含一個 store 實例。單狀態(tài)樹讓我們能夠直接地定位任一特定的狀態(tài)片段,在調(diào)試的過程中也能輕易地取得整個當前應用狀態(tài)的快照。

    Getters:用來從 store 獲取 Vue 組件數(shù)據(jù)。

    Mutators:事件處理器用來驅(qū)動狀態(tài)的變化。

    Actions:可以給組件使用的函數(shù),以此用來驅(qū)動事件處理器 mutations

    Vuex和簡單的全局對象是不同的,當Vuex從store中讀取狀態(tài)值的時候,若狀態(tài)發(fā)生了變化,那么相應的組件也會高效的更新。并且,改變store中狀態(tài)的唯一途徑就是提交commit mutations。這樣便于我們跟蹤每一次狀態(tài)的變化。只要發(fā)生了狀態(tài)的變化,一定伴隨著mutation的提交。

    讓我們來看一個最簡單的vuex例子:

     

    安裝 Vuex 之后,讓我們來創(chuàng)建一個 store。創(chuàng)建過程直截了當——僅需要提供一個初始 state 對象和一些 mutations:

     

    現(xiàn)在,你可以通過 store.state 來獲取狀態(tài)對象,以及通過 store.commit 方法觸發(fā)狀態(tài)變更:

    vue-resource介紹

    Vue-resource有體積小,支持IE9以上的瀏覽器,支持promise特性的特點。同樣推薦使用npm來安裝Vue-resource。

    $ npm install vue-resource 

    在安裝并引入vue-resource后,可以基于全局的Vue對象使用http,也可以基于某個Vue實例使用http。

     

    在發(fā)送請求后,使用then方法來處理響應結(jié)果,then方法有兩個參數(shù),第一個參數(shù)是響應成功時的回調(diào)函數(shù),第二個參數(shù)是響應失敗時的回調(diào)函數(shù)。

    vue-resource的請求API是按照REST風格設計的,它提供了7種請求API:

    1. get(url,[options])
    2. head(url,[options])
    3. delete(url,[options])
    4. jsonp(url,[options]) 
    5. post(url,[body], [options])
    6. put(url, [body],[options]) 
    7. patch(url,[body], [options])

    vue工程目錄結(jié)構

    下圖是一個簡單的vue項目的大概結(jié)構,下面簡要介紹一下每個文件夾中一般都會存放哪些內(nèi)容。

     

    components/文件夾用來存放Vue 組件。個人建議,把每一個組件中使用到的image圖片放置到對應的組件子文件目錄下,便于統(tǒng)一的管理

    Node_modules/npm安裝的該項目的依賴庫

    vuex/文件夾存放的是和 Vuex store 相關的東西(state對象,actions,mutations)

    router/文件夾存放的是跟vue-router相關的路由配置項

    build/文件是 webpack 的打包編譯配置文件

    static/文件夾存放一些靜態(tài)的、較少變動的image或者css文件

    config/文件夾存放的是一些配置項,比如服務器訪問的端口配置等

    dist/該文件夾一開始是不存在,在我們的項目經(jīng)過 build 之后才會產(chǎn)出

    App.vue根組件,所有的子組件都將在這里被引用

    index.html整個項目的入口文件,將會引用我們的根組件 App.vue

    main.js入口文件的 js 邏輯,在webpack 打包之后將被注入到 index.html 中

    vue中l(wèi)ess的應用

     

    在vue項目中一樣可以使用less預編譯,只是需要使用npm安裝less-loader插件。安裝完成后,在vue中的css模塊進行簡單的配置,這樣就可以直接使用less來編寫樣式表了。在打包編譯的時候,會自動生成對應的css樣式。

    vue合實例講解Vue核心功能

    Vue的功能有很多,很難一一進行詳細的解釋。下面根據(jù)在工作中的項目實例,結(jié)合代碼解釋一下vue的幾大核心功能。

    計算屬性

    假設有如下的購物車結(jié)算場景,用戶選中商品的總金額是根據(jù)商品數(shù)量、選中商品種類數(shù) 和商品單價來變化的。然而,數(shù)量、選中種類數(shù)量和單價這幾個對象都是根據(jù)用戶選擇而動態(tài)變化的,如果在前端模版中為了計算最終商品總額,放入這幾個動態(tài)變化的變量(商品數(shù)量、商品單價、選中商品種類),會讓這個邏輯變得復雜難以維護。在這種情況下,模版便不再簡潔清晰。Vue給出了此種場景的解決方案,在任何復雜的邏輯,vue都推薦使用計算屬性。

     

     

    如上圖所示,在html中,我們只需要使用{{totalPrice}}這個計算屬性就可以來表示最終的商品總額。我們不需要關注這個變量的數(shù)值變化,totalPrice這個變量的邏輯寫在對應的computed計算屬性中。

    也許會有疑問,這個計算屬性和定義一個method方法不是差不多么?這兩者最大的區(qū)別是計算屬性是基于它的依賴進行緩存的。計算屬性只有在它的相關依賴發(fā)生變化時才會重新計算求值。在本例中,只有當選擇商品的價格price和數(shù)量count發(fā)生變化時,這個計算屬性totalPrice才會重新計算新的值。這就意味著,只要totalPrice這個值沒有發(fā)生變化,多次訪問該計算屬性會立即返回之前的計算結(jié)果,而不必再次執(zhí)行計算。

    模版語法

    Vue.js 使用了基于 HTML 的模版語法,允許開發(fā)者聲明式地將 DOM 綁定至底層 Vue 實例的數(shù)據(jù)。所有 Vue.js 的模板都是合法的 HTML ,所以能被遵循規(guī)范的瀏覽器和 HTML 解析器解析。Vue的模版語法包括了使用雙大括號插入文本、使用v-html插入純HTML內(nèi)容、使用v-bind插入對象、類似angular的v-if、v-show、v-for指令、以及過濾器等等。

    組件化

    組件(Component)是 Vue.js 最強大的功能。組件可以封裝可重用的代碼,通過傳入對象的不同,實現(xiàn)組件的復用。
    舉一個簡單的組建例子,我們首先編寫一個star組件,它就是一個普通的star.vue文件。它的作用就是簡單實現(xiàn)了一個五角星。

    如何在其他的vue文件中使用這個star組件呢?如下圖所示,首先通過import引入star組件對象,并在想使用star組件的vue文件中聲明注冊star組件。現(xiàn)在就可以愉快的通過標簽來在該vue文件中任意地方使用star組件了。在你想展示一個五角星的地方,使用一個star標簽,就可以輕松完成這個功能。

    組件實例的作用域是孤立的。這意味著不能在子組件的模板內(nèi)直接引用父組件的數(shù)據(jù)。要讓子組件使用父組件的數(shù)據(jù),我們需要通過子組件的props選項。如本例所示,子組件star要顯式的使用props選項聲明它期待獲得的數(shù)據(jù)。在這里就是指的“size”和“score”兩個變量。我們可以通過父級給子組件star傳入大小和數(shù)值這兩個對象,來實現(xiàn)對子組件的定制化。

     

    過渡效果

    Vue 在插入、更新或者移除 DOM 時,提供多種不同方式的應用過渡效果,可以用簡單的幾行代碼實現(xiàn)酷炫的過渡效果。Vue 提供了 transition 的封裝組件,在使用v-if、v-show等方法使得transition內(nèi)部dom元素發(fā)生變化時,可以給任何元素和組件添加 entering/leaving 過渡。

    當v-show中內(nèi)容發(fā)生變化時,transition組件中的元素會發(fā)生狀態(tài)的改變,在應用了transition封裝后,Vue會自動識別目標元素是否應用了CSS過渡效果動畫,如果有,會在合適的時機添加 entering/leaving的class來實現(xiàn)該過渡效果。

    下圖所示是一個簡單的過渡效果的例子,需要將想實現(xiàn)過渡效果的元素放在transition標簽中包裹,通過name=“slide-fade”來聲明過渡效果名稱,并在對應的vue文件中添加過渡效果的css樣式,這樣就可以簡單的完成該元素的過渡效果。


    總結(jié)

    根據(jù)不完全統(tǒng)計,包括餓了么、稀土掘金、蘇寧易購、美團、天貓、荔枝FM、房多多、Laravel、htmlBurger等國內(nèi)外知名大公司都在使用vue進行新項目的開發(fā)和舊項目的前端重構工作。

    此外,vue + vuex+ vue-resource + vue-router + webpack + es6 + less的項目架構成為了越來越多大公司的第一選擇。

    聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    全面介紹vue 全家桶和項目實例

    全面介紹vue 全家桶和項目實例:簡介 簡單卻不失優(yōu)雅,小巧而不乏大匠。 2016年最火的前端框架當屬Vue.js了,很多使用過vue的程序員這樣評價它,vue.js兼具angular.js和react.js的優(yōu)點,并剔除了它們的缺點。授予了這么高的評價的vue.js,也是開源世界華人的驕傲,因為它的作者
    推薦度:
    標簽: VUE 項項目 全家桶
    • 熱門焦點

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 久久精品毛片免费观看| 成人区人妻精品一区二区不卡网站| 四虎国产精品永久在线无码| 国产91久久精品一区二区| 在线精品动漫一区二区无广告| 99精品人妻少妇一区二区| 精品无码无人网站免费视频| 欧美精品一区二区三区免费观看 | 久久精品无码午夜福利理论片| 久久精品国产亚洲精品| 91精品国产福利在线观看麻豆| 大桥未久在线精品视频在线 | 亚洲精品二三区| 青青草97国产精品免费观看| 国产精品原创巨作?v网站| 亚洲国产精品成| 精品精品国产自在久久高清| 国产精品美女久久久久| 久久99国产综合精品| 亚洲精品国产精品乱码不99| 亚洲精品和日本精品| 久久久久亚洲精品天堂久久久久久| 99精品国产成人一区二区| 99国产精品国产免费观看| 97精品伊人久久久大香线蕉| 亚洲国产精品自在在线观看 | 日韩精品久久无码中文字幕| 在线观看自拍少妇精品| 最新在线精品国自av| 一本一道久久a久久精品综合| 午夜成人精品福利网站在线观看| 精品国产综合区久久久久久| 国产一区二区三区在线观看精品| 国产美女精品视频| 精品亚洲视频在线观看| 久夜色精品国产一区二区三区| 久久久久99精品成人片牛牛影视| 久久精品国产99久久香蕉| 久草视频精品在线| 亚洲精品线路一在线观看| 日韩精品极品视频在线观看免费 |