在光标处插入文字

文章介绍了在Vue.js环境中,如何处理点击span标签后将内容插入到el-inputtextarea的光标位置。通过v-for循环获取span内容,并使用insertTextAtCursor方法实现动态插入,同时处理了括号等特殊字符的情况,确保光标位置正确。
摘要由CSDN通过智能技术生成

点击span标签,使span标签的内容插入到input光标处

           <el-input
              ref="formulaTextareaRef"
              v-model="expression"
              type="textarea"
              placeholder="示例:(月度设备可利用率-98%)/0.1*10"
              autosize
            />

span内容通过for循环获取

			<span
			  v-for="op in visibleOperators"
			  :key="op.value"
			  :value="op.value"
			  :label="op.value"
			  @click="insertTextAtCursor(op.value)"
			  >{{ op.value }}</span>

光标处插入文字


    async insertTextAtCursor(value) {
      // 获取input标签
      const textarea = this.$refs.formulaTextareaRef.$el.children[0]
      const startPos = textarea.selectionStart
      const endPos = textarea.selectionEnd
      this.expression = textarea.value.slice(0, startPos) + value + textarea.value.slice(endPos, textarea.value.length)
      await nextTick()
      textarea.focus()
      if (value.slice(-2) === '()') {
        textarea.setSelectionRange(startPos + value.length - 1, startPos + value.length - 1)
      } else {
        textarea.setSelectionRange(startPos + value.length, startPos + value.length)
      }
    },
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值