在iphone12或者13pro上的input和textarea上弹出uni-popup弹出层
- 发布:2021-12-30 17:56
- 更新:2023-07-20 13:53
- 阅读:1983
产品分类: uniapp/小程序/微信
PC开发环境操作系统: Windows
PC开发环境操作系统版本号: win10
HBuilderX类型: 正式
HBuilderX版本号: 3.3.5
第三方开发者工具版本号: 1.05.2110290
基础库版本号: 2.21.2
项目创建方式: HBuilderX
操作步骤:
预期结果:
uni-popup弹出层不能看见和点击input和textarea
uni-popup弹出层不能看见和点击input和textarea
实际结果:
uni-popup弹出层能看见和点击input和textarea
uni-popup弹出层能看见和点击input和textarea
bug描述:
iphone12或者13pro上点击uni-popup 弹出层会穿透到下面的input和textarea上调起输入框,安卓没出现这个问题
最佳回复
用示例代码hello uni-app能出现你的问题吗?
不能的话你需要排查出来具体你哪个页面,甚至哪一行导致的。
找出来具体原因后提供一个能复现你描述的bug的最小化demo,让我们及时定位问题,及时修复。
【bug优先处理规则】https://ask.dcloud.net.cn/article/38139
-
回复 w***@126.com: 看你录屏后几次弹框打开是正常的,刚进来的时候是操作了什么吗?出现弹框时有遮罩层应该是无法再点击底下的输入框的
2021-12-31 15:46
-
w***@126.com (作者)
回复 DCloud_UNI_Anne: 其实只是看上去正常,点击还是会穿透到input下面去,你看视频里面老是弹出输入框就是因为我点击了弹出框的取消按钮穿透到下面去了,刚我试了iphone XR也会穿透
2021-12-31 16:06
w***@126.com (作者)
<template>
<view class="container">
<uni-card is-full :is-shadow="false">
<text class="uni-h6">弹出层组件用于弹出一个覆盖到页面上的内容,使用场景如:底部弹出分享弹窗、页面插屏广告等。</text>
</uni-card>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<input class="test" type="text" value="" placeholder="我是输入框"/>
<uni-section title="对话框示例" type="line" class="hideOnPc">
<view class="example-body box">
<button class="button popup-success" @click="dialogToggle('success')"><text
class="button-text success-text">成功</text></button>
<button class="button popup-error" @click="dialogToggle('error')"><text
class="button-text error-text">失败</text></button>
<button class="button popup-warn" @click="dialogToggle('warn')"><text
class="button-text warn-text">警告</text></button>
<button class="button popup-info" @click="dialogToggle('info')"><text
class="button-text info-text">信息</text></button>
</view>
</uni-section>
<input type="text" value="" placeholder="我是输入框"/>
<uni-section title="输入框示例" type="line" padding>
<view class="dialog-box">
<text class="dialog-text">输入内容:{{ value }}</text>
</view>
<button class="button" type="primary" @click="inputDialogToggle"><text
class="button-text">输入对话框</text></button>
</uni-section>
<uni-section title="底部分享示例" type="line" padding>
<button class="button" type="primary" @click="shareToggle"><text class="button-text">分享模版示例</text></button>
</uni-section>
<view>
<!-- 普通弹窗 -->
<uni-popup ref="popup" background-color="#fff" @change="change">
<view class="popup-content" :class="{ 'popup-height': type === 'left' || type === 'right' }"><text
class="text">popup 内容</text></view>
</uni-popup>
</view>
<view>
<!-- 提示信息弹窗 -->
<uni-popup ref="message" type="message">
<uni-popup-message :type="msgType" :message="messageText" :duration="2000"></uni-popup-message>
</uni-popup>
</view>
<view>
<!-- 提示窗示例 -->
<uni-popup ref="alertDialog" type="dialog">
<uni-popup-dialog :type="msgType" title="通知" content="欢迎使用 uni-popup!" @confirm="dialogConfirm"
@close="dialogClose"></uni-popup-dialog>
</uni-popup>
</view>
<view>
<!-- 输入框示例 -->
<uni-popup ref="inputDialog" type="dialog">
<uni-popup-dialog ref="inputClose" mode="input" title="输入内容" value="对话框预置提示内容!"
placeholder="请输入内容" @confirm="dialogInputConfirm"></uni-popup-dialog>
</uni-popup>
</view>
<view>
<!-- 分享示例 -->
<uni-popup ref="share" type="share">
<uni-popup-share></uni-popup-share>
</uni-popup>
</view>
</view>
</template>
<script>
export default {
data() {
return {
type: 'center',
msgType: 'success',
messageText: '这是一条成功提示',
value: ''
}
},
onReady() {},
methods: {
change(e) {
console.log('当前模式:' + e.type + ',状态:' + e.show);
},
toggle(type) {
this.type = type
// open 方法传入参数 等同在 uni-popup 组件上绑定 type属性
this.$refs.popup.open(type)
},
messageToggle(type) {
this.msgType = type
this.messageText = `这是一条${type}消息提示`
this.$refs.message.open()
},
dialogToggle(type) {
this.msgType = type
this.$refs.alertDialog.open()
},
dialogConfirm() {
console.log('点击确认')
this.messageText = `点击确认了 ${this.msgType} 窗口`
this.$refs.message.open()
},
inputDialogToggle() {
this.$refs.inputDialog.open()
},
dialogClose() {
console.log('点击关闭')
},
dialogInputConfirm(val) {
uni.showLoading({
title: '3秒后会关闭'
})
setTimeout(() => {
uni.hideLoading()
console.log(val)
this.value = val
// 关闭窗口后,恢复默认内容
this.$refs.inputDialog.close()
}, 3000)
},
shareToggle() {
this.$refs.share.open()
}
}
}
</script>
<style lang="scss">
.test{
text-align: center;
width: 100%;
}
@mixin flex {
/* #ifndef APP-NVUE */
display: flex;
/* #endif */
flex-direction: row;
}
@mixin height {
/* #ifndef APP-NVUE */
height: 100%;
/* #endif */
/* #ifdef APP-NVUE */
flex: 1;
/* #endif */
}
.box {
@include flex;
}
.button {
@include flex;
align-items: center;
justify-content: center;
flex: 1;
height: 35px;
margin: 0 5px;
border-radius: 5px;
}
.example-body {
background-color: #fff;
padding: 10px 0;
}
.button-text {
color: #fff;
font-size: 12px;
}
.popup-content {
@include flex;
align-items: center;
justify-content: center;
padding: 15px;
height: 50px;
background-color: #fff;
}
.popup-height {
@include height;
width: 200px;
}
.text {
font-size: 12px;
color: #333;
}
.popup-success {
color: #fff;
background-color: #e1f3d8;
}
.popup-warn {
color: #fff;
background-color: #faecd8;
}
.popup-error {
color: #fff;
background-color: #fde2e2;
}
.popup-info {
color: #fff;
background-color: #f2f6fc;
}
.success-text {
color: #09bb07;
}
.warn-text {
color: #e6a23c;
}
.error-text {
color: #f56c6c;
}
.info-text {
color: #909399;
}
.dialog,
.share {
/* #ifndef APP-NVUE */
display: flex;
/* #endif */
flex-direction: column;
}
.dialog-box {
padding: 10px;
}
.dialog .button,
.share .button {
/* #ifndef APP-NVUE */
width: 100%;
/* #endif */
margin: 0;
margin-top: 10px;
padding: 3px 0;
flex: 1;
}
.dialog-text {
font-size: 14px;
color: #333;
}
</style>