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

elementUI rules 判断 el-cascader控件修改值未生效

今天修改一个前端项目,增加一个多选字段,使用的是el-cascader控件,因页面是通过引用子页面组件形式使用,出现一个点选后再勾选原有值,输入框内不展示或取消后的也未正常隐藏,如果勾选的值是全新的则其他已选值也会被带出展示,好神奇~~~~~。

具体如下图:

各种尝试修改,隐藏屏蔽,还是不行。。。

最后发下一个之前遇到类似问题,就是引用子页面组件控件动态赋值时出现未及时更新情况。最后再组件中增加了点击事件方法,在方法里加了一句话就解决了。!!!!!

上代码:

//父级页面应用子页面组件
<el-tab-pane label="基本资料" name="userinfo">
  <userInfo :user-data="user" :risk-list="riskList"/>
</el-tab-pane>

 这里是子页面userInfo.vue页面应用el-cascader控件部分代码;其核心就再@change事件里面。

//子页面使用控件部分代码    
<el-form-item  label="检测因素" prop="itemList">
      <el-cascader
        v-model="userData.itemList"
        placeholder="试试搜索"
        :options="riskList"
        :props="{ label: 'label', value: 'id', multiple: true  }"
        filterable @change="handleChangeCas"></el-cascader>
 </el-form-item>

验证必填代码:

data() {
   const validateOrg = (rule, value, callback) => {
      if (!this.userData.itemList.length) {
        callback(new Error('检测因素不能为空'))
      } else {
        callback()
      }
  }
 return {
   // 表单校验
   rulesData: {
    itemList: [
          { type:'array', required: true, validator: validateOrg }
    ],
   }
 }
}

 

handleChageCas方法代码:

 methods: {
    //刷新控件
    handleChangeCas(val){
      this.$forceUpdate()
    },
}

总结:最后发现因为引用页面,值没有被更新,需要手动更新(

this.$forceUpdate()

)后才能生效。如果引用子页面输入控件(el-input)/选择控件(el-select)也出现类似情况可以使用此方法再@input事件执行。

<el-form-item label="联系电话" prop="phonenumber">
      <el-input v-model="userData.phonenumber" maxlength="11" show-word-limit  @input="change($event)"/>
</el-form-item>
<el-form-item label="联系邮箱" prop="email">
      <el-input v-model="userData.email" @input="change($event)"/>
</el-form-item>
<el-form-item label="机构类型:" prop="organizationTypeAttr">
      <el-select v-model="userData.organizationTypeAttr" clearable multiple @input="change($event)">
        <el-option  v-for="dict in dict.type.organization_type"
                    :value="dict.value"
                    :label="dict.label"
                    :key="parseInt(dict.value)"></el-option>
      </el-select>
</el-form-item>
    //解决输入框无法输入
    change() {
      this.$forceUpdate()
    },

相关文章:

  • Qt中QApplication 类和uic、moc程序
  • Node.js调用DeepSeek Api 实现本地智能聊天的简单应用
  • DeepSeek R1生成图片总结(虽然本身是不能直接生成图片,但是可以想办法利用别的工具一起实现)
  • Linux入侵检查流程
  • 使用 Visual Studio Code (VS Code) 开发 Python 图形界面程序
  • 你认为如何理解“约定大于配置”?
  • CentOS 系统上安装 Anaconda3-2022.05-Linux-x86_64.sh linux安装python3.9
  • 缓存三大问题及其解决方案
  • Jieba分词算法应用
  • json-schema 的编辑器
  • DeepSeek图解10页PDF
  • SpringCloud - Seata 分布式事务
  • 登录弹窗效果
  • 基础网络详解4--HTTP CookieSession 思考 2
  • 差分及其性质不变算子移位算子
  • 深入探索C语言中的字符串处理函数:strstr与strtok
  • 磁盘与mysql的故事
  • 聊一聊FutureTask源码中体现的“自旋锁”思想
  • 【无线感知会议系列-22 】Vivisecting Mobility Management in 5G Cellular Networks
  • 类型通配符上限
  • 中国制造网外贸平台网址/搜索引擎seo关键词优化效果
  • 网站搜索引擎优化案例/广告传媒公司
  • 邢台柏乡县建设局网站/百度seo是啥意思
  • 福州营销型网站建设/青岛seo招聘
  • 莱芜金点子电子版报纸/seo的定义
  • 网站建设 php 企业网站/网页怎么做出来的