state.js:
const state={
article:localStorage["article"]?JSON.parse(localStorage["article"]): [],
collections:localStorage["collections"]?JSON.parse(localStorage["collections"]): [],
carts:localStorage["carts"]?JSON.parse(localStorage["carts"]): [],
orders:localStorage["orders"]?JSON.parse(localStorage["orders"]): [],
todos:localStorage["todos"]?JSON.parse(localStorage["todos"]): [],
address:localStorage["address"]?JSON.parse(localStorage["address"]): [],
nowIndex:0,
arr:[1,2,3,4,5]
}
export default state
action.js:
const actions={
//購物車
setCart({commit},data){
commit('SET_CARTS',data)
},
//文章收藏
setArticle({commit},data){
commit('SET_ARTICLE',data)
},
//商品收藏
setGoods({commit},data){
commit('SET_GOODS',data)
},
//地址
setAddress({commit},data){
commit('SET_ADDRESS',data)
},
//訂單
setOrders({commit},data){
commit('SET_ORDERS',data)
}
}
export default actions
type.js:
export const SET_CARTS = 'SET_CARTS' //加入購物車
export const SET_ARTICLE ='SET_ARTICLE' //文章收藏
export const SET_GOODS='SET_GOODS' //商品收藏
export const SET_ORDERS='SET_ORDERS' //訂單
export const SET_ADDRESS='SET_ADDRESS' //地址
import state from './state'
import * as type from './type.js'
import { MessageBox } from 'mint-ui';
const matutaions={
//購物車
[type.SET_CARTS](state,data){
state.carts.push(data)
localStorage.setItem("carts",JSON.stringify(state.carts));
},
//文章
[type.SET_ARTICLE](state,data){
state.article.push(data)
localStorage.setItem("article",JSON.stringify(state.article));
},
//商品
[type.SET_GOODS](state,data){
state.collections.push(data)
localStorage.setItem("collections",JSON.stringify(state.collections));
},
//訂單
[type.SET_ORDERS](state,data){
state.orders.push(data)
localStorage.setItem("orders",JSON.stringify(state.orders));
},
//地址
[type.SET_ADDRESS](state,data){
state.address.push(data)
localStorage.setItem("address",JSON.stringify(state.address));
},
//文章刪除
del:(state,index)=>{
MessageBox.confirm('確定取消收藏該文章么?').then(action=>{
state.article.splice(index,1)
localStorage.setItem("article",JSON.stringify(state.article));
})
},
//商品刪除
cancel:(state,index)=>{
MessageBox.confirm('確定取消收藏該商品么?').then(action=>{
state.collections.splice(index,1)
localStorage.setItem("collections",JSON.stringify(state.collections));
})
},
laji:(state,index)=>{
MessageBox.confirm('確定刪除收貨地址么?').then(action=>{
state.address.splice(index,1)
localStorage.setItem("address",JSON.stringify(state.address));
})
},
//購物車刪除
shanchu:(state,index)=>{
MessageBox.confirm('確定刪除該商品么?').then(action=>{
state.carts.splice(index,1)
localStorage.setItem("carts",JSON.stringify(state.carts));
})
},
//訂單刪除
odefault:(state,index)=>{
MessageBox.confirm('確定刪除該訂單么?').then(action=>{
state.orders.splice(index,1)
localStorage.setItem("orders",JSON.stringify(state.orders));
})
},
//數(shù)量加
add(state,index){
state.carts[index].value++
},
//數(shù)量減
reduce(state,index){
state.carts[index].value==1?state.carts[index].value=1: state.carts[index].value--
},
settlement:(state,data)=>{
state.carts=[];
localStorage.setItem("carts",JSON.stringify(state.carts));
},
}
export default matutaions
上述代碼源于github一個項目,我是下載下來自己研究。在這里有幾個問題請教大家一下。
1、在vuex 整個結(jié)構(gòu)中,type.js 扮演的什么角色,在學(xué)習(xí)vuex的時候沒有見到過這種寫法,為什么要這么寫?必須要這么寫么?
2、vuex中action.js 有一些方法,但是不是全部,就是為什么//地址
[type.SET_ADDRESS](state,data){
state.address.push(data)
localStorage.setItem("address",JSON.stringify(state.address));
},
//文章刪除
del:(state,index)=>{
MessageBox.confirm('確定取消收藏該文章么?').then(action=>{
state.article.splice(index,1)
localStorage.setItem("article",JSON.stringify(state.article));
})
},
同樣是vuex里面的方法,有的方法是用上面的 [type.SET_ADDRESS]寫法,有的直接就可以像del這么使用,為什么要寫兩種呢?
3、vuex 一刷新瀏覽器然后vuex里面的state數(shù)據(jù)就消失了,我查到了localstorage,請問這是最好的方法么?
說一下我個人的理解吧。
關(guān)于type.js
簡單來講,type.js只是一個引用,或者說字符串的映射。
type.js把這些string集中在一起使得你可以很直觀的看到你的模塊或者app具有哪些狀態(tài)以及狀態(tài)變化。
這里是官方的解釋: https://vuex.vuejs.org/zh/gui...。
// type.js
export const GET_LIST = 'GET_ORDER_LIST'
// action.js
[types.GET_LIST](...) {...} // 實際上等價于直接使用string: GET_ORDER_LIST(...) {...}
至于第二個問題,我只能說是代碼的規(guī)范問題了,不使用type.js當(dāng)然可以,只要你能保證action的name能夠不沖突就行了。但是個人還是比較建議同時只使用一種,要么都用type,要么都不用。
關(guān)于數(shù)據(jù)持久化,參考目前的一些插件的話,也都是用的localStorage,我自己也是用的localStorage和sessionStorage,如果有更多或者更好的辦法的話,麻煩告知我:-)。
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達(dá)內(nèi)教育集團成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國家深化產(chǎn)教融合/校企合作的政策,積極推進(jìn)“中國制造2025”,實現(xiàn)中華民族偉大復(fù)興的升級產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。