Vue使用Alt + Enter键替代Enter键回车,enter发送消息

因为要做一个聊天输入框,所以遇到了这个问题,因为发送消息比回车换行要常用,所以用enter键发送消息,alt+enter键回车换行

首先先给文本输入框加两个键盘事件

<textarea v-model="message" ref="textDom @keydown.enter="handleEnter" @keydown.alt.enter="handleAltEnter"></textarea>
// 非原生组件要加上.native  示例 @keyup.enter.native (非原生组件才需要)注意不能使用keyup,需要使用keydown

然后你会发现当你使用alt+enter组合键时,你仍然会触发enter事件,这当然不符合我的要求,所以我的做法是,在使用alt+enter键时,阻塞enter键的触发事件

    handleAltEnter() {
      let textDom = this.$refs.textDom
      let startPos = textDom.selectionStart
      let endPos = textDom.selectionEnd // 获取开始光标和结束光标
      // 把输入的换行符插入到你光标的位置
      this.message = this.message.substring(0, startPos) + '\n' + this.message.substring(endPos, this.message
        .length)
      this.isAltEnter = true // 设置阻塞状态,因为enter事件仍然会触发
    },
   handleEnter(e) {
      e.preventDefault() // 阻止默认行为
      setTimeout(() => {
        if (this.isAltEnter) { //如果为阻塞状态就反转状态
          this.isAltEnter = false
        } else { //如果不是就执行发送
          this.sendMessage()
        }
      }, 100)
    },

如果有更好的解决办法,希望能交流一下哦!

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Vue3中,你可以通过使用`@keydown.enter.prevent`监听器来实现回车替代Tab的功能。具体步骤如下: 1. 在Vue3项目中创建一个全局的指令,用于处理回车替代Tab的功能: ``` // enter-tab.js export default { mounted(el) { el.addEventListener('keydown', (e) => { if (e.key === 'Enter') { e.preventDefault(); const formElements = [...el.querySelectorAll( 'button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])' )].sort((a, b) => a.tabIndex - b.tabIndex); const index = formElements.indexOf(e.target); formElements[index + 1]?.focus(); } }); } }; ``` 在上面的代码中,我们定义了一个名为`enter-tab`的指令,它会在元素挂载时添加一个`keydown`事件监听器。当用户按下回车时,它会阻止默认的行为,然后获取页面上所有可聚焦的元素,并按照`tabIndex`属性排序。接着,它会找到当前聚焦元素在排序后的数组中的位置,然后将焦点移动到下一个可聚焦元素。 2. 在Vue3项目中,你需要全局注册上面定义的指令: ``` // main.js import { createApp } from 'vue' import enterTab from './directives/enter-tab.js' import App from './App.vue' const app = createApp(App) app.directive('enter-tab', enterTab) app.mount('#app') ``` 在上面的代码中,我们将`enter-tab`指令全局注册到Vue3应用中。 3. 在你的Vue3组件中,你可以将`v-enter-tab`指令添加到需要替代Tab的元素上: ``` <template> <div> <input type="text" v-enter-tab> <button v-enter-tab>Submit</button> </div> </template> ``` 在上面的代码中,我们将`v-enter-tab`指令添加到了文本框和按钮上,这样用户在按下回车时,焦点将会被移动到下一个可聚焦元素。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值