回车发送功能(区分输入法回车和普通回车以及shift+回车换行功能)

需求

用户在输入框内输入完成后,点击回车键或者发送按钮发送信息,通过shift+回车键换行。

难点

如果简单的以code === 'Enter'作为发送事件的条件,在中文输入拼音阶段,直接点击回车仍会触发发送事件。

思路

  1. 监听输入框的键盘事件
  2. 判断按键为回车键
    1. 当不是中文输入回车且没有同时按 'shift'键时,触发发送事件

一、区分输入法回车

我们首先要了解一下键盘事件,键盘事件有哪些?

keydown/keyup

当我们按下'enter'键事件返回以下内容

当我们在中文输入过程中(输入拼音但未选择的时候)按下'enter'键

此时我们应该发现了这个关键的keyprocess 代表'The Process key. Instructs the IME to process the conversion.'(过程密钥。指示输入法处理转换。),由此我们可以通过key === 'Process'来区分普通'enter'和输入法时'enter'。

二、如何确定 shift + 回车

到现在我们已经可以区分普通回车和输入法回车,哪如何shift+回车换行呢?

仍然是回车时间返回的参数,当我同时按下shift+回车,返回以下内容,会返回两个键的信息,一个是shift键,一个是enter键的信息,我们看enter键的信息也就是第二个,注意shiftKey,它表示事件触发时 shift 键是 (true) 否 (false) 按下。

由此我们可以知道通过shiftKey可以判断回车时是否同时按shift键。

注意:

到现在我们已经可以实现需求了,但是还有一个坑,键盘事件需要选择keydown而不是keyupkeyup事件内去阻止浏览器默认事件是不行的,也就是说 enter 依旧换行。

代码示例为vue + element示例,其他框架思想一样暂且不表。

xml 复制代码
<template>
  <div>
      <el-input
        v-model="content"
        @keydown="contentKeyDown"></el-input>
  </div>
<template>

<script setup>
  import { ref } from "vue";
  const content = ref('')
  // 按键事件,enter输入
  const contentKeyDown = (e) => {
  	const { code, key, shiftKey } = e
    if (code === 'Enter') {
      // key === Process 输入法按键
      if (key !== 'Process' && !shiftKey) { // shift + enter 换行
        e.preventDefault() // 阻止浏览器默认时间,不换行
        sendMsg(content.value) // 发送事件
      }
    }
	}
  // 发送事件
  const sendMsg = () => {
    // ...
  }
</script>

完结。

参考:

MND-KeyboardEvent

MDN-keyvalues

相关推荐
Alan Lu Pop16 分钟前
前端开发助手
前端·智能体
程序员鱼皮17 分钟前
我用 GitHub 仓库养 AI 龙虾,自动开发上线项目!保姆级教程
前端·人工智能·ai·程序员·github·编程·ai编程
276695829230 分钟前
京东随机变速滑块拼图验证码识别(京东E卡)
java·服务器·前端·python·京东滑块·京东变速滑块·京东e卡绑卡
এ慕ོ冬℘゜1 小时前
手写生产级 jQuery Toast 轻量提示组件|零插件依赖、动画流畅、极简高
前端·javascript·jquery
Oneslide1 小时前
UI设计-企业OA风格
前端
程序员海军1 小时前
我用了 8 个月 Codex CLI,总结出这套 AI 编程工作流
前端·后端·aigc
大家的林语冰1 小时前
Express 团队官宣:全新网站正式上线,Logo 重做,支持两个主版本文档无缝切换!
javascript·node.js·express
এ慕ོ冬℘゜2 小时前
手写一款高兼容、零BUG图片预览组件|前端
前端·bug
铁链鞭策大师2 小时前
javaEE之多线程(2)
java·前端·java-ee
KaMeidebaby2 小时前
卡梅德生物技术快报|生信实操:ChIP 染色质免疫共沉淀技术流程、短板与替代方案详解
前端·人工智能·物联网·百度·新浪微博