Vue3+Ts封装input组件时遇到的问题

news2024/9/21 20:27:56

使用input事件监听输入框变化时,如果当前使用的输入法是中文,他也会触发input事件,正常来说,中文没有输入完毕是不用触发事件的。

控制台打印时发现:

那么我们应该怎么去规避这件事呢?

其实input还有几个事件:

  • compositionstart:事件在用户开始使用输入法输入时触发。
  • onCompositionUpdate:事件在用户正在使用输入法输入时触发
  • compositionend: 事件在用户完成使用输入法输入时触发

 我们可以建立一个全局变量

const isComposing = ref(false);

在handleCompositionStart和handleCompositionEnd的事件中更改这个全局变量

const handleCompositionStart = () => {
	isComposing.value = true;
};

const handleCompositionEnd = (event: Event) => {
	isComposing.value = false;
};

在input事件中判断是否是中文输入法输入中的状态

const input = (event: Event) => {
	if (isComposing.value) {
		return;
	}
	const value = (event.target as HTMLInputElement).value;
	emit("update:modelValue", value);
	emit("change", value); // 添加此行代码
};

最后在handleCompositionEnd事件中添加如下代码:

const handleCompositionEnd = (event: Event) => {
	isComposing.value = false;
	const value = (event.target as HTMLInputElement).value;
	emit("update:modelValue", value);
	emit("change", value);
};

最后即可解决这个问题!

最后附上我封装的input组件(若觉得组件功能不完善,可以自行扩展组件)

MyInput.vue

<template>
	<div class="input-wrapper" :class="{ 'is-focused': isFocused }">
		<span class="prefix">
			<slot name="prefix"></slot>
		</span>
		<input
			:type="type"
			@input="input"
			:placeholder="placeholder"
			:disabled="disabled"
			:readonly="readonly"
			:maxlength="maxlength"
			@focus="handleFocus"
			@blur="handleBlur"
			@compositionstart="handleCompositionStart"
			@compositionend="handleCompositionEnd"
		/>
		<span class="suffix">
			<slot name="suffix"></slot>
		</span>
	</div>
</template>

<script setup lang="ts">
import { ref } from "vue";

const isFocused = ref(false);
const isComposing = ref(false);

const props = defineProps<{
	type?: string;
	modelValue: string;
	placeholder?: string;
	disabled?: boolean;
	readonly?: boolean;
	maxlength?: number;
}>();

const handleFocus = () => {
	isFocused.value = true;
};

const handleBlur = () => {
	isFocused.value = false;
};

const emit = defineEmits<{
	(e: "update:modelValue", value: string): void;
	(e: "change", value: string): void;
}>();

// 监听是否是中文输入事件
const handleCompositionStart = () => {
	isComposing.value = true;
};

const handleCompositionEnd = (event: Event) => {
	isComposing.value = false;
	const value = (event.target as HTMLInputElement).value;
	emit("update:modelValue", value);
	emit("change", value);
};

const input = (event: Event) => {
	if (isComposing.value) {
		return;
	}
	const value = (event.target as HTMLInputElement).value;
	emit("update:modelValue", value);
	emit("change", value);
};
</script>

<style scoped>
.input-wrapper {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1px 11px;
	border-radius: 10px;
	box-shadow: 0 0 0 1px #b5b5b5 inset;
}
.input-wrapper.is-focused {
	box-shadow: 0 0 0 2px #2478f2 inset;
}
input {
	width: 100%;
	flex-grow: 1;
	padding: 0;
	outline: 0;
	border: none;
	background: 0 0;
	box-sizing: border-box;
	outline: 0;
	font-size: 14px;
	line-height: 30px;
}

input:disabled {
	background-color: #000000;
	cursor: not-allowed;
}

input[readonly] {
	background-color: #000000;
	cursor: default;
}
.prefix {
	margin-right: 8px;
}
.suffix {
	margin-left: 8px;
}
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2079072.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

从永远到永远-日语学习-て形用法及变形规律

て形用法及变形规律 0.前置知识1.常见用法1.请求某人做某事 「&#xff5e;てください」2.几个连续发生的动作 &#xff5e;て、&#xff5e;て、&#xff5e;て3.两个动作先后发生「てから」4. 表示许可 「てもいいです」5.表示禁止 「&#xff5e;てはいけません」6.「&#…

亚马逊新品如何获取评论,为店铺提高产品排名权重流量订单?测评

大多数消费者都会购买具有最佳评论和评级的产品。亚马逊评论是影响消费者决策的关键因素&#xff0c;卖家对评论的重视程度也非常之高&#xff0c;亚马逊卖家最常见的挑战之一是获得产品评论。 1.亚马逊Vine计划&#xff1a; 亚马逊Vine计划是亚马逊为品牌卖家提供的专属评论计…

猫咪浮毛如何清理?希喂、安德迈、范罗士宠物空气净化器功能实测

拥有一只属于自己的小猫咪&#xff0c;是一件非常幸福的事。美中不足的就是它掉毛&#xff0c;疯狂的掉毛&#xff0c;家里到处都是毛发散落的痕迹。和它亲近的时候&#xff0c;也会沾满一身毛&#xff0c;清理起来非常麻烦。特别是随着季节的转换&#xff0c;猫咪换毛季的到来…

使用IntelliJ IDEA将本地项目推送到远程Git

1&#xff0c;安装Git 打开 下载地址&#xff0c;下载Git安装包。根据引导程序&#xff0c;完成安装。 2&#xff0c;IntelliJ IDEA配置Git 打开IntelliJ IDEA&#xff0c;依次点击File>>Settings…>>Git&#xff0c;然后配置自己的Git的路径&#xff0c;然后点…

系统架构分析

一、速通一图流 二、系统架构功能、作用分析 1. Furion&#xff1a;框架核心层 功能&#xff1a;这是 Furion 框架的核心层&#xff0c;通常包含框架本身的基本功能和配置。这一层应该是比较稳定的&#xff0c;不应该包含业务逻辑&#xff0c;而是提供项目其他部分需要依赖的…

yolo7 自定义数据训练

数据打标labelimg 预定义标签 格式name label 数据集定义文件errimg.yaml train: /home/kean/works/yolov7/dataset/train.txt val: /home/kean/works/yolov7/dataset/val.txt # number of classes nc: 1 # class names names: ["error_dialog"] 数据定义文件train.…

【JS】使用MessageChannel实现深度克隆

前言 通常使用简便快捷的JSON 序列化与反序列化实现深克隆&#xff0c;也可以递归实现或者直接使用lodash。 但 JSON 序列化与反序列化 无法处理如下的循环引用&#xff1a; 实现 MessageChannel 内部使用了浏览器内置的结构化克隆算法&#xff0c;该算法可以在不同的浏览器上…

学习之在window上安装MySQL server 并连接到Navicat

一、下载 下载地址&#xff1a;https://www.mysql.com/ 二、安装 1、双击软件安装2、点击yes

【解析几何笔记】9. 向量的内积运算

9. 向量的内积运算 定义&#xff1a;有向量 α , β \pmb{\alpha},\pmb{\beta} α,β&#xff0c; α ⋅ β ∣ α ∣ ∣ β ∣ ⋅ cos ⁡ < α , β > \pmb{\alpha}\cdot\pmb{\beta}|\pmb{\alpha}||\pmb{\beta}|\cdot\cos<\pmb{\alpha},\pmb{\beta}> α⋅β∣α…

Commons Lang库中,StringUtils.isBlank()和StringUtils.isEmpty()区别

在Apache Commons Lang库中&#xff0c;StringUtils.isBlank()和StringUtils.isEmpty()方法都是用来判断字符串是否为空或者空白的。它们的主要区别在于处理空格的方式上。 StringUtils.isEmpty(String str): 这个方法会返回true当字符串为null或者长度为0时。也就是说&#xf…

自动化测试和性能测试面试题精选(含答案)

前言 今天分享软件测试工程师常见的面试题&#xff0c;主要来源于个人面试遇到的、网络搜集&#xff08;完善&#xff09;、工作日常讨论等&#xff0c;分为以下十个部分&#xff0c;供大家参考。如有错误的地方&#xff0c;欢迎指正。有更多的面试题或面试中遇到的坑&#xf…

javacv-ffmpeg ProcessBuilder实现对图片的旋转

javacv-ffmpeg ProcessBuilder实现对图片的旋转&#xff0c;最近需要处理很多图片&#xff0c;量有点多&#xff0c;所以不能一个一个去编辑旋转图片&#xff0c;所以写一个工具类&#xff0c;实现对图片的旋转 maven配置文件&#xff0c;加上对ffmpeg的依赖&#xff0c;由于f…

读论文《SHOW-O》8.22发布的贼强的大模型多模态理解和生成解决方案

全名&#xff1a;Show-o: One Single Transformer to Unify Multimodal Understanding and Generation 8月22发表的&#xff0c;一个名为Show-o的统一变换器&#xff08;transformer&#xff09; 论文地址&#xff1a;2408.12528v2 (arxiv.org) 项目地址&#xff1a;GitHub …

开放式耳机有哪些优点?开放式耳机推荐

开放式耳机&#xff0c;相较于封闭式耳机&#xff0c;以其独特的声学设计和佩戴体验&#xff0c;为用户带来了更加自然流畅的听觉享受。以下是开放式耳机几个显著优点&#xff1a; 宽广的音场与深度&#xff1a;开放式耳机最大的魅力之一在于它们能够模拟出更加宽广和深邃的音场…

P1533 可怜的狗狗

*原题链接* 题意&#xff1a;m次询问区间[l,r]中第k大的数&#xff0c;各询问区间互不相交。 这道题的解法可谓是八仙过海&#xff0c;而我看到询问区间[l,r]中第k大的数&#xff0c;直接就想到了权值线段树(本蒟蒻不会更高级的数据结构了)&#xff0c;权值线段树维护区间中数…

Python编写BC260Y TCP数据收发压力测试脚本

Python编写BC260Y TCP数据收发压力测试脚本 使用BC260Y的TCP AT命令发送数据时&#xff0c;能够在数据中带有’\r\n’&#xff08;回车换行&#xff09;&#xff0c;而其他模组会将’\r\n’当做AT命令处理的结束符&#xff0c;例如EC800E&#xff0c;为了验证TCP数据中带有’\r…

Zoom iOS 转录例子

一、在zoom marketplace创建通用app&#xff0c;zoom-recall 详见Zoom会议机器人转写例子-CSDN博客 二、mac下按照Xcode&#xff0c;创建APP项目meetingbot4ios 三、本实用的SDK为MobileRTC&#xff0c;即Meeting SDK的iOS版本 四、依赖如下&#xff1a; MobileRTC和Crypto…

Swift-UITableView列表动态设置高度,根据不同的内容长度,设置heightForRowAt

此篇文章主要阐述如何利用swift语言&#xff0c;实现返回内容不同长度文本的高度&#xff0c;比如第一个列表文字1行&#xff0c;只需要50像素高度&#xff0c;第二个列表文字超出了1行&#xff0c;如2行&#xff0c;那么就自动调整这个单元文本的高度&#xff1b; 用MVC实现&…

给房子“养老”,你准备好了吗?

文&#xff5c;琥珀食酒社 作者 | 积溪 真崩不住了啊 一觉醒来 朋友圈被房屋养老金刷屏了 有人说买房如买“爹”&#xff0c;真的好费钱 有的说咱自己的养老还没着落呢 未来还得给房子养老&#xff1f; 当然&#xff0c;这事已经被辟谣了 说公共账户不需要咱老百姓额外…

力扣经典题目之->相同的树(递归判断两颗二叉树是否相同)

一&#xff1a;题目 二&#xff1a;代码 三&#xff1a;递归展开 第一种模型&#xff1a; 递归展开图&#xff1a; 左&#xff1a; 右&#xff1a; 第二种模型及其递归展开图&#xff1a; 解释&#xff1a; 递归思路即&#xff1a;根相同&#xff0c;左子树相同&#xff0c;…