当前位置: 首页 > news >正文

uni-app 广告弹窗最佳实践:不扰民、可控制频次、含完整源码

需求背景

在很多移动端应用中,广告弹窗是常见的变现手段。但频繁弹出、无法关闭、重复打扰的广告往往会适得其反,导致用户流失。

本文将带你用 uni-app 实现一个**“智能不扰民”的广告弹窗组件,支持24小时只弹一次**、点击跳转优雅关闭,可直接复制使用。

效果预览

image-20251023154222615

功能亮点

  • 24小时内只弹一次,避免骚扰
  • 点击蒙层或关闭按钮均可关闭
  • 图片点击支持跳转活动页
  • 不依赖第三方库,开箱即用

核心思路拆解

模板
  • .ad-mask 作为半透明遮罩层,点击可关闭广告
  • .ad-container 包含广告图片和关闭按钮
  • .ad-image 显示广告图片,点击可跳转
  • .ad-close-btn 提供关闭按钮
样式
  • .ad-mask: 遮罩层样式,居中显示内容
  • .ad-container: 广告容器尺寸和定位
  • .ad-image: 图片自适应显示
  • .ad-close-btn: 关闭按钮样式,圆形设计
逻辑部分
  • visible 驱动渲染:控制广告显示状态。
  • 事件冒泡“双保险”:蒙层绑定 @click="closeAd",内部容器加 @click.stop 阻止冒泡。
  • 频次控制:利用 uni.setStorageSync('lastAdTime', Date.now()) 记录本次弹出时间,下次 onLoad 时对比 24 h 间隔,不到时间绝不骚扰。

使用建议

  • 广告图建议尺寸:600x800rpx,体积 < 100KB
  • 弹窗频率可升级为后端控制,避免前端被篡改
  • 可扩展 uni.request 动态获取广告图和跳转链接
  • 若需支持“不再提示”,可新增 uni.setStorageSync('neverShowAd', true)

完整代码

<template><view class="content"><!-- 其他元素 --><!-- 广告弹窗 --><view v-if="visible" class="ad-mask" @click="closeAd"><view class="ad-container" @click.stop><image class="ad-image" :src="adImage" mode="aspectFit" @click="onAdClick" /><view class="ad-close-btn" @click="closeAd"></view></view></view></view>
</template><script>
export default {data() {return {visible: false,adImage: '/static/ad.png',adLink: '/pages/activity/index'}},onLoad() {const last = uni.getStorageSync('lastAdTime');const now = Date.now();const oneDay = 24 * 60 * 60 * 1000;if (!last || now - last > oneDay) {this.showAd()}},methods: {showAd() {this.visible = true;},closeAd() {this.visible = false;uni.setStorageSync('lastAdTime', Date.now());},onAdClick() {uni.navigateTo({ url: this.adLink });this.closeAd();}}
}
</script><style>
.ad-mask {position: fixed;inset: 0;background: rgba(0, 0, 0, 0.6);display: flex;justify-content: center;align-items: center;z-index: 9999;
}
.ad-container {position: relative;width: 600rpx;height: 800rpx;
}
.ad-image {width: 100%;height: 100%;border-radius: 16rpx;
}
.ad-close-btn {position: absolute;top: 16rpx;right: 16rpx;color: #fff;font-size: 36rpx;background: rgba(0, 0, 0, 0.5);border-radius: 50%;width: 60rpx;height: 60rpx;line-height: 60rpx;text-align: center;
}
</style>
http://www.dtcms.com/a/519449.html

相关文章:

  • 使用eNSP模拟器搭建网络拓扑结构(笔记2):从 0 到 1 掌握华为网络仿真
  • UniApp 多页面编译优化:编译时间从10分钟到1分钟
  • C++变量与函数命名规范技术指南 (基于华为编码规范与现代C++最佳实践)
  • ELK1——elasticsearch
  • 【图像卷积基础】卷积过程卷积实现通道扩充与压缩池化Pooling原理和可视化
  • 杭州公司网站设计外贸手工做兼职的网站
  • 深入浅出Langchain4j——构建Java大语言模型应用的新范式
  • Babylon.js学习之路《添加自定义摇杆控制相机》
  • 【JAVA 进阶】SpringBoot集成Sa-Token权限校验框架深度解析
  • 【CMakeLists.txt】Qt6 依赖配置详解
  • 用js做网站登录网页成品
  • 数据库安全网关:从“看得见访问”到“控得住风险”的关键一层
  • 对泊松过程的理解
  • 【数论】质数筛(埃氏筛、欧拉筛)
  • 扩展名网站兰州做网站一咨询兰州做网站公司
  • 华为OD-Java面经-21届考研
  • Excel拆分和合并优化版本
  • 智能网联汽车:当汽车遇上“智慧网络”
  • 常规点光源在工业视觉检测上的应用
  • C++新特性——正则表达式
  • 基于卷积神经网络的汽车类型识别系统,resnet50,vgg16,resnet34【pytorch框架,python代码】
  • 设计 企业网站电脑系统网站建设
  • 做网站业务的怎么找资源网站推广名片
  • FPGA强化- HDMI显示器驱动设计与验证
  • 【PPT-ungroup PPT解组合,python无水印】
  • Java 17 环境下 EasyPoi 反射访问异常分析与解决方案(ExcelImportUtil.importExcelMore)
  • SpringBoot+alibaba的easyexcel实现前端使用excel表格批量插入
  • 重大更新,LVGL有UI编辑器用了
  • 多场景 VR 教学编辑器:重构教学流程的场景化实践
  • 公司做网站让我们销售单页面网站模板怎么做