当前位置: 首页 > news >正文

网站建设 软件seop

网站建设 软件,seop,教育网络平台建设,魔方建站前言 以下内容都是基于element Plus 和 vue3 一个form-item校验两个下拉框 有时候不可避免会遇到需要一个form-item校验两个下拉框的情况,比如: 这种情况下传统的校验已经无法实现,需要通过form表单提供的自定义校验来实现。以上面的必填…

前言

以下内容都是基于element Plus 和 vue3

一个form-item校验两个下拉框

有时候不可避免会遇到需要一个form-item校验两个下拉框的情况,比如:
在这里插入图片描述
这种情况下传统的校验已经无法实现,需要通过form表单提供的自定义校验来实现。以上面的必填为例

<el-form-item label="工作时报" prop="workStartTime"><el-selectv-model="states.formData.workStartTime"filterablestyle="width: 120px"placeholder="请选择"clearable><el-optionv-for="item in states.workStartTimeList":key="item.completeTime":label="item.label":value="item.completeTime"/></el-select><span style="padding: 0px 5px"> ~ </span><el-selectv-model="states.formData.workEndTime"filterablestyle="width: 120px"placeholder="请选择"clearableref="workEndTimeRef"><el-optionv-for="item in states.workEndTimeList":key="item.completeTime":label="item.label":value="item.completeTime"/></el-select>
</el-form-item>
const validatePass = (rule: any, value: any, callback: any) => {let workEndTime = workEndTimeRef.value.selected.valueif (value && workEndTime) {// 校验成功,这里也可以一些其他逻辑callback()} else {callback(new Error('工作时报不能为空'))}
}
const rules = reactive({workStartTime: [{required: true,validator: validatePass,trigger: 'change',},],
})

注意点:
1、定义的校验方法要放在校验规则上面,不然会提示找不到方法
2、这点最重要,首先form-item上绑定的属性是workStartTime,所以你校验方法中只能拿到该属性对应的值。另一个下拉的值要先获取到,你必须在下拉上绑定一个ref
在这里插入图片描述
你可以通过打印这个ref来找到另一个下拉的值。当第一个下拉改变后就会触发校验,这时只需要判断两个下拉是否都已经有值,如果没有值,返回提示信息就好。

下拉框加一个二次确认,确认值是否改变

以下图为例,当计划类型值的改变时需要清空其他值时,这时最好给与一个二次确认。确认是否改变,而不是直接改变,导致其他数据被清空,这样会很奇怪。
在这里插入图片描述
在这里插入图片描述
这里的问题是,当取消后应该显示原来显示的值。最初想的方向有点错了,想通过监听来实现,当取消时直接将旧值赋值给绑定的属性,但实际结果是监听一直被触发,确认弹窗无法被关闭。

其实实现起来挺简单,最怕的就是方向想错了。可以定义一个变量来保存旧值,然后将二次确认弹窗的部分加到下拉框change事件里

// 计划类型改变事件
const planTypeChange = val => {if (states.lastPlanType) {E_Msg.confirm('提示', '计划类型改变将清空所有资源对应的编码,是否确认修改?').then(() => {emits('planTypeChange', val, true)}).catch(() => {states.formData.planType = states.lastPlanType})} else {states.lastPlanType = val}
}

当第一次下拉选择时,不应该弹出二次确认,这时将当前选择的值记录,当下次下拉改变后,就会进行提示。
这里不用判断记录的值是否和当前选择的值相同,只有当下拉值改变后,才会触发change事件。change事件触发了,一定说明值改变了。

获取form校验的返回结果

有时候因为业务逻辑比较复杂,就会进行组件拆分。这时遇到的问题时,如何在父组件里获取到子组件校验后的返回值。查了一下确实可以实现

// 子组件//获取表单数据
const getFormData = () => {return baseFormRef.value.validate().then(res => {console.log('校验结果:', res)if (res) {// 校验成功,将表单数据返回return states.formData} else {// 检验失败,返回false,表示子组件表单检验不满足return false}})
}// 父组件,子组件的返回值是一个promise函数,这里要进行处理// 这里比较特殊,父组件也需要进行校验,正常情况添加上 async和await就好
formRef.value.validate(async valid => {if (valid) {// 基本信息const baseData = await baseRef.value.getFormData()// 资源信息const resourceData = resourceRef.value.getFormData()console.log('保存的信息:', baseData, resourceData)if (baseData && resourceData) {}}})
http://www.mnyf.cn/news/43347.html

相关文章:

  • 怎么做下载网站搜索大全
  • 陕西省建设监理协会网站主页创建网站花钱吗
  • 关键字搜索网站怎么做苏州网站建设方案
  • 扬州外贸网站建设seo推广专员工作好做吗
  • 怎么做阿里巴巴网站班级优化大师电脑版
  • 无锡网站建设选众鼎吴忠seo
  • wordpress会员阅读权限最新seo网站优化教程
  • 鹤山网站建设易搜互联郑州seo优化顾问热狗
  • 黄色直接观看seo网络科技有限公司
  • 深圳龙岗做网站公司哪家好产品推广计划方案
  • 统一企业官方网站优化搜索引擎营销
  • 武汉网站制作 网络服务绍兴百度seo排名
  • 公司网站建设费用多少seo网站优化师
  • 大连市开发区网站建设公司中国免费网站服务器下载
  • 怎么做app网站ui原型免费入驻的卖货平台有哪些
  • 合肥网站建设费用以网红引流促业态提升
  • 怎么评价一个网站做的好否企业获客方式
  • 网站做的不好会有什么后果seo顾问培训
  • 遵义建一个网站大概要多少钱哈尔滨怎样关键词优化
  • 建设网站需要掌握什么编程语言2022最新永久地域网名
  • 有效的网站推广方式长沙h5网站建设
  • python毕业设计做网站个人怎么建立网站
  • 苏州网络推广苏州网站建设域名注册信息怎么查
  • 2023山西疫情情况seo快速优化方法
  • 网站app怎么做杭州互联网公司排名榜
  • 株洲网站建设报价seo基础理论
  • 网站开发网站制作报价seo公司哪家好用
  • 网站做的像会侵权吗注册网站域名
  • 北京专业网站维护公司seo免费浏览网站
  • 南通企业网站seo百度账号登录中心