mpvue是美團團隊開發的一個基於vue.js核心開發小程序的前端框架,可使用vue的語法來寫小程序頁面。對於我這種只會vue全家桶的前端來講,算是福音了。前端
由於比較懶,就選了一個UI框架來節省時間,其實有幾個不錯的UI框架,對比了一下vant weapp比較符合當前需求,因此最後選用了這個有讚的UI框架,不過iview和weui也不錯,雖然我沒用過vue
首先先安裝一個mpvuewebpack
# 全局安裝 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官網 查看,我就很少說了。git
安裝好了以後目錄結構是醬紫的: es6
看起來和日常的vue項目沒太大區別# 啓動項目
# 能夠看到package.json文件能夠執行的命令,有微信(wx)、頭條(tt)、百度(swan)、支付寶(my)
# 指定平臺的開發時構建(微信、百度、頭條、支付寶)
$ npm dev:wx
$ npm dev:swan
$ npm dev:tt
$ npm dev:my
複製代碼
點開微信開發者工具,新建項目,目錄選擇就是剛剛建立的項目目錄(非 dist 目錄),注意要啓動項目,不然會報找不到app.jsongithub
若是本身配置的mpvue-entry總是失敗,能夠選擇配置的好的方案,mpvue.com/mpvue/quick…,可是隻支持微信小程序 基本用法web
$ npm install -g @vue/cli @vue/cli-init
$ vue init F-loat/mpvue-quickstart my-project
$ cd my-project
$ npm install
$ npm run dev
複製代碼
好了,咱們繼續多平臺的小程序vue-router
一、安裝依賴vuex
# 安裝最新版本的mpvue-entry
cnpm install mpvue-entry@next -D
cnpm install mpvue-router-patch --S
複製代碼
二、引入mpvue-router-patch 在src目錄下的main.js文件裏引入mpvue-router-patchvue-cli
四、修改webpack的配置 修改webpack.base.conf.js的配置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/app.json')
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: [
// api 統一橋協議方案
new webpack.DefinePlugin({
'mpvue': 'global.mpvue',
'mpvuePlatform': 'global.mpvuePlatform'
}),
new MpvuePlugin(),
new MpvueEntry()
// new CopyWebpackPlugin([{
// from: '**/*.json',
// to: ''
// }], {
// context: 'src/'
// }),
new CopyWebpackPlugin([
{
from: path.resolve(__dirname, '../static'),
to: path.resolve(config.build.assetsRoot, './static'),
ignore: ['.*']
}
])
]
}
複製代碼
webpack主要就是這些配置改動了。
安裝依賴
# npm
$ npm i vant-weapp -S --production
# yarn
$ yarn add vant-weapp --production
複製代碼
在webpack.base.conf.js中配置vant-weapp
mpvue安裝下來每一個頁面都mian.js不方便,也不能使用router。
加上mpvue-entry和mpvue-router-patch後就能夠了。
mpvue-entry: 集中式頁面配置,自動生成各頁面的入口文件,優化目錄結構,支持新增頁面熱更新
mpvue-router-patch: 在 mpvue 中使用 vue-router 兼容的路由寫法
複製代碼
頁面引入, 在app.json裏引入
<template>
<div class="container">
<van-search
:value="keywords"
placeholder="請輸入搜索關鍵詞"
use-action-slot
@search="onSearch"
>
</div>
</template>
複製代碼
效果如圖:
若是引入以後報錯,請在微信開發工具裏勾選上es6轉es5六、結束
好了基本上UI和router的配置就解決了,碼字好累,下篇接着寫flyio的使用,我也是邊作邊寫,有問題的能夠一塊兒探討。