首頁 web前端 js教程 關於vue專案常用組件和框架結構分享

關於vue專案常用組件和框架結構分享

Jan 05, 2018 pm 05:40 PM
常用 組件

一個vue的項目,我覺得最小的子集其實就是{vue,vue-router,component},vue作為基礎庫,提供我們雙向綁定等功能。 vue-router連接不同的"頁",component作為樣式或行為輸出,你可以透過這三個東西來實現最基本的靜態SPA網站。當然我在這裡不談vue全家桶這樣寬泛的概念,我會如數家珍的把主要的技術點一一列舉。

1.vue-cli:搭建基本的vue專案骨架,鷹架工具

2.sass-loader&node-sass:我是使用的sass作為樣式的預編譯工具,兩者缺一不可,大家也可以自行選擇,less,stylus都可以

3.postcss:實現響應式佈局的關鍵,px=>rem。沙漠已經提出了基於vw,vh的佈局方案,不過我暫時持觀望態度。

4.vuex:管理複雜的資料流向,狀態機工具,特化的Flux

5.vuex-persistedstate:將vuex中state持久化的工具

6.vue-router:實作SPA間「頁」之間的跳躍

7.vue-lazyload:實現圖片的懶加載,優化http傳輸效能

8.vue-awesome-swiper:輪播功能的實現及一些特殊切換效果的完成

# 9.better-scroll:實作清單捲動及父子元件間的捲動問題

# 10.axios:http工具,實作向API請求數據,以及攔截器的實作

11.fastclick:解決300ms延遲的函式庫

以上這些,都是我覺得一個中大型的vue專案需要用到的,還有一些比如我在實現圖片上傳中用到了jsx的語法,需要babel-jsx這樣的東西,不具有普適性,就不例舉了。

下面簡述一下上面說到的這些東西,有的東西會單獨的來出來細說:

1.vue-cli:

https://github.com/vuejs/vue-cli

# 鷹架工具,當我們選擇vue作為我們的開發技術堆疊以後,就要開始為我們的專案建造目錄及開發的環境。安裝好node以後,透過以後指令進行安裝

npm install -g vue-cli 將vue-cli安裝到全域環境

vue init webpack my-vue-demo 建立基於webpack模板的名為my-vue-demo檔名的vue項目

這裡的模板有6中,不過我們比較常用的就是webpack了。

期間你會看到有一些例如e2e這樣的單元測試的工具和ESLint檢測程式碼品質的工具,我覺得都是可以不必安裝的。

那麼,其實我們最關心的就是src資料夾下面的內容了。可以看下圖

關於vue專案常用組件和框架結構分享

上圖就是一個在刨除vue-cli的基本結構,在專案上比較成熟的vue骨架了。

2&3 :sass,postcss

直接寫css得洪荒時代已經過去了,預先編譯的樣式處理器幫助我們解放了生產力,提高了效率。 sass,less,stylus各有優缺,也各有信徒。

要使用sass的話,你需要安裝一下sass-loader和node-sass,不過node-sass不是很好裝,被牆的厲害,建議還是用taobao的鏡像。如果安裝完成後還是報錯無法解析的話,你可能需要去webpack.base.conf.js裡去看看是否設定好了對應的loader。

postcss的常用功能

px2rem => 可以幫助我們實現px到rem單位的轉換,只需要你定義好對應的轉換標準就可以了。

autoprefixer => 相容性的處理postcss也可以幫我們處理好。

//vue-loader.conf.js
module.exports = {
 loaders: utils.cssLoaders({
 sourceMap: isProduction
 ? config.build.productionSourceMap
 : config.dev.cssSourceMap,
 extract: isProduction
 }),
 postcss: [
 require('autoprefixer')({
 browsers: ['iOS >= 7', 'Android >= 4.1']
 }),
 require('postcss-px2rem')
 ({ remUnit: 64 })
 ]
}
登入後複製

4,5:vuex,vuex-persistedstate

https://github.com/robinvdvleuten/vuex-persistedstate

一個中大型的vue項目,肯定有複雜的狀態需要去管理。簡單的event bus已經不再適用了。

特化的Flux架構,vuex就迎頭頂上。簡而言之:他就是我們處理無論是使用者操作,API返回,URL變更等多重操作的狀態管理工具。以後我會具體的說下vuex。

用過vuex的人,會發現一個很痛苦的地方,就是vuex裡面的state,只要我們去刷新,它就被釋放掉了。有的狀態還好,沒有了大不了我們可以讓使用者去重新操作一遍。但是像登入這樣的操作,你不可能讓使用者刷一下就去登一下吧。當然,你會說,我們可以存到local啊,cookie裡面啊。是可以!但是這樣的話,state就和local裡的數據形成了一種鬆散的關聯,state顯得十分的脆弱,因為你無法預知你什麼時候會少寫一個setStore這樣的方法。 vuex-persistedstate幫我們解決了這樣的問題,它幫我們直接把state映射到了本地的快取環境,我們可以在computed裡面用vuex提供的mapState輔助函數,來動態的更新local裡面的資料。而不需要持久化的state,我們依舊可以刷新來釋放掉。

6.vue-router

当我们使用vue来构建SPA的应用时,就等于说我们完全的分离了前后端。或者通俗点的说:这就是一个纯前端的项目。后端仅仅提供数据,任何的逻辑都在前端实现。既然"脱离"了后端,那么肯定就没有request Mapping这样的同步映射url了。那么,前端就需要router来实现我们前端"页面"的跳转。vue-router就帮我们做了这样的事情,他提供给了路由守卫给我们,我们可以设置全局的,组件内的路由守卫,来实现特定的业务逻辑。 提供过渡动画,来更加生动的展示SPA应用应有的风采等等,这个以后也要具体的来说。

7.vue-lazyload

https://github.com/hilongjw/vue-lazyload

实现图片的懒加载。这是前端性能优化的一个必须面对的问题:图片。懒加载可以减少请求的数量,而且在很直观的视觉上,也有一个良好的过渡。当然,图片我们也是需要去做一些处理的,使用webp格式来减小图片的质量,或者通过oss来对图片作处理。

8.vue-awesome-swiper

https://github.com/surmon-china/vue-awesome-swiper

通过它可以实现基本轮播,横轴的切换,横轴的列表滚动等。

關於vue專案常用組件和框架結構分享

例如我要去实现四个tab切换这样的功能,但是简单的display这样的效果我又觉得不是很满意。那么我们就可以通过swiper来实现,每次tab里面的content都会对应swiper的一个swiper-item。切换的tab,其实就是swiper里面的next page或者before page.

data(){
  return{
    swiperOption: {
  slidesPerView :'auto',
  direction: 'horizontal',
  freeMode : true,
  loop: false,
  spaceBetween: 20,
    },
 }
}
登入後複製
<swiper>
  <swiper-slide>
  <router-link>
  <img  src="/static/imghw/default1.png" data-src="https://img.php.cn//upload/image/269/731/454/1515140771950235.png" class="lazy" alt="關於vue專案常用組件和框架結構分享" >
   <span>¥{{item.price}}/日</span>
  </router-link>
  </swiper-slide>
 </swiper>
 <p></p>
登入後複製

9.better-scroll

https://github.com/ustbhuangyi/better-scroll

实现纵轴列表的滚动,以及当有嵌套的路由的时候,通过better-scroll来实现的禁止父路由随着子路由的滚动的问题。

better-scroll其实也可以去实现横轴的滚动,但是为什么不使用better-scroll来处理呢?这是因为在better-scroll实现横轴滚动的时候,我们无法在better-scorll的content的内容区域里去下向拉动我们的页面。所以导致的一个Bug就是,在better-scroll横轴滚动的区域里,页面动不了了。

關於vue專案常用組件和框架結構分享

如上图:横轴滚动下面还有内容,但是在图片所示的区域里面,无法向下拉动。所以横轴的滚动其实也是通过vue-awesome-swiper来实现的。

10.axios

基本功能就是通过axios来请求后台接口的数据。并且axios可以配合router更好的实现类似后台的拦截器的功能,例如处理token过期这样问题。因为当token过期的时候,仅仅通过vue-router的router.beforeEach来处理就有点无能为力了。这时候就需要配合后台响应返回的code来进行url的处理。

相关推荐:

vue项目中定义全局变量和全局函数方法

如何新建一个vue项目

vue项目构建与实战实例教程

以上是關於vue專案常用組件和框架結構分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何安裝Win10舊版元件DirectPlay 如何安裝Win10舊版元件DirectPlay Dec 28, 2023 pm 03:43 PM

不少用戶在玩win10的的一些遊戲的時候總是會遇到一些問題,比如說卡屏和花屏等等情況,這個時候我們是可以採用打開directplay這個功能來解決的,而且功能的操作方法也很簡單。 win10舊版元件directplay怎麼安裝1、在搜尋框裡面輸入「控制台」然後開啟2、檢視方式選擇大圖示3、找到「程式與功能」4、點選左側的啟用或關閉win功能5、選擇舊版這裡的勾選上就可以了

如何使用 Vue 實現日曆元件? 如何使用 Vue 實現日曆元件? Jun 25, 2023 pm 01:28 PM

Vue是一款非常流行的前端框架,它提供了許多工具和功能,如元件化、資料綁定、事件處理等,能夠幫助開發者建立出高效、靈活和易於維護的Web應用程式。在這篇文章中,我來介紹如何使用Vue實作一個日曆元件。 1.需求分析首先,我們需要分析這個行事曆組件的需求。一個基本的日曆應該具備以下功能:展示當前月份的日曆頁面;支援切換到前一月或下一月;支援點擊某一天,

VUE3開發基礎:使用extends繼承元件 VUE3開發基礎:使用extends繼承元件 Jun 16, 2023 am 08:58 AM

Vue是目前最受歡迎的前端框架之一,而VUE3則是Vue框架的最新版本,相較於VUE2,VUE3具備了更高的性能和更出色的開發體驗,成為了眾多開發者的首選。在VUE3中,使用extends繼承元件是一個非常實用的開發方式,本文將為大家介紹如何使用extends繼承元件。 extends是什麼?在Vue中,extends是一個非常實用的屬性,它可以用於子元件繼承父

Angular元件及其顯示屬性:了解非block預設值 Angular元件及其顯示屬性:了解非block預設值 Mar 15, 2024 pm 04:51 PM

Angular框架中元件的預設顯示行為不是區塊級元素。這種設計選擇促進了元件樣式的封裝,並鼓勵開發人員有意識地定義每個元件的顯示方式。透過明確設定CSS屬性 display,Angular組件的顯示可以完全控制,從而實現所需的佈局和響應能力。

如何開啟win10舊版組件的設置 如何開啟win10舊版組件的設置 Dec 22, 2023 am 08:45 AM

win10舊版元件是需要使用者自己去設定裡面打開的,因為很多的元件平時都是預設關閉的狀態,首先我們需要進入到設定裡面,操作很簡單,跟著下面的步驟來就可以了win10舊版元件在哪裡開啟1、點選開始,然後點選「win系統」2、點選進入控制台3、再點選下面的程式4、點選「啟用或關閉win功能」5、在這裡就可以選擇你要的開啟了

學習canvas框架 詳解常用的canvas框架 學習canvas框架 詳解常用的canvas框架 Jan 17, 2024 am 11:03 AM

探索Canvas框架:了解常用的Canvas框架有哪些,需要具體程式碼範例引言:Canvas是HTML5中提供的一個繪圖API,透過它我們可以實現豐富的圖形和動畫效果。為了提高繪圖的效率和便利性,許多開發者開發了不同的Canvas框架。本文將介紹一些常用的Canvas框架,並提供具體程式碼範例,以幫助讀者更深入地了解這些框架的使用方法。一、EaselJS框架Ea

Vue元件開發:進度條元件實作方法 Vue元件開發:進度條元件實作方法 Nov 24, 2023 am 08:56 AM

Vue元件開發:進度條元件實作方法前言:在Web開發中,進度列是一種常見的UI元件,在資料要求、檔案上傳、表單提交等場景中常用來顯示作業的進度。在Vue.js中,透過自訂元件的方式,我們可以很方便地實作一個進度條元件,本文將介紹一種實作方法,並提供具體的程式碼範例。希望能對Vue.js初學者有幫助。組件的結構和樣式首先,我們需要定義進度條組件的基本結構和樣

Vue組件實戰:分頁組件開發 Vue組件實戰:分頁組件開發 Nov 24, 2023 am 08:56 AM

Vue元件實戰:分頁元件開發介紹在網路應用程式中,分頁功能是不可或缺的一個元件。一個好的分頁元件應該展示簡潔明了,功能豐富,而且易於整合和使用。在本文中,我們將介紹如何使用Vue.js框架來開發一個高度可自訂化的分頁元件。我們將透過程式碼範例來詳細說明如何使用Vue元件開發。技術堆疊Vue.js2.xJavaScript(ES6)HTML5和CSS3開發環

See all articles