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端和手机端我们都可以达到我们想要的效果

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

相关推荐
心中无石马3 小时前
uniapp引入tailwindcss4.x
前端·css·uni-app
fix一个write十个3 小时前
【uniApp开发】微信小程序 web-view 内嵌 H5 跳转支付踩坑实录
微信小程序·uni-app
wuxianda10306 小时前
苹果App上架4.3a被拒解决方案汇报总结
ios·uni-app·objective-c·cocoa·苹果上架·4.3a
西洼工作室12 小时前
uniapp+vue3+python对接阿里云短信认证服务alibabacloud_dypnsapi20170525
python·阿里云·uni-app
wuxianda103013 小时前
苹果App上架4.3a问题3天解决方案汇报总结
开发语言·javascript·uni-app·ecmascript·ios上架·苹果上架
_pengliang13 小时前
uni-app 实现sse流式音频技术方案
uni-app·音视频
MY_TEUCK1 天前
【AI 应用】前端接口联调工程化:把 Swagger 接入沉淀成可复用 Skill
前端·人工智能·uni-app·状态模式
上架ipa2 天前
uniapp打包ios配置、申请证书、测试和上架综合教程
uni-app
00后程序员张2 天前
完整指南 iOS App上架到App Store的步骤详解
macos·ios·小程序·uni-app·objective-c·cocoa·iphone
hhzz2 天前
记录微信小程序tabbar不显示问题:uni-app Vue 3 自定义 tabBar 不渲染
vue.js·微信小程序·uni-app