能看这篇文章应该已对mpvue有所了解,此处不做赘述。
源码
构成
1、采用mpvue 官方脚手架搭建项目底层结构
2、采用Fly.js 作为http请求库
目录结构
├── src // 我们的项目的源码编写文件
│ ├── components // 组件目录
│ ├── config //公共配置
│ │ └── tips // 提示与加载工具类
│ ├── http //http请求配置文件
│ │ └── api // 接口调用文件
│ │ └── config //fly 配置文件
│ ├── pages //项目页面目录
│ ├── store //状态管理 vuex配置目录
│ │ └── actions.js //actions异步修改状态
│ │ └── getters.js //getters计算过滤操作
│ │ └── mutation-types.js //mutations 类型
│ │ └── mutations.js //修改状态
│ │ └── index.js //我们组装模块并导出 store 的地方
│ │ └── state.js //数据源定义
│ ├── untils //工具函数目录
│ │ └── index.js
│ ├── App.vue // APP入口文件
│ ├── main.js // 主配置文件
│ ├── config.js // host配置
快速创建一个mpvue项目
# 全局安装 vue-cli
$ npm install -g vue-cli
# 创建一个基于 mpvue-quickstart 模板的新项目,记得选择安装vuex
$ vue init mpvue/mpvue-quickstart mpvue-demo
# 安装fly
$ npm i flyio --save
# 安装依赖
$ cd mpvue-demo
$ npm i
# 启动构建
$ npm run dev
配置fly
1、配置公共设置
src/http/config.js
//引入 fly
var Fly = require("flyio/dist/npm/wx")
var fly = new Fly;
//配置请求基地址
// //定义公共headers
// fly.config.headers={xx:5,bb:6,dd:7}
// //设置超时
// fly.config.timeout=10000;
// //设置请求基地址
// fly.config.baseURL="https://wendux.github.io/"
//添加请求拦截器
fly.interceptors.request.use((request)=>{
//给所有请求添加自定义header
request.headers["X-Tag"]="flyio";
//打印出请求体
// console.log(request.body)
//终止请求
//var err=new Error("xxx")
//err.request=request
//return Promise.reject(new Error(""))
//可以显式返回request, 也可以不返回,没有返回值时拦截器中默认返回request
return request;
})
//添加响应拦截器,响应拦截器会在then/catch处理之前执行
fly.interceptors.response.use(
(response) => {
//只将请求结果的data字段返回
return response.data
},
(err) => {
//发生网络错误后会走到这里
//return Promise.resolve("ssss")
}
)
// Vue.prototype.$http=fly //将fly实例挂在vue原型上
export default fly
2、配置个性设置
src/http/api.js
import fly from './config'
import qs from 'qs'
import config from '../config'
const host = config.host;
const appKey = config.appKey;
const appid = config.appid;
/**
* 接口模版====post
*
* export const test = params => {return fly.post(`${root}/xx/xx`, qs.stringify(params))};
*
* 接口模版====get
*
* export const test1 = function(){return fly.get(`${root}/api/getNewsList`)}
*
*
* 用法:
* 在 页面用引入 test
* import {test} from '../../http/api.js'
*
* test(params).then(res=>{ console.log(res) })
*/
// 通用的get请求
export const get = (params) => {
return fly.get(`${host}${params.url}`, qs.stringify(params.data))
};
// 通用的post请求
export const post = (params) => {
return fly.post(`${host}${params.url}`, qs.stringify(params.data))
};
host配置
config.js
const host = 'http://xxx.xxx'
const config = {
host
}
export default config
配置vuex
1、目录结构
│ ├── store //状态管理 vuex配置目录
│ │ └── actions.js //actions异步修改状态
│ │ └── getters.js //getters计算过滤操作
│ │ └── mutation-types.js //mutations 类型
│ │ └── mutations.js //修改状态
│ │ └── index.js //我们组装模块并导出 store 的地方
│ │ └── state.js //数据源定义
2、main.js
中引入store, 并绑定到Vue构造函数的原型上,这样在每个vue的组件都可以通过this.$store
访问store对象。
import store from './store/index'
Vue.prototype.$store=store;
3、定义初始变量store/state.js
const state={
openId: '',
}
export default state
4、mutation类型
方便检测错误和书写,一般写方法
export const SET_OPEN_ID = 'SET_OPEN_ID'
5、store/mutations.js
写处理方法
import * as types from './mutation-types'
const matations={
/**
* state:当前状态树
* v: 提交matations时传的参数
*/
[types.SET_OPEN_ID] (state, v) {
state.openId = v;
},
}
export default matations
6、store/index.js
汇总配置
import Vue from 'vue';
import Vuex from 'vuex';
import state from './state'
import mutations from './mutations'
Vue.use(Vuex);
export default new Vuex.Store({
state,
mutations,
})
使用vuex
ps:没有用到复杂计算,因此没有引入getters.js
和actions.js
栗子:App.vue
<script>
import config from './config'
import { mapState, mapMutations } from 'vuex'
import { SET_OPEN_ID } from './store/mutation-types'
export default {
data: {
globalData: {
loginUrl: 'https://xxx.com/mini/login'
}
},
computed: {
...mapState([
'openId'
])
},
methods: {
...mapMutations({
setOpenId: 'SET_OPEN_ID'
}),
login() {
let _this = this;
wx.login({
success: function (res) {
if (res.code) {
let code = res.code;
// 登录后台,获取openId
wx.request({
url: _this.globalData.loginUrl,
method: 'GET',
data: {
appid: config.appid,
code: code,
appKey: config.appKey
},
success: function(res) {
if (res.data.code === 200) {
_this.setOpenId(res.data.data.openId);
} else {
wx.showModal({
title: '提示',
content: res.data.message,
showCancel: false
})
}
},
fail: err => {
wx.showToast({
title: err
})
}
})
} else {
console.log('获取用户登录态失败!' + res.errMsg)
}
},
fail: err => {
}
});
}
},
created() {
this.login()
}
}
</script>
<style>
</style>
使用vuex-persistedstate
,使vuex状态持久化(缓存到本地)
store/index.hs
的export default
中添加配置:
// 引入vuex-persistedstate,将vuex的数据持久化到本地
export default new Vuex.Store({
state,
mutations,
getters,
actions,
plugins: [
createPersistedState({
storage: {
getItem: key => wx.getStorageSync(key),
setItem: (key, value) => wx.setStorageSync(key, value),
removeItem: key => {}
}
})
]
})