微信小程序自定义波浪组件
发表于更新于
广州
开发微信小程序微信小程序自定义波浪组件
❄️2winter最近看到好多app上有波浪背景,有动态的,有静态的,这里是在小程序中用得动态。
先看看效果图:里面的文本是组件内部定义的。
这是用两个svg的图片用css关键帧动画做的效果(这里谢谢子弹短信里前端群的小伙伴提供的web版的css动画文件)
在小程序中使用,注意一个问题:就是svg不可以直接使用,需要转为base64(这个大家应该有收藏吧),这里我已经转换好了,在下面的wxss中。
这里顺便用一下自定义组件:
首先定义组件 wave
wave.wxml:这里我默认是用得显示个人信息。其中isShowInfo来控制是否显示
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
| <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(),用来隐藏内部组件,灵活运用很方便。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
| Component({
properties: { },
data: { isShowInfo:false },
methods: { __hideInfo:function(){ this.setData({ isShowInfo:true }) } },
})
|
wave.json:第一个是设置为自定义组件,第二个可选是使用其他的自定义组件,比如引用组件,一会就会用得
1 2 3 4
| { "component": true, "usingComponents": {} }
|
wave.wxss:zr的背景直接改为自己需要的,或者用属性传递。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
| .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一样直接用
1 2 3 4 5 6
| {
"usingComponents": { "wave": "../com/wave/waves" } }
|
index.wxml
index.js:通过wave设置的id获取组件对象,调用私有方法。去除内部信息。
1 2 3 4
| onLoad: function (options) { this.wave = this.selectComponent("#wave"); this.wave.__hideInfo() },
|
再来一个静态图:
好了。
❄️2winter
ReactNative FullStack Developer
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 ❄️2winter!