I've seen a lot of them recently app There is a wave background on it , Dynamic , There are static ones , Here is the dynamic used in the applet .

Let's take a look at the renderings : The text inside is defined within the component .

This is with two svg For pictures of css Keyframe animation to do the effect ( Here, thank you for the bullet SMS front-end group of small partners to provide web Version of css Animation file )

Using in applets , Pay attention to one problem : namely svg It can't be used directly , Need to be converted to base64( We should have a collection ), I've already converted here , Below wxss in .

By the way, custom components are used here :

First define the component wave

 wave.wxml: I use it to display personal information by default . among isShowInfo To control whether it is displayed
<!--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>, Welcome </view> </view> <view
class="water"> <view class="water-c"> <view class="water-1"> </view> <view
class="water-2"> </view> </view> </view> </view>
wave.js: Here, the component defines a private method __hideInfo(), Used to hide internal components , Flexible use is very convenient .
// utils/wave/waves.js Component({ /** * List of properties for the component */ properties: { }, /** *
Initial data for the component */ data: { isShowInfo:false }, /** * Component's method list */ methods: {
__hideInfo:function(){ this.setData({ isShowInfo:true }) } }, })
wave.json: The first is to set it as a custom component , The second option is to use other custom components , For example, reference components , I'll use it later
{ "component": true, "usingComponents": {} }
wave.wxss:zr Change the background to what you need , Pass or use attributes .
/* Component background color */ .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; }
Component definition complete , The following is a reference to this component :

index.json: It's used here userxxx Using our defined components , The reference name is wave, This is also the node name that will be used later , and view Same as direct use
{ // Using components , Reference name ( Directly used as a node ), route "usingComponents": { "wave": "../com/wave/waves" } }
index.wxml

index.js: adopt wave Set id Get component object , Calling private methods . Remove internal information .
onLoad: function (options) { this.wave = this.selectComponent("#wave");
this.wave.__hideInfo() },
Another static diagram :

okay .

Technology