SakuraCaslana 2022-09-22 15:58 采纳率: 50%
浏览 29
已结题

element-ui使用问题

使用element-ui 动态编辑标签 用的它提供的回调,将input切换为tag,触发条件是失去焦点或回车,失焦没有问题,回车时会执行根本不会执行的语句

//自动获取焦点
    autoFocus() {
      this.$nextTick(() => {
        this.$refs.saveTagInput.$refs.input.focus()
      })
    },
    //点击添加按钮
    showInput(row) {
      this.$set(row, 'inputVisible', true)
      this.$set(row, 'inputValue', '')
      this.autoFocus()
    },
 handleInputConfirm(row) {
      const { baseSaleAttrId, inputValue } = row
      //判断属性值是否重复
      let result = row.spuSaleAttrValueList.every((item) => {
        return item.saleAttrValueName != inputValue
      })
      //判断输入框是否为空
      if (inputValue.trim() == '') {
        this.$message({ message: '请输入属性值', type: 'warning' })
      }
      //判断是否重复
      else if (!result) {
        this.$message.error('重复的属性值')//使用回车可以执行语句,但是!result=false也就是没有输入重复的值,且跳过了retrun,可以将代码执行到底
        this.autoFocus()
        return
      }
      //保存输入框
      else {
        let newAttrValue = { baseSaleAttrId, saleAttrValueName: inputValue }
        row.spuSaleAttrValueList.push(newAttrValue)
      }
      //输入框状态改变
      row.inputVisible = false
    },

img

  • 写回答

3条回答 默认 最新

  • SakuraCaslana 2022-09-22 16:11
    关注

    感谢回答,我发现问题了,我是把keyup和blur回调写成了一个,在我按下enter键的时候,会先触发了blur,再触发enter,回调执行了两次,第一次就将数据添加到列表,第二次执行提示重复,且ref失效了

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 9月30日
  • 已采纳回答 9月22日
  • 创建了问题 9月22日

悬赏问题

  • ¥15 对于知识的学以致用的解释
  • ¥50 三种调度算法报错 有实例
  • ¥15 关于#python#的问题,请各位专家解答!
  • ¥200 询问:python实现大地主题正反算的程序设计,有偿
  • ¥15 smptlib使用465端口发送邮件失败
  • ¥200 总是报错,能帮助用python实现程序实现高斯正反算吗?有偿
  • ¥15 对于squad数据集的基于bert模型的微调
  • ¥15 为什么我运行这个网络会出现以下报错?CRNN神经网络
  • ¥20 steam下载游戏占用内存
  • ¥15 CST保存项目时失败