vue + vuex 表单处理
使用场景:在一个表单中,各项数据提交后需要重置表单中各<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 表单处理的更多相关文章
- vue的表单编辑删除,保存取消功能
过年回来第一篇博客,可能说的不是很清楚,而且心情可能也不是特别的high,虽然今天是元宵,我还在办公室11.30在加班,但就是想把写过的代码记下来,怕以后可能真的忘了.(心将塞未塞,欲塞未满) VUE ...
- Vue.js表单校验;动画指令;避免内存泄露。
Vue.js表单校验: 动画指令:创建自定义的滚动指令. 避免内存泄露. 避免内存泄露 在单页面应用开发时SPA,用户无需刷新浏览器.所以javascript应用需要自行清理组件来防止内存占用不断增长 ...
- 12.Vue.js 表单
这节我们为大家介绍 Vue.js 表单上的应用. 你可以用 v-model 指令在表单控件元素上创建双向数据绑定. <div id="app"> <p>in ...
- Vue Element-ui表单校验规则,你掌握了哪些?
1.前言 Element-ui表单校验规则,使得错误提示可以直接在form-item下面显示,无需弹出框,因此还是很好用的. 我在做了登录页面的表单校验后,一度以为我已经很了解表单的校验规则. ...
- vue b表单
你可以用 v-model 指令在表单控件元素上创建双向数据绑定. v-model 会根据控件类型自动选取正确的方法来更新元素. 输入框 实例中演示了 input 和 textarea 元素中使用 v- ...
- Vue(六) 表单与 v-model
学习使用 v-model 指令完成表单数据双向绑定 基本用法 表单控件在实际业务较为常见,比如单选,多选.下拉选择.输入框等,用他们可以完成数据的录入.校验.提交等.Vue.js 提供了 v-mode ...
- 前端框架之Vue(8)-表单输入绑定
基础用法 你可以用 v-model 指令在表单 <input> . <textarea> 及 <select> 元素上创建双向数据绑定.它会根据控件类型自动选取正确 ...
- 使用vue做表单验证
<template> <Form ref="formInline" :model="formInline" :rules="rule ...
- 【转】vue.js表单校验详解
官方文档:https://monterail.github.io/vuelidate/ https://github.com/monterail/vuelidate 1.npm安装vue-valida ...
随机推荐
- Freemarker常用技巧(三)
freemarker模板解析过程 例如:一个freemarker表达式<body> ${hello} </body>,会被解析成三个部分,分别是<body>${he ...
- Mui实现退出登录
document.getElementById("logout").addEventListener("tap",function(){ var btn=[&q ...
- 帧动画 AnimationDrawable
Drawable Animation(Frame Animation):帧动画,就像GIF图片,通过一系列Drawable依次显示来模拟动画的效果. 首先,在res/drawable中定义动画 < ...
- 渲染器 Shader BitmapShader
渲染模式: tileX tileY:The tiling mode for x/y to draw the bitmap in. 在位图上 X/Y 方向 瓦工/花砖/瓷砖 模式 CLAMP :如 ...
- Myeclipse中点(.)不出来方法或者属性?
- 对相同id的input框的循环判断
$("input[id=sl]").each(function(){ alert(10); });
- ASP.NET-FineUI开发实践-9(四)
现在是这么个问题,在开发中表格是动态出来的,就是标准板是全部字段列出,客户要根据情况列出自己想要的,在增加操作页面的同时要是能用前台自带的功能直接保存到后台就好了,现在的列显示和隐藏是不回发的. 1. ...
- hdu 2689
hdu 2689 超级大水题....两种代码都过了,开始以为n^2会tle,后来竟然过了...汗 注意下cin写在while里面,就可以了 #include <iostream> usin ...
- java图片缩放
package com.rubekid.springmvc.utils; import java.awt.AlphaComposite; import java.awt.Graphics2D; imp ...
- 使用HTML5 API(AudioContext)实现可视化频谱效果
如今的HTML5技术正让网页变得越来越强大,通过其Canvas标签与AudioContext对象可以轻松实现之前在Flash或Native App中才能实现的频谱指示器的功能. Demo: Cyand ...