1.store/actions.js
/*
通过mutation间接更新state的多个方法的对象
*/
import {
RECEIVE_ADDRESS,
RECEIVE_CATEGORYS,
RECEIVE_SHOPS,
RECEIVE_USER_INFO,
RESET_USER_INFO,
RECEIVE_GOODS,
RECEIVE_RATINGS,
RECEIVE_INFO,
INCREMENT_FOOD_COUNT,
DECREMENT_FOOD_COUNT,
CLEAR_CART,
RECEIVE_SEARCH_SHOPS
} from './mutation-types'
import {
reqAddress,
reqFoodCategorys,
reqShops,
reqUserInfo,
reqLogout,
reqShopRatings,
reqShopGoods,
reqShopInfo,
reqSearchShop
} from '../api'
export default {
// 异步获取地址
async getAddress({commit, state}) {
// 发送异步ajax请求
const geohash = state.latitude + ',' + state.longitude
const result = await reqAddress(geohash)
// 提交一个mutation
if (result.code === 0) {
const address = result.data
commit(RECEIVE_ADDRESS, {address})
}
},
// 异步获取食品分类列表
async getCategorys({commit}) {
// 发送异步ajax请求
const result = await reqFoodCategorys()
// 提交一个mutation
if (result.code === 0) {
const categorys = result.data
commit(RECEIVE_CATEGORYS, {categorys})
}
},
// 异步获取商家列表
async getShops({commit, state}) {
// 发送异步ajax请求
const {longitude, latitude} = state
const result = await reqShops(longitude, latitude)
// 提交一个mutation
if (result.code === 0) {
const shops = result.data
commit(RECEIVE_SHOPS, {shops})
}
},
// 同步记录用户信息
recordUser({commit}, userInfo) {
commit(RECEIVE_USER_INFO, {userInfo})
},
// 异步获取用户信息
async getUserInfo({commit}) {
const result = await reqUserInfo()
if (result.code === 0) {
const userInfo = result.data
commit(RECEIVE_USER_INFO, {userInfo})
}
},
// 异步登出
async logout({commit}) {
const result = await reqLogout()
if (result.code === 0) {
commit(RESET_USER_INFO)
}
},
// 异步获取商家信息
async getShopInfo({commit}) {
const result = await reqShopInfo()
if (result.code === 0) {
const info = result.data
commit(RECEIVE_INFO, {info})
}
},
// 异步获取商家评价列表
async getShopRatings({commit}, callback) {
const result = await reqShopRatings()
if (result.code === 0) {
const ratings = result.data
commit(RECEIVE_RATINGS, {ratings})
// 数据更新了, 通知一下组件
callback && callback()
}
},
// 异步获取商家商品列表
async getShopGoods({commit}, callback) {
const result = await reqShopGoods()
if (result.code === 0) {
const goods = result.data
commit(RECEIVE_GOODS, {goods})
// 数据更新了, 通知一下组件
callback && callback()
}
},
// 同步更新food中的count值
updateFoodCount({commit}, {isAdd, food}) {
if (isAdd) {
commit(INCREMENT_FOOD_COUNT, {food})
} else {
commit(DECREMENT_FOOD_COUNT, {food})
}
},
// 同步清空购物车
clearCart({commit}) {
commit(CLEAR_CART)
},
// 异步获取商家商品列表
async searchShops({commit, state}, keyword) {
const geohash = state.latitude + ',' + state.longitude
const result = await reqSearchShop(geohash, keyword)
if (result.code === 0) {
const searchShops = result.data
commit(RECEIVE_SEARCH_SHOPS, {searchShops})
}
},
}
2.store/getters.js
/*
包含多个基于state的getter计算属性的对象
*/
export default {
totalCount (state) {
return state.cartFoods.reduce((preTotal, food) => preTotal + food.count , 0)
},
totalPrice (state) {
return state.cartFoods.reduce((preTotal, food) => preTotal + food.count*food.price , 0)
},
positiveSize (state) {
return state.ratings.reduce((preTotal, rating) => preTotal + (rating.rateType===0?1:0) , 0)
}
}
3.store/index.js
/*
vuex最核心的管理对象store
*/
import Vue from 'vue'
import Vuex from 'vuex'
import state from './state'
import mutations from './mutations'
import actions from './actions'
import getters from './getters'
Vue.use(Vuex)
export default new Vuex.Store({
state,
mutations,
actions,
getters
})
4.store/mutation-types.js
/*
包含n个mutation的type名称常量
*/
export const RECEIVE_ADDRESS = 'receive_address' // 接收地址
export const RECEIVE_CATEGORYS = 'receive_categorys' // 接收食品分类数组
export const RECEIVE_SHOPS = 'receive_shops' // 接收商家数组
export const RECEIVE_USER_INFO = 'receive_user_info' // 接收用户信息
export const RESET_USER_INFO = 'reset_user_info' // 重置用户信息
export const RECEIVE_GOODS = 'receive_goods' // 接收商品数组
export const RECEIVE_RATINGS = 'receive_ratings' // 接收商家评价数组
export const RECEIVE_INFO = 'receive_info' // 接收商家信息
export const INCREMENT_FOOD_COUNT = 'increment_food_count' // 增加food中的count
export const DECREMENT_FOOD_COUNT = 'decrement_food_count' // 减少food中的count
export const CLEAR_CART = 'clear_cart' // 清空购物车
export const RECEIVE_SEARCH_SHOPS = 'receive_search_shops' // 接收搜索的商家数组
5.store/mutations.js
/*
直接更新state的多个方法的对象
*/
import Vue from 'vue'
import {
RECEIVE_ADDRESS,
RECEIVE_CATEGORYS,
RECEIVE_SHOPS,
RECEIVE_USER_INFO,
RESET_USER_INFO,
RECEIVE_INFO,
RECEIVE_RATINGS,
RECEIVE_GOODS,
INCREMENT_FOOD_COUNT,
DECREMENT_FOOD_COUNT,
CLEAR_CART,
RECEIVE_SEARCH_SHOPS
} from './mutation-types'
export default {
[RECEIVE_ADDRESS] (state, {address}) {
state.address = address
},
[RECEIVE_CATEGORYS] (state, {categorys}) {
state.categorys = categorys
},
[RECEIVE_SHOPS] (state, {shops}) {
state.shops = shops
},
[RECEIVE_USER_INFO] (state, {userInfo}) {
state.userInfo = userInfo
},
[RESET_USER_INFO] (state) {
state.userInfo = {}
},
[RECEIVE_INFO](state, {info}) {
state.info = info
},
[RECEIVE_RATINGS](state, {ratings}) {
state.ratings = ratings
},
[RECEIVE_GOODS](state, {goods}) {
state.goods = goods
},
[INCREMENT_FOOD_COUNT](state, {food}) {
if(!food.count) { // 第一次增加
// food.count = 1 // 新增属性(没有数据绑定)
/*
对象
属性名
属性值
*/
Vue.set(food, 'count', 1) // 让新增的属性也有数据绑定
// 将food添加到cartFoods中
state.cartFoods.push(food)
} else {
food.count++
}
},
[DECREMENT_FOOD_COUNT](state, {food}) {
if(food.count) {// 只有有值才去减
food.count--
if(food.count===0) {
// 将food从cartFoods中移除
state.cartFoods.splice(state.cartFoods.indexOf(food), 1)
}
}
},
[CLEAR_CART](state) {
// 清除food中的count
state.cartFoods.forEach(food => food.count = 0)
// 移除购物车中所有购物项
state.cartFoods = []
},
[RECEIVE_SEARCH_SHOPS](state, {searchShops}) {
state.searchShops = searchShops
},
}
6.store/state.js
/*
状态对象
*/
export default {
latitude: 40.10038, // 纬度
longitude: 116.36867, // 经度
address: {}, //地址相关信息对象
categorys: [], // 食品分类数组
shops: [], // 商家数组
userInfo: {}, // 用户信息
goods: [], // 商品列表
ratings: [], // 商家评价列表
info: {}, // 商家信息
cartFoods: [], // 购物车中食物的列表
searchShops: [], // 搜索得到的商家列表
}