微信小程序实现首页弹出广告
网络编程 2021-07-04 14:07www.168986.cn编程入门
这篇文章主要为大家详细介绍了微信小程序实现首页弹出广告,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了微信小程序实现首页弹出广告的具体代码,供大家参考,具体内容如下
这个微信小程序首页广告demo
仅供有需要的参考
.wxml
<!-- 广告展示 --> <view class="AdView" hidden="{{showAd}}" catchtouchmove="preventMove"> <view class="bg" ></view> <view class="active active-sport" > <view class="cancel" bind:tap = "cancelTap" ></view> <view class="active-content" bind:tap ="activeContent" data-id='2340173092'> <text>this is ad</text> <image class="active-img" src ='cloud://international-3bp20.696e-international-3bp20-1300609829/my-image.jpeg' mode="aspectFit"></image> </view> </view> </view>
//事件 catchtouchmove方法主要作用是固定广告防止点击穿透,就是使用弹出广告的后面内容不能上下拉动。其中对应的.js方法可以不做任何处理。此处只能在真机上看到实际效果,在电脑上不能。并且此方法要放到广告view最外层
.wxss
.bg{ width: 100%; height: 100%; position: fixed; : 0; left: 0; z-index: 990; background-color:rgb(180, 180, 180); opacity: 0.5; } .active{ width: 80%; height:80%; background-color: #fff; position: absolute; :10%; left:50%; transform: translate(-50%); z-index: 992; } .active-sport{ animation: sport 1.5s linear 1; } @keyframes sport{ from{ transform:rotate(0deg) skew(-10deg) scale(2.0) translate(-100%,0)} to{ transform:rotate(360deg) skew(0deg) scale(1.0) translate(-50%,0)} } .active-content{ width: 80%; height:80%; background-color: blue ; position: absolute; : 50%; left: 50%; transform: translate(-50%,-50%); text-align: center; } .active-img{ width: 100%; } .cancel{ background: url('data:image/svg+xml;base64,PD94bWwgdmVyc2lvbj0iMS4wIiBzdGFuZGFsb25lPSJubyI/PjwhRE9DVFlQRSBzdmcgUFVCTElDICItLy9XM0MvL0RURCBTVkcgMS4xLy9FTiIgImh0dHA6Ly93d3cudzMub3JnL0dyYXBoaWNzL1NWRy8xLjEvRFREL3N2ZzExLmR0ZCI+PHN2ZyB0PSIxNTc5OTMwNDc5NTM2IiBjbGFzcz0iaWNvbiIgdmlld0JveD0iMCAwIDEwMjQgMTAyNCIgdmVyc2lvbj0iMS4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHAtaWQ9IjIxMTkiIHdpZHRoPSIzMiIgaGVpZ2h0PSIzMiIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiPjxkZWZzPjxzdHlsZSB0eXBlPSJ0ZXh0L2NzcyI+PC9zdHlsZT48L2RlZnM+PHBhdGggZD0iTTg1MC41MzgzNDMgODk1LjUxNjc0NGMtMTEuNDk0Nzk5IDAtMjIuOTg4NTc0LTQuMzg2OTE0LTMxLjc2MzQyNC0xMy4xNjE3NjRMMTQxLjEwMzY5MiAyMDQuNjY5NDI2Yy0xNy41NDg2NzgtMTcuNTM0MzUyLTE3LjU0ODY3OC00NS45OTI0OTcgMC02My41MjU4MjUgMTcuNTQ4Njc4LTE3LjU0ODY3OCA0NS45NzcxNDctMTcuNTQ4Njc4IDYzLjUyNTgyNSAwbDY3Ny42NzEyMjcgNjc3LjY4NTU1M2MxNy41NDg2NzggMTcuNTM0MzUyIDE3LjU0ODY3OCA0NS45OTI0OTcgMCA2My41MjU4MjVDODczLjUyNjkxNyA4OTEuMTI4ODA3IDg2Mi4wMzIxMTggODk1LjUxNjc0NCA4NTAuNTM4MzQzIDg5NS41MTY3NDR6IiBwLWlkPSIyMTIwIiBmaWxsPSIjY2RjZGNkIj48L3BhdGg+PHBhdGggZD0iTTE3Mi44NjcxMTYgODk1LjUxNjc0NGMtMTEuNDk0Nzk5IDAtMjIuOTg4NTc0LTQuMzg2OTE0LTMxLjc2MzQyNC0xMy4xNjE3NjQtMTcuNTQ4Njc4LTE3LjUzNDM1Mi0xNy41NDg2NzgtNDUuOTkyNDk3IDAtNjMuNTI1ODI1bDY3Ny42NzEyMjctNjc3LjY4NTU1M2MxNy41NDg2NzgtMTcuNTQ4Njc4IDQ1Ljk3NzE0Ny0xNy41NDg2NzggNjMuNTI1ODI1IDAgMTcuNTQ4Njc4IDE3LjUzNDM1MiAxNy41NDg2NzggNDUuOTkyNDk3IDAgNjMuNTI1ODI1TDIwNC42Mjk1MTcgODgyLjM1NDk3OUMxOTUuODU1NjkgODkxLjEyODgwNyAxODQuMzYwODkxIDg5NS41MTY3NDQgMTcyLjg2NzExNiA4OTUuNTE2NzQ0eiIgcC1pZD0iMjEyMSIgZmlsbD0iI2NkY2RjZCI+PC9wYXRoPjwvc3ZnPg==') no-repeat 10rpx 10rpx/40rpx 40rpx; width: 60rpx; height: 60rpx; position: absolute; :5rpx; right: 5rpx; z-index: 998; }
此处cancel的背景图片只能使用base64或本地。
image 只能是网络或者fieldId上
可以作用CSS3特性,制作动画,制作动画时要注意加上transform之后,才可以增加rotate旋转,skew翻转,scale缩放,translate移动。
.js
// miniprogram/pages/demo/demo.js Page({ / 页面的初始数据 / data: { playlist:[], showAd:false }, //cancelTap隐藏方向 cancelTap(){ this.setData({showAd:!this.data.showAd}); }, //广告链接 activeContent(event){ console.log(event.currentTarget.dataset.id); // this.setData({showAd:!this.data.showAd}); let musicId=event.currentTarget.dataset.id; wx.navigateTo({ url:`../musicList/musicList?playlistId=${musicId}`, suess(){ console.log('navigate suess') }, fail(err){ console.log(err) } }); }, //阻止滚动穿透 preventMove(e){ console.log(e); }, / 生命周期函数--监听页面加载 / async onLoad(options) { this._getPlaylist(); }, async _getPlaylist(){ wx.showLoading({ title: '加载中', }) let listCount = await wx.cloud.callFunction({ name: 'music', data: { $url: 'getPlaylist', start: this.data.playlist.length, count: 15 } }) .then(res => { console.log(res); res.result.map(value=>{ this.setData({ playlist:this.data.playlist.concat(value) }) }) wx.hideLoading(); return res.result.length; }) .catch(err=>{console.error;wx.hideLoading();wx.showToast({ title: '加载失败,稍后再试!', icon:'none', duration:1500 })}); return listCount; }, //tcbRouter async tcbmusicTap(){ let result = await wx.cloud.callFunction({ name:'tcbRouter', data:{ $url:'music' } }) .then(res=>console.log(res)) .catch(err=>console.error); }, async tcbmovieTap(){ let result = await wx.cloud.callFunction({ name:'tcbRouter', data:{ $url:'movie' } }) .then(res=>console.log(res)) .catch(err=>console.error); }, / 生命周期函数--监听页面初次渲染完成 / onReady: function () { }, / 生命周期函数--监听页面显示 / onShow: function () { // this.setData({showAd:false}); }, / 生命周期函数--监听页面隐藏 / onHide: function () { }, / 生命周期函数--监听页面卸载 / onUnload: function () { }, / 页面相关事件处理函数--监听用户下拉动作 / async onPullDownRefresh() { this.setData({ playlist:[]}); await this._getPlaylist(); wx.sPullDownRefresh(); }, / 页面上拉触底事件的处理函数 / async onReachBottom() { let flag = await this._getPlaylist(); if(!flag){ wx.showToast({ title: '我是一个有底的人!', duration:2000, image:'../../images/girl3.png' }) } }, / 用户点击右上角分享 / onShareAppMessage: function () { } })
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 甘肃哪有关键词排名优化购买方式有哪些
- 甘肃SEO如何做网站优化
- 河南seo关键词优化怎么做电话营销
- 北京SEO优化如何做QQ群营销
- 来宾百度关键词排名:提升您网站曝光率的关键
- 卢龙关键词优化:提升您网站排名的策略与技巧
- 山东网站优化的注意事项有哪些
- 四川整站优化怎样提升在搜索引擎中的排名
- 疏附整站优化:提升网站性能与用户体验的全新
- 海南seo主要做什么工作售后服务要做到哪些
- 荣昌百度网站优化:提升您网站的搜索引擎排名
- 河北seo网站排名关键词优化如何做SEO
- 江西优化关键词排名推广售后保障一般有哪些
- 古浪SEO优化:提升你的网站可见性
- 西藏网站排名优化怎么把网站排名在百度首页
- 如何提升阳东百度快照排名:详尽指南