vue3_input输入框,Ctrl+Enter键换行,Enter键发送信息

1.Ctrl+Enter换行,Enter键发送信息

<template>
  <div class="line">
    <span>输入框:</span>
    <el-input
      ref="textInput"
      type="textarea"
      v-model="inputVal"
      @keyup.ctrl.enter.native="lineBreak"
      @keydown.enter.exact.native="submit" //.exact精确修饰符,只有单独点击enter键才生效,点击enter加其他任意键不生效
    >
    </el-input>
  </div>
</template>

<script setup lang="ts">
import { ref } from "vue";
const inputVal = ref();
const textInput = ref();
function lineBreak() {
  const textarea = textInput.value.textarea; //注意此处获取dom
  const start = textarea.selectionStart;
  const end = textarea.selectionEnd;
  const value = textarea.value;
  const newValue = value.substring(0, start) + "\n" + value.substring(end);
  textarea.value = newValue;
  textarea.selectionStart = textarea.selectionEnd = start + 1;
}
function submit(e: any) {
  e.preventDefault();
}
</script>

<style scoped lang="less">
.line{
    display: flex;
    margin:10px;
    .el-textarea{
        width:300px
    }
}
</style>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值