vue element 编辑下拉框el-select不能回显的问题

本人的需求是点击表格里面的编辑按钮,把数据回显到弹窗内,其他的都能回显,但是就下拉框不能正常的回显
本人后端人员,有不对的地方,勿喷
vue element 编辑下拉框el-select不能回显的问题_第1张图片
vue element 编辑下拉框el-select不能回显的问题_第2张图片
这是因为点击编辑,收集到下拉框的value是一个数字导致的,传值应该是 ‘1’ 而不是 1
解决办法一:,给弹窗子组件传参的时候,单独给下拉框转下字符串格式

  methods: {
    handleEdit(index, row) {
      this.$refs.UrlDiaLog.form = row //row 是收集到的所在行的数据,但是里面下拉框的值是数字,而不是字符串
      this.$refs.UrlDiaLog.form.is_better = row.is_better.toString() //可以在这里单独toString()下,
      																//然后再重新传给弹窗子组件,下拉框就能正常回显
      this.$refs.UrlDiaLog.form.url_type = row.url_type.toString()
      this.$refs.UrlDiaLog.dialogFormVisible = true;
    },

解决办法二:给下拉框的v-model 写个计算属性函数

<el-form-item label="推荐" :label-width="formLabelWidth">
          <el-select v-model="isBetterToStr" style="width: 100%" placeholder="是否推荐">
            <el-option label="" value="0">el-option>
            <el-option label="" value="1">el-option>
          el-select>
        el-form-item>
        <el-form-item label="类型" :label-width="formLabelWidth">
          <el-select v-model="urlTypeToStr" style="width: 100%" placeholder="请选择类型">
            <el-option label="电影" value="1">el-option>
            <el-option label="音乐读物" value="2">el-option>
            <el-option label="书籍小说" value="3">el-option>
            <el-option label="软件工具" value="4">el-option>
            <el-option label="开发设计" value="5">el-option>
            <el-option label="学习教育" value="6">el-option>
          el-select>
        el-form-item>
      el-form>
  computed: {
    urlTypeToStr() {
      return this.form.url_type.toString()
    },
    isBetterToStr() {
      return this.form.is_better.toString()
    }
  }

解决办法三:不写办法二里面的计算属性函数,直接在v-model里面toString(),但是这不符合规范,也能实现,不过估计要关掉ESLint
vue element 编辑下拉框el-select不能回显的问题_第3张图片
会有ESLint提示:

ESLint: 'v-model' directives require the attribute value which is valid as LHS.(vue/valid-v-model)

大致意思是:v-model的值必须是一个数据变量,而不是一个条件值或计算值

你可能感兴趣的:(vue.js,javascript,前端)