最近看到好多app上有波浪背景,有动态的,有静态的,这里是在小程序中用得动态。
先看看效果图:里面的文本是组件内部定义的。
这是用两个svg的图片用css关键帧动画做的效果(这里谢谢子弹短信里前端群的小伙伴提供的web版的css动画文件)
在小程序中使用,注意一个问题:就是svg不可以直接使用,需要转为base64(这个大家应该有收藏吧),这里我已经转换好了,在下面的wxss中。
这里顺便用一下自定义组件:
首先定义组件 wave
wave.wxml:这里我默认是用得显示个人信息。其中isShowInfo来控制是否显示
<!--utils/wave/waves.wxml--> <view class="zr"> <view class='user_box' hidden="{{isShowInfo}}"> <view class='userInfo'> <open-data type="userAvatarUrl"></open-data> </view> <view class='userInfo_name'> <open-data type="userNickName"></open-data>,欢迎您 </view> </view> <view class="water"> <view class="water-c"> <view class="water-1"> </view> <view class="water-2"> </view> </view> </view> </view>
wave.js:这里组件定义一个私有方法 __hideInfo(),用来隐藏内部组件,灵活运用很方便。
// utils/wave/waves.js Component({ /** * 组件的属性列表 */ properties: { }, /** * 组件的初始数据 */ data: { isShowInfo:false }, /** * 组件的方法列表 */ methods: { __hideInfo:function(){ this.setData({ isShowInfo:true }) } }, })
wave.json:第一个是设置为自定义组件,第二个可选是使用其他的自定义组件,比如引用组件,一会就会用得
{ "component": true, "usingComponents": {} }
wave.wxss:zr的背景直接改为自己需要的,或者用属性传递。
/*组件背景颜色*/ .zr { background: #0396FF; width: 100%; height:100px; position: relative; } .water { position: absolute; left: 0; bottom: -10px; height: 30px; width: 100%; z-index: 1 } .water-c { position: relative } .water-1 { background: url("") repeat-x; background-size: 600px; -webkit-animation: wave-animation-1 3.5s infinite linear; animation: wave-animation-1 3.5s infinite linear } .water-2 { top: 5px; background: url("") repeat-x; background-size: 600px; -webkit-animation: wave-animation-2 6s infinite linear; animation: wave-animation-2 6s infinite linear } .water-1, .water-2 { position: absolute; width: 100%; height: 60px } .back-white { background: #fff } @keyframes wave-animation-1 { 0% { background-position: 0 top } 100% { background-position: 600px top } } @keyframes wave-animation-2 { 0% { background-position: 0 top } 100% { background-position: 600px top } } .user_box { display: flex; z-index: 10000!important; } .userInfo_name { flex: 1; vertical-align: middle; width: 100%; margin-left: 5%; margin-top: 5%; } .userInfo { flex: 1; width: 100%; border-radius: 50%; overflow: hidden; max-height: 50px; max-width: 50px; margin-left: 5%; margin-top: 5%; border: 2px solid #fff; }
组件定义完,下面是引用这个组件:
index.json:这里用到了userxxx使用我们定义的组件,引用名为wave,这也是一会使用的节点名,和view一样直接用
{ //使用组件,引用名(直接当做节点使用),路径 "usingComponents": { "wave": "../com/wave/waves" } }
index.wxml
index.js:通过wave设置的id获取组件对象,调用私有方法。去除内部信息。
onLoad: function (options) { this.wave = this.selectComponent("#wave"); this.wave.__hideInfo() },
再来一个静态图:
好了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
微信小程序,波浪组件
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新动态
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]