使用场景:在一个表单中,各项数据提交后需要重置表单中各<input>元素的值为空。

组件中关联:

<template>
<el-form ref="form" :model="form" label-width="80px">
<el-form-item label="排序号">
<el-input v-model="form.sort" placeholder="请输入排序号"></el-input>
</el-form-item>
<el-form-item label="编码">
<el-input v-model="form.categoryCode" placeholder="请输入种类编号/代码"></el-input>
</el-form-item>
<el-form-item label="名称">
<el-input v-model="form.categoryName" placeholder="请输入种类名称"></el-input>
</el-form-item>
<el-form-item label="禁用">
<input type="checkbox" v-model="form.status" />禁用
</el-form-item>
<el-form-item label="备注">
<el-input type="textarea" v-model="form.remark"></el-input>
</el-form-item>
<el-form-item>
<el-button type="primary" @click="onSubmit">保存</el-button>
<el-button>取消</el-button>
</el-form-item>
</el-form>
</template>
<script>
import { mapGetters, mapActions } from 'vuex'
export default { computed: mapGetters({
form:"categoryForm"
}),
methods: {
...mapActions({
onSubmit:"addCategory"
})
}
}
</script>

vuex中的配置为:

const state = {
// 初始化表单
_categoryForm: {}
} const getters = {
//类别表单
categoryForm: state => state._categoryForm
} const actions = { /**
* 新增类别
*/
addCategory(context) {
var formData = context.getters.categoryForm
//Web API 调用
dictServer.addCategory(formData, function (body) {
//成功回调函数
context.commit("DICT_ADDED_CATEGORY", true, body)
}, function (body) {
//失败回调函数
context.commit("DICT_ADDED_CATEGORY", false, body)
});
}
} const mutations = {
//新增类别后
[types.DICT_ADDED_CATEGORY](state, isSuccess, body) {
if (isSuccess) {
//state._categoryForm = {} //不起作用,必须使用下面的方法
state._categoryForm = {
sort:"",
categoryCode: "",
categoryName: "",
status:false,
remark:""

}

//其他操作
} else {
//操作不成功时操作
}
},

看红字部分,初始化时 直接赋值为空对象即可(_categoryForm: {} ) ,但新增成功后,重置表单 state._categoryForm = {}  却不起作用,必须对其每个元素单项设置才起作用:

      state._categoryForm = {
sort:"",
categoryCode: "",
categoryName: "",
status:false,
remark:""

}

另:element-ui(1.0.6) 中的 Switch开关 Radio单选框  Checkbox多选框 对于空元素无能为力,不是滑块移动不了,就是点击没有反应,现只能用原生的<input>元素代替。 

你以为这样就可以了吗?太天真了少年!初次提交后,表单是会重置,但是只要再次在<input>里输入了内容,开发工具里立即监控到错误:

官方文档说的清楚(http://vuex.vuejs.org/zh-cn/forms.html):
当在严格模式中使用 Vuex 时,在属于 Vuex 的 state 上使用 v-model 会比较棘手:

<input v-model="obj.message">
假设这里的 obj 是在计算属性中返回的一个属于 Vuex store 的对象,在用户输入时,v-model 会试图直接修改 obj.message。在严格模式中,由于这个修改不是在 mutation 函数中执行的, 这里会抛出一个错误。

办法倒是有,按官方给出的解决方案,是为每个属性添加get/set属性,但在一般的信息系统中,录入页面起码几十个<input>元素,为每个元素建立get/set属性,再在Vuex存储文件里建立相应的state get action mutation!需要添加的代码太多了!!!不现实。

为解决这个问题,在网上找了半天答案,找到的例子都是些习作,一个表单2个录入框,3-4个页面的学习型小小型项目,根本没有大型的应用的例子!

现在卡在这儿了!

其实要解决也简单:只要改个参数即可:

export default new Vuex.Store({
actions,
getters,
modules: { },
//不采用严格模式
//strict: debug
strict: false

})

但这样好像不符合官方建议的规范!

经过这个月来的实践,感觉Vue在开发应用系统方面坑太多了,双向绑定是不错,但是使用了Vuex后立马变成坑了!!!目前阶段只能用来做些简单的系统,逻辑复杂的系统还是采用传统的java C# php构建比较靠谱。

vue + vuex 表单处理的更多相关文章

  1. vue的表单编辑删除,保存取消功能

    过年回来第一篇博客,可能说的不是很清楚,而且心情可能也不是特别的high,虽然今天是元宵,我还在办公室11.30在加班,但就是想把写过的代码记下来,怕以后可能真的忘了.(心将塞未塞,欲塞未满) VUE ...

  2. Vue.js表单校验;动画指令;避免内存泄露。

    Vue.js表单校验: 动画指令:创建自定义的滚动指令. 避免内存泄露. 避免内存泄露 在单页面应用开发时SPA,用户无需刷新浏览器.所以javascript应用需要自行清理组件来防止内存占用不断增长 ...

  3. 12.Vue.js 表单

    这节我们为大家介绍 Vue.js 表单上的应用. 你可以用 v-model 指令在表单控件元素上创建双向数据绑定. <div id="app"> <p>in ...

  4. Vue Element-ui表单校验规则,你掌握了哪些?

    1.前言   Element-ui表单校验规则,使得错误提示可以直接在form-item下面显示,无需弹出框,因此还是很好用的.   我在做了登录页面的表单校验后,一度以为我已经很了解表单的校验规则. ...

  5. vue b表单

    你可以用 v-model 指令在表单控件元素上创建双向数据绑定. v-model 会根据控件类型自动选取正确的方法来更新元素. 输入框 实例中演示了 input 和 textarea 元素中使用 v- ...

  6. Vue(六) 表单与 v-model

    学习使用 v-model 指令完成表单数据双向绑定 基本用法 表单控件在实际业务较为常见,比如单选,多选.下拉选择.输入框等,用他们可以完成数据的录入.校验.提交等.Vue.js 提供了 v-mode ...

  7. 前端框架之Vue(8)-表单输入绑定

    基础用法 你可以用 v-model 指令在表单 <input> . <textarea> 及 <select> 元素上创建双向数据绑定.它会根据控件类型自动选取正确 ...

  8. 使用vue做表单验证

    <template> <Form ref="formInline" :model="formInline" :rules="rule ...

  9. 【转】vue.js表单校验详解

    官方文档:https://monterail.github.io/vuelidate/ https://github.com/monterail/vuelidate 1.npm安装vue-valida ...

随机推荐

  1. mysql 热备

    全备份:(生成时间戳文件夹:2016-04-20_16-12-01)innobackupex --users=root --password=root /tmp/backup 第一次增量备份:(生成时 ...

  2. noip 2005 等价表达式

    /* 开始想的是 维护a的每个指数的系数 然而不好办 然而还有^10^10^10这种数据 特殊值带入吧 多搞几个素数 接下来就是玄学的事了 给a赋值之后 就是简单地表达式求值 虽然思路简单 但是字符串 ...

  3. jQuery 基本实现功能模板

    下面是列出了基本功能的实现 <!DOCTYPE html> <html> <head> <script src="http://libs.baidu ...

  4. spring-junit的标注总结

    如果在测试类的类名上面添加了注解 @ContextConfiguration("meta/springConfigured.xml") 如何在标注了@Test的方法里面获取上面xm ...

  5. 纯 CSS 创建各种不同的图形形状

    使用代码 矩形 .rectangle { width: 250px; height: 150px; background-color: #6DC75F; } <div></div&g ...

  6. Memcached 深度分析

    Memcached是danga.com(运营LiveJournal的技术团队)开发的一套分布式内存对象缓存系统,用于在动态系统中减少数据库 负载,提升性能.关于这个东西,相信很多人都用过,本文意在通过 ...

  7. JavaScript 客户端JavaScript之cookie和客户端持久性

    Document对象都有一个cookie属性,它使得JavaScript代码能够在用户的硬盘上持久地存储数据, 并且能够获取以这种方式存储的数据.客户端持久性是赋予WEB应用程序记忆力的一种简单方法. ...

  8. 【转】C#注册快捷键

    转自:http://blog.csdn.net/xiahn1a/article/details/42561015 这里需要引用到“user32.dll”.对于Win32的API,调用起来还是需要dll ...

  9. Java语言实现简单FTP软件------>FTP软件远程窗口的实现(六)

    1.首先看一下远程窗口的布局效果 2.看一下本地窗口实现的代码框架 3.远程窗口主要实现代码FtpPanel.java package com.oyp.ftp.panel.ftp; import ja ...

  10. PHPCMS v9构建模块

    ■补课: 1.phpcms v9帮助文件,上面会写关于二次开发的一些方法. http://v9.help.phpcms.cn/ 2.找一个后台还没安装的模块,先把代码看一边.比如dianping模块 ...