<template>
<view class="main">
<view class="mobile layout-flex-acjs">
<input class="input" type="number" placeholder="请输入乘车人手机号" placeholder-style="color: #b7becc" maxlength="11"
:focus="mobileFocus" v-model="mobile" @focus="mobileFocus = true" @blur="mobileFocus = false"
v-if="mobileFocus || mobile" />
<text v-else class="input" @tap="tapMobile"> 请输入乘车人手机号 </text>
<view class="image" @tap="clearMobile" v-if="mobileFocus && mobile">
<image src="https://tx-t3propublic.t3go.cn/t3-admin/1446319048521506850" />
</view>
</view>
<view class="record">
<view class="record-h layout-flex-acjs" @tap="toPassengerHistory">
<text>历史乘车人</text>
<view class="image">
<image src="https://tx-t3propublic.t3go.cn/t3-admin/1446312561728389153" />
</view>
</view>
</view>
</view>
</template>
<script>
export default {
data() {
return {
mobile: '',
mobileFocus: false, // 号码输入框聚焦
};
},
methods: {
tapMobile() {
this.mobileFocus = true;
},
clearMobile(e) {
console.log('xxx-clearMobile', e);
this.mobile = '';
},
toPassengerHistory(e) {
console.log('xxx-toPassengerHistory', e);
},
},
};
</script>
<style lang="less" scoped>
.layout-flex {
display: flex;
&-ac {
display: flex;
align-items: center;
}
&-acjc {
display: flex;
align-items: center;
justify-content: center;
}
&-acjs {
display: flex;
align-items: center;
justify-content: space-between;
}
}
.main {
padding-top: 48rpx;
margin: 0 auto;
width: 702rpx;
min-height: 208rpx;
background: #ffffff;
box-shadow: 0px 16rpx 24rpx 0px rgba(49, 56, 84, 0.08);
border-radius: 24rpx;
box-sizing: border-box;
.mobile {
padding: 26rpx 4rpx 26rpx 24rpx;
margin: 0 auto;
width: 654rpx;
height: 112rpx;
background: #f7f8fc;
// box-shadow: 0px 2rpx 6rpx 0px rgba(49, 56, 84, 0.03);
border-radius: 16rpx;
box-sizing: border-box;
.input {
flex: 1;
height: 60rpx;
font-size: 44rpx;
font-family: PingFangSC-Medium, PingFang SC;
font-weight: 500;
color: #02102a;
line-height: 60rpx;
caret-color: #ff8533;
}
.image {
padding: 20rpx;
width: 44rpx;
height: 44rpx;
image {
width: 44rpx;
height: 44rpx;
}
}
}
.record {
position: relative;
padding: 32rpx 0 40rpx;
&-h {
padding: 0 48rpx;
text {
font-size: 24rpx;
font-family: PingFangSC-Regular, PingFang SC;
font-weight: 400;
color: #747881;
line-height: 34rpx;
}
.image {
image {
width: 24rpx;
height: 24rpx;
}
}
}
&-l {
padding: 0 16rpx;
box-sizing: border-box;
margin-top: 24rpx;
height: 56rpx;
white-space: nowrap;
}
&-i {
display: inline-block;
margin-right: 16rpx;
padding: 12rpx 24rpx 10rpx;
height: 56rpx;
background: rgba(255, 231, 214, 0.3);
border-radius: 8rpx;
border: 2rpx solid rgba(255, 133, 51, 0.5);
box-sizing: border-box;
font-size: 24rpx;
font-family: PingFangSC-Regular, PingFang SC;
font-weight: 400;
color: #996220;
line-height: 34rpx;
&:first-child {
margin-left: 32rpx;
}
&:last-child {
margin-right: 32rpx;
}
}
.mask {
position: absolute;
top: 86rpx;
width: 72rpx;
height: 64rpx;
&-1 {
left: 0;
background: linear-gradient(90deg, #ffffff 0%, rgba(255, 255, 255, 0) 100%);
}
&-2 {
right: 0;
background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, #ffffff 100%);
}
}
}
}
</style>
- 发布:2024-09-26 16:34
- 更新:2024-10-15 19:49
- 阅读:383
产品分类: uniapp/小程序/微信
PC开发环境操作系统: Mac
PC开发环境操作系统版本号: macOS 15.0 (24A335)
HBuilderX类型: 正式
HBuilderX版本号: 4.28
第三方开发者工具版本号: RC 1.06.2409131
基础库版本号: 3.6.0
项目创建方式: HBuilderX
示例代码:
操作步骤:
输入手机号,点击清除按钮
输入手机号,点击清除按钮
预期结果:
输入手机号,点击清除按钮,清除手机号
输入手机号,点击清除按钮,清除手机号
实际结果:
输入手机号,点击清除按钮,触发了下面历史乘车人处绑定的点击事件。
输入手机号,点击清除按钮,触发了下面历史乘车人处绑定的点击事件。
bug描述:
是 vue3 微信小程序 ! 用 HBuilderX 和 Cli 都试了,都有这个问题!
输入手机号后,清除按钮(具有v-if的)上绑定的点击事件,是清除手机号的。但是触发了下面历史乘车人处绑定的点击事件。
下个版本修复,目前可以用 v-show 替换 v-if 来临时解决这个问题
-
在你的工程,你这边同时绑定了blur 事件和click事件。点击的时候,先后触发blur 事件 和 click事件,blur先触发。 blur触发时更新了事件绑定逻辑,把click绑定的事件替换了导致的bug(下个版本修复)。
一般来讲小程序端,这个bug触发条件也比较苛刻,需要同时连续触发两个事件且触发的事件影响v-if的标签,且v-if上面也绑定对应的事件。 所以影响范围较小
2024-10-09 15:06
-
1***@qq.com (作者)
回复 BFC: 我不太理解为什么click绑定的事件会被替换。
我发现uni-app在vue3版本里好像把事件当成变量去渲染了,导致一个事件在AppData、WXML里会变化更新。我感觉并不是同时绑定多个事件的问题。
私信讲的那个例子是子组件向父组件 emit 事件,在老版本正常,但是新版本异常。2024-10-09 15:16
DCloud_UNI_OttoJi - 日常回复 uni-app/x 问题,如果艾特我没看到,请主动私信
如果发版后仍有问题,请艾特我来跟进。github 上 issues 先关闭了,有进展会在这里进行更新