uniapp小程序中给web-view页面添加授权弹窗(使用cover-view组件覆盖实现该功能)
效果图:
web-view是承载网页的容器。会自动铺满整个小程序页面,个人类型的小程序暂不支持使用。
再看下面一个提示:
每个页面只能有一个 web-view,web-view 会自动铺满整个页面,并覆盖其他组件。
也就是说,小程序中使用web-view打开网页,在页面上写的其它组件会直接被网页给覆盖住
需求:在web-view页面添加弹窗
刚好有一个组件cover-view可以覆盖web-view
cover-view覆盖在原生组件上的文本视图。
app-vue和小程序框架,渲染引擎是webview的。但为了优化体验,部分组件如map、video、textarea、canvas通过原生控件实现,原生组件层级高于前端组件(类似flash层级高于div)。为了能正常覆盖原生组件,设计了cover-view。
cover-view功能描述:
可覆盖的原生组件包括 map、video、canvas、camera、live-player、live-pusher、web-view
cover-view只支持嵌套 cover-view、cover-image,可在 cover-view 中使用 button。组件属性的长度单位默认为px,2.4.0起支持传入单位(rpx/px)。
也就是在cover-view中只能使用cover-view、cover-image、button三个组件
代码示例:
注意:checkbox按钮是图片代替的,因为不能使用checkbox组件
本服务将由{{corporateName}}提供,南洋商业银行(中国)将在您办理以下业务时将您的对应信息提供给该公司用于下述目的: 购买商品 手机号码:用于识别客户及查询订单 {{corporateName}}服务热线{{phoneNum}},相关商品和服务(包括售后)均由该公司负责。 我已阅读并同意 《用户协议》 和 《隐私协议》 不同意授权 已知悉,同意授权 import apiUrl from '@/utils/commonUrl.js'; export default { data() { return { url: '', corporateName:'上海xxx科技有限公司', phoneNum: '999999999', coverIsShow: false, chackBoxIsShow: false, }; }, onLoad() { this.url = apiUrl.baseUrl+ "&t=" + new Date().getTime() }, methods: { }, // 复选框点击 checkBoxBtn(){ this.chackBoxIsShow = !this.chackBoxIsShow; }, // 取消返回 goBack(){ uni.navigateBack({ delta:1 }) }, // 确认协议 confirm(){ this.$store.commit('SET_BEILIANPROVICY', '1'); this.coverIsShow = false }, // 用户协议 userPrivacy(){ uni.navigateTo({ url:'/pages/home/beiLiAnUser' }) }, // 隐私协议 agreePrivacy(){ uni.navigateTo({ url:'/pages/home/beiLiAnPrivacy' }) } } } .my-cover{ position: fixed; top: 0; left: 0; width: 100%; height: 100%; z-index: 100; background-color: rgba(0,0,0,.3); display: flex; align-items: center; justify-content: center; z-index: 99999; .cover-box{ width: 636rpx; box-sizing: border-box; background: #fff; border-radius: 16rpx; display: flex; flex-direction: column; justify-content: center; align-items: center; .des { font-size: 26rpx; margin-top: 40rpx; width: 560rpx; .des-text{ width: 560rpx; color: #666; line-height: 48rpx; white-space: pre-wrap; text-indent: 2em; word-break:break-all; } .des-text1{ width: 560rpx; white-space:pre-wrap; line-height: 48rpx; color: #333; font-weight: bold; text-indent: 2em; word-break:break-all; } } .nav-select{ margin-top: 28rpx; margin-left: 10rpx; margin-right: 10rpx; font-size: 26rpx; display: flex; .select-item{ display: flex; .image { width: 30rpx; height: 30rpx; margin-right: 20rpx; } } .nav-privacy{ color: #1989FF; } } .btns { margin-top: 32rpx; margin-bottom: 0; display: flex; .reject { color: #333; font-size: 28rpx; background: #fff; height: 100rpx; line-height: 100rpx; font-weight: 500; width: 320rpx; border-top: 2rpx solid #eee; } .agree { color: #1989ff; font-size: 28rpx; background: #fff; height: 100rpx; line-height: 100rpx; font-weight: 500; width: 320rpx; border-top: 2rpx solid #eee; margin-left: -2rpx; } :deep(button[disabled][type=primary]) { color: #8cc4fd !important; border-radius: 0!important; } button { border-radius: 0!important; } } } }
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们。