uniapp中搜索栏中input的@blur和搜索按钮的@click事件存在都执行的问题

blur与click的冲突问题

blur事件:当元素失去焦点时触发blur事件;blur和focus事件不会冒泡,其他表单事件都可以

click事件:当点击元素时触发click事件;所有元素都有此事件,会产生冒泡。

解决方案一:

使用setTimeout将blur事件延迟进行,但会产生一种停顿感

解决方案二:

将click事件换成mousedown事件,这样事件的执行顺序就变成mousedown > mouseup > click

案例:

事件触发的先后问

这是一个简单的手机搜索页面

当我们输入搜索文字后, 我设置一个blur(失去焦点事件)

复制代码
<view class="header-search">
    <view class="search-input">
		<image src="/static/images/icon_search_gray.png" mode="widthFix"></image>
		<input v-model="search" placeholder="药品名称/药品id" @blur="blurHandler" ref="searchInput">
	</view>
	<view class="search-btn" @tap="searchHandler">搜索</view>
</view>

然后点击搜索, 进行判断

这是一个非常简单的流程

在JavaScript中 事件的触发算的上是一种异步回调

而这种异步回调触发的先后 在pc端和小程序端出现了明显的差别

在 pc 端我们输入完内容点击确认 先执行了blur事件 后执行了onclick事件

而在手机端 先执行了onclick事件 后执行了blur事件**

复制代码
<view class="search-btn" @mousedown="searchHandler">搜索</view>

这样在pc端和手机端我们都可以达到我们想要的效果

总结:小程序开发,我们测试时一定要注意在手机上测试,不要觉得电脑测试下成功了就提交了,很容易造成意想不到的问题。

相关推荐
2501_916007479 小时前
iOS 混淆与团队协作,研发、安全、运维、测试如何在加固流程中高效配合(iOS 混淆、ipa 加固、协作治理)
android·ios·小程序·https·uni-app·iphone·webview
2501_9160088915 小时前
iOS 不上架怎么安装?多种应用分发方式解析,ipa 文件安装、企业签名、Ad Hoc 与 TestFlight 实战经验
android·macos·ios·小程序·uni-app·cocoa·iphone
卷Java16 小时前
uni-app 模板语法修复说明
java·数据库·spring boot·uni-app·mybatis
iOS阿玮17 小时前
国庆假期 iOS 开发者守好邮箱 “防线”,严防恶意投诉避免产品下架
uni-app·app·apple
00后程序员张18 小时前
iOS App 混淆实战,在源码不可用情况下的成品加固与测试流程
android·ios·小程序·https·uni-app·iphone·webview
isixe19 小时前
Uniapp IOS 和 Android 下的文件写入用户目录
前端·uni-app
2501_9160137421 小时前
iOS 26 设备文件管理实战指南,文件访问、沙盒导出、系统变更与 uni-app 项目适配
android·ios·小程序·uni-app·cocoa·iphone·webview
2501_915921431 天前
前端用什么开发工具?常用前端开发工具推荐与不同阶段的选择指南
android·前端·ios·小程序·uni-app·iphone·webview
2501_916007471 天前
iOS 26 能耗检测实战指南,升级后电池掉速是否正常 + KeyMob + Instruments 实时监控 + 优化策略
android·macos·ios·小程序·uni-app·cocoa·iphone
2501_916013741 天前
苹果上架 App 全流程详解,iOS 应用发布步骤、ipa 文件上传工具、TestFlight 测试与 App Store 审核经验
android·ios·小程序·https·uni-app·iphone·webview