簡單介紹一下mpvue
mpvue是美團團隊開發的一個基於vue.js核心開發小程式的前端框架,可以使用vue的語法來寫小程式頁面。對於我這種只會vue全家桶的前端來說,算是福音了。
介紹一下vantUI
因為比較懶,就選了一個UI框架來節省時間,其實有幾個不錯的UI框架,對比了一下vant weapp比較符合當前需求,所以最後選用了這個有讚的UI框架,不過iview和weui也不錯,雖然我沒用過
起步
首先先安裝一個mpvue
# 全域性安裝 vue-cli
$ npm install --global vue-cli
# 建立一個基於 mpvue-quickstart 模板的新專案
$ vue init mpvue/mpvue-quickstart my-project
# 安裝依賴
$ cd my-project
$ npm install
# 啟動構建
$ npm run dev
複製程式碼
更多詳情可以自己去 Mpvue官網 檢視,我就不多說了。
安裝好了之後目錄結構是醬紫的:
![微信小程式mpvue+vantUI+flyio+vuex入坑(1)](https://i.iter01.com/images/97f2b7058074f2d5442ed441907767c6c8b8d8452b94ac3d5aa83d87a61f2fcf.png)
# 啟動專案
$ npm run dev
複製程式碼
點開微信開發者工具,新建專案,目錄選擇專案下的dist資料夾,開啟專案,會看到專案預設頁面
引入UI框架
研究了很多,也試過了Mpvue-zanUI,最後還是放棄了,直接把git上下載的vantUI的dist拷貝到自己專案的dist目錄下,我自己重新命名了檔名為vant。如圖:
![微信小程式mpvue+vantUI+flyio+vuex入坑(1)](https://i.iter01.com/images/6339aef9f3a320811236e2c931ee9bb6f13dba14b1612ea4c549e181dd134399.png)
usingComponents: {
'van-search': '../../vant/search/index',
'van-col': '../../vant/col/index',
'van-row': '../../vant/row/index',
'van-icon': '../../vant/icon/index'
}
複製程式碼
mpvue安裝下來每個頁面都mian.js不方便,也不能使用router。
加上mpvue-entry和mpvue-router-patch後就可以了。
mpvue-entry: 集中式頁面配置,自動生成各頁面的入口檔案,優化目錄結構,支援新增頁面熱更新
mpvue-router-patch: 在 mpvue 中使用 vue-router 相容的路由寫法
複製程式碼
1、安裝依賴
cnpm install mpvue-entry --D
cnpm install mpvue-router-patch --S
複製程式碼
2、建立router檔案
在src目錄下建立router資料夾
複製程式碼
![微信小程式mpvue+vantUI+flyio+vuex入坑(1)](https://i.iter01.com/images/914663f05d381c778d5fb093e3c4efaa87ee0f6e04ebd03c836b9316fedf29e0.png)
![微信小程式mpvue+vantUI+flyio+vuex入坑(1)](https://i.iter01.com/images/b26f34f68f808baf15d1aa09809922b9a748fdc8b3ec7482b52a391b1c372b7d.png)
![微信小程式mpvue+vantUI+flyio+vuex入坑(1)](https://i.iter01.com/images/1bef2d742c091acdaaca834d5cfc9e1478bfae290b1ce133d0766208ede04978.png)
var path = require('path')
var fs = require('fs')
var utils = require('./utils')
var config = require('../config')
var vueLoaderConfig = require('./vue-loader.conf')
var MpvuePlugin = require('webpack-mpvue-asset-plugin')
var glob = require('glob')
var CopyWebpackPlugin = require('copy-webpack-plugin')
var relative = require('relative')
const MpvueEntry = require('mpvue-entry')
function resolve (dir) {
return path.join(__dirname, '..', dir)
}
// function getEntry (rootSrc) {
// var map = {};
// glob.sync(rootSrc + '/pages/**/main.js')
// .forEach(file => {
// var key = relative(rootSrc, file).replace('.js', '');
// map[key] = file;
// })
// return map;
// }
// const appEntry = { app: resolve('./src/main.js') }
// const pagesEntry = getEntry(resolve('./src'), 'pages/**/main.js')
// const entry = Object.assign({}, appEntry, pagesEntry)
const entry = MpvueEntry.getEntry('./src/router/router.js')
module.exports = {
// 如果要自定義生成的 dist 目錄裡面的檔案路徑,
// 可以將 entry 寫成 {'toPath': 'fromPath'} 的形式,
// toPath 為相對於 dist 的路徑, 例:index/demo,則生成的檔案地址為 dist/index/demo.js
entry,
target: require('mpvue-webpack-target'),
output: {
path: config.build.assetsRoot,
filename: '[name].js',
publicPath: process.env.NODE_ENV === 'production'
? config.build.assetsPublicPath
: config.dev.assetsPublicPath
},
resolve: {
extensions: ['.js', '.vue', '.json'],
alias: {
'vue': 'mpvue',
'@': resolve('src')
},
symlinks: false,
aliasFields: ['mpvue', 'weapp', 'browser'],
mainFields: ['browser', 'module', 'main']
},
module: {
rules: [
{
test: /\.(js|vue)$/,
loader: 'eslint-loader',
enforce: 'pre',
include: [resolve('src'), resolve('test')],
options: {
formatter: require('eslint-friendly-formatter')
}
},
{
test: /\.vue$/,
loader: 'mpvue-loader',
options: vueLoaderConfig
},
{
test: /\.js$/,
include: [resolve('src'), resolve('test')],
use: [
'babel-loader',
{
loader: 'mpvue-loader',
options: {
checkMPEntry: true
}
},
]
},
{
test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
loader: 'url-loader',
options: {
limit: 10000,
name: utils.assetsPath('img/[name].[ext]')
}
},
{
test: /\.(mp4|webm|ogg|mp3|wav|flac|aac)(\?.*)?$/,
loader: 'url-loader',
options: {
limit: 10000,
name: utils.assetsPath('media/[name].[ext]')
}
},
{
test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
loader: 'url-loader',
options: {
limit: 10000,
name: utils.assetsPath('fonts/[name].[ext]')
}
}
]
},
plugins: [
new MpvuePlugin(),
new MpvueEntry(),
new CopyWebpackPlugin([{
from: '**/*.json',
to: ''
}], {
context: 'src/'
}),
new CopyWebpackPlugin([
{
from: path.resolve(__dirname, '../static'),
to: path.resolve(__dirname, '../dist/static'),
ignore: ['.*']
}
])
]
}
複製程式碼
![微信小程式mpvue+vantUI+flyio+vuex入坑(1)](https://i.iter01.com/images/5eaeafdd6cf8b45650818f2747587bf6d3c932eb459608b6d932d7958070c5e8.png)
![微信小程式mpvue+vantUI+flyio+vuex入坑(1)](https://i.iter01.com/images/649584e8909111bfe7b8f1bc1ca5d1ca5b075d015aa0160f48e0fe9caab26df3.png)
![微信小程式mpvue+vantUI+flyio+vuex入坑(1)](https://i.iter01.com/images/6e123da1e1ba3016a6b174254996d2e0ad6025daca2ed837b5ca1ed6eabf7b52.png)
5、配置router.js,並在對應的頁面使用UI元件
我就直接上程式碼了
module.exports = [
{
path: 'pages/index/index',
name: 'index',
config: {
navigationBarTitleText: '首頁',
enablePullDownRefresh: true,
usingComponents: {
'van-search': '../../vant/search/index',
'van-col': '../../vant/col/index',
'van-row': '../../vant/row/index',
'van-icon': '../../vant/icon/index'
}
}
}]
複製程式碼
頁面引入
<template>
<div class="container">
<van-search
:value="keywords"
placeholder="請輸入搜尋關鍵詞"
use-action-slot
@search="onSearch"
>
</div>
</template>
複製程式碼
效果如圖:
![微信小程式mpvue+vantUI+flyio+vuex入坑(1)](https://i.iter01.com/images/297160685f2a0de8c7b7a05a8ac20627e81d76f9462e452b9519134574819d5f.png)
6、結束
好了基本上UI和router的配置就解決了,碼字好累,下篇接著寫flyio的使用,我也是邊做邊寫,有問題的可以一起探討。