javascript - vuex 參數(shù)綁定問題求解
問題描述
組件中參數(shù)的定義像如下寫的這樣
<script>import store from ’../vuex/store’;export default { // vuex: { // actions: actions, // getters: { // // 過濾后的會(huì)話列表 // sessions: ({ sessions, filterKey }) => { // let result = sessions.filter(session => session.user.name.includes(filterKey)); // return result; // }, // // 當(dāng)前會(huì)話index // currentId: ({ currentSessionId }) => currentSessionId // } // }, data(){return { sessions: store.state.sessions, currentId: store.state.currentSessionId} }, methods:{selectSession(id){ console.log(id); store.dispatch(’selectSession’, id)} }};</script><template><p class='list'> <ul><li v-for='item in sessions' : @click='selectSession(item.id)'> <img:alt='item.user.name' :src='http://www.intensediesel.com/wenda/item.user.img'> <p class='name'>{{item.user.name}}</p></li> </ul></p></template>
其中sessions的定義能不能雙向綁定呢, 我發(fā)現(xiàn)selectSession 方法執(zhí)行的時(shí)候, sessions并沒有改變,是不是哪里沒有寫對(duì)呢。
問題解答
回答1:vuex 官方文檔不是這么綁定數(shù)據(jù)的哦,數(shù)據(jù)監(jiān)聽放在 computed里面,而不是直接放在 data 的方法里面,而且 vuex 對(duì)表單的雙向處理是這樣子的。
//來自 vuex 官方例子<input v-model='message'>// jscomputed: { message: { get () { return this.$store.state.obj.message }, set (value) { this.$store.commit(’updateMessage’, value) } }}
希望對(duì)你有幫助~~~
相關(guān)文章:
1. node.js - 在vuejs-templates/webpack中dev-server.js里為什么要exports readyPromise?2. mysql優(yōu)化 - 關(guān)于mysql分區(qū)3. html5 - 如何實(shí)現(xiàn)帶陰影的不規(guī)則容器?4. javascript - 循環(huán)嵌套多個(gè)promise應(yīng)該如何實(shí)現(xiàn)?5. python - 管道符和ssh傳文件6. 請(qǐng)教各位大佬,瀏覽器點(diǎn) 提交實(shí)例為什么沒有反應(yīng)7. objective-c - iOS開發(fā)支付寶和微信支付完成為什么跳轉(zhuǎn)到了之前開發(fā)的一個(gè)app?8. javascript - 為什么這個(gè)點(diǎn)擊事件需要點(diǎn)擊兩次才有效果9. javascript - ionic2 input autofocus 電腦成功,iOS手機(jī)鍵盤不彈出10. vue.js - vue 打包后 nginx 服務(wù)端API請(qǐng)求跨域問題無法解決。
