Vue2 移動端開發環境搭建
本文給出基于 Vue2 的移動端環境搭建,移動端大家更多想到的是響應布局,我們根據不同大小的屏幕進行適配,當然少不了我們的重頭戲 rem,移動端相比 pc 端就沒什么特別的了。
我會一步一步帶領大家進入 Vue2 的世界,擁抱變化,熟悉 Vue 1.x 的根據文檔可以迅速掌握 2.0,因為其中大約 90% 的語法是重復的。2.0 更多是基于框架本身的優化,整體設計思想是不變的。
vue-cli
首先還是介紹我們的腳手架工具,因為它能讓我們省去大部分的配置時間,這里只給出簡單步驟,保證你的命令順利運行的前提是安裝最新版本的 node 和 npm,這里不贅述升級流程
全局安裝 vue-cli
npm install vue-cli -g
借此也全局安裝一個 webpack
npm install webpack -g
注意這里可能會有坑,墻內的用戶安裝失敗,沒關系,我們先安裝淘寶鏡像
npm install -g cnpm --registry=https://registry.npm.taobao.org
然后通過以下命令安裝 webpack
cnpm install webpack -g
注:下面 orange 默認給出 npm 的安裝方案,安裝失敗請自行轉為 cnpm 安裝
在需要創建工程的位置運行
vue init webpack-simple 工程名字<工程名字不能用中文>
或者創建 vue1.0 的項目,只需將命令換成
vue init webpack-simple#1.0
這里我們基于 2.x 開發的,直接使用第一種方法創建工程即可,下圖是創建工程時的截圖,需要你添加 Project name , Project description , Author .
圖中已經給出下一步應該操作的步驟,我們按照步驟一步一步執行,這里 orange 不給大家一步一步列出。
注意:這里一定要使用 npm install 安裝官方庫,而不要使用淘寶鏡像,會導致部分依賴丟失。
安裝完成后,目錄如下圖。
然后我們運行我們的項目后瀏覽器會自動彈出,并展示以下頁面
這里注意觀察,默認給我們八個鏈接,可以根據這幾個鏈接獲得我們想要的學習資源,上面是必要的的鏈接(官方文檔以及關注 vue 動態),下面是 vue 的生態系統,大家親切的叫它們為全家桶。
Vue 全家桶
我們接下來介紹全家桶的安裝(使用詳情大家可以去初始頁面的鏈接查看)
一句命令搞定全家桶
npm install vue-router vue-resource vuex --save
package.json 已經加入了我們的全家桶,node_modules 目錄下也有對應的依賴包,注意這里現在還不能用擴展之后的方法,因為我們沒引入到項目中來。
src/main.js 修改如下
import Vue from 'vue' import VueResource from 'vue-resource' import VueRouter from 'vue-router' import Vuex from 'vuex' import App from './App.vue' Vue.use(VueResource) Vue.use(VueRouter) Vue.use(Vuex) new Vue({ el: '#app', render: h => h(App) })
這時我們的項目就能運行對應的擴展方法了
集成 Sass
作為移動端的開發怎么能缺少 css 預編譯語言。sass 安裝需要幾個依賴。
我們干脆在 package.json 把版本寫死,然后通過 npm install 安裝
在 "devDependencies": {} 中添加下面幾個依賴
"node-sass": "^3.8.0", "sass": "^0.5.0", "sass-loader": "^4.0.0",
好,我們 npm install 后,就可以正式使用 sass 啦
目錄結構建議
依賴的安裝到這里差不多結束了,其它大家需要的可以自定義安裝
下面給出我的目錄建議供大家參考,
這里的 img 目錄放置圖片,script 目錄放置公共的工具函數,style 目錄放置我們的 sass 文件,
你查看 App.vue 文件時不難發現,默認的把樣式文件給到了模塊里,這樣樣式一直跟著模塊
orange 建議大家不要這樣做,因為這樣十分不利于樣式的模塊化,注意區分與模版模塊化的區別,
我們單獨設置 style 目錄,并在目錄當中對 sass 進行模塊化處理(通過 import 引入 sass 模塊)
對應的 App.vue 也變得非常簡潔,代碼如下
<style lang="sass"> @import "/style/base.scss"; </style>
rem 適配
對于移動端的開發,rem 適配必不可少,我們可以用多種方式實現,下面給出一種方案
在 /src/script/util.js 中添加如下代碼
export function setREM() { let html = document.documentElement; window.rem = html.getBoundingClientRect().width / 16 ; html.style.fontSize = window.rem + 'px'; }
這里基于寬 320px 的屏幕分成了 16 份,也就是 1rem = 20px,目前大多數設計稿都是根據 iphone6 的寬( 375px )走的,建議大家在這里分成 25 份,也就是 1rem = 15px,計算起來方便些。
然后在 App.vue 的 script 部分中這樣引入
import { setREM } from './script/util';
保證你的 App.vue 是接下來所有開發模塊的父級模塊,切換頁面通過路由實現
簡單說下 rem 原理:根據 html 的 fontSize 屬性值為基準,其它所有的 rem 值,根據這個基準計算。
我們根據屏幕寬度用 js 動態修改了 html 的 fontSize 屬性值,達到移動端適配的目的
來自:http://orangexc.xyz/2016/10/18/Vue2-mobile-terminal-development-environment-to-build/