javascript - vuex 参数绑定问题求解
问题描述
组件中参数的定义像如下写的这样
<script>import store from ’../vuex/store’;export default { // vuex: { // actions: actions, // getters: { // // 过滤后的会话列表 // sessions: ({ sessions, filterKey }) => { // let result = sessions.filter(session => session.user.name.includes(filterKey)); // return result; // }, // // 当前会话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='https://www.haobala.com/wenda/item.user.img'> <p class='name'>{{item.user.name}}</p></li> </ul></p></template>
其中sessions的定义能不能双向绑定呢, 我发现selectSession 方法执行的时候, sessions并没有改变,是不是哪里没有写对呢。
问题解答
回答1:vuex 官方文档不是这么绑定数据的哦,数据监听放在 computed里面,而不是直接放在 data 的方法里面,而且 vuex 对表单的双向处理是这样子的。
//来自 vuex 官方例子<input v-model='message'>// jscomputed: { message: { get () { return this.$store.state.obj.message }, set (value) { this.$store.commit(’updateMessage’, value) } }}
希望对你有帮助~~~
相关文章:
1. javascript - typescript关于接口,对象字面量额外属性检测问题,为什么使用断言或者变量时就不会检测额外属性?2. html - 非微信官方网页,将由微信转换为手机预览模式3. css3 - 关于flex布局的一个问题4. javascript - 为什么当index等于5的时候,不在当前页面跳转到百度?不跳转的代码在倒数第五行5. html5 - HTML或者JS可否动态改变 .css的属性?6. javascript - 请教如何获取百度贴吧新增的两个加密参数7. 极光推送 - Android app消息推送 百度 极光 个推 信鸽哪个好一些?8. javascript - jQuery中live事件在移动微信端下没有效果;代码如下9. 【小白问题】这行python命令行程序是什么意思?10. 为什么微信内置浏览器用$_COOKIE取不到值?
