微信小程序?qū)崿F(xiàn)點(diǎn)擊空白隱藏的方法示例
怎樣實(shí)現(xiàn)jq中的slideUp或者slideDown這種動(dòng)畫(huà)效果呢,我的思路是用css3的transform: translateY()屬性,給需要?jiǎng)赢?huà)的元素添加上一個(gè)動(dòng)畫(huà)class。
先上效果圖:

1.蒙層的結(jié)構(gòu):
<!-- 購(gòu)物車(chē)蒙層 -->
<view class='list-fix' wx:if="{{mengShow}}" bindtap='outbtn'> //mengShow是蒙層是否顯示的標(biāo)志,然后蒙層綁定outbtn的點(diǎn)擊事件
<view class='in-list {{aniStyle?"slideup":"slidedown"}}' catchtap='inbtn'> //這里的三元運(yùn)算符是判斷動(dòng)畫(huà)該執(zhí)行哪一種,catchtap這個(gè)是阻止冒泡的點(diǎn)擊事件,這個(gè)事件必須有,才能阻止冒泡
<view class='in-content'>
<text>已選商品(1)</text>
<text class='iconfont icon-6'>清空購(gòu)物車(chē)</text>
</view>
<view class='cho-list' wx:for="{{chooseList}}" wx:key="">
<view class='listName'>{{item.Cname}}</view>
<view class='listPrice'>¥{{item.Cprice}}</view>
<view class='opBtn'>
<view class='com-btn cuts' >-</view>
<view class='com-num'>{{item.Cnum}}</view>
<view class='com-btn add' >+</view>
</view>
</view>
</view>
</view>
注意:三元運(yùn)算符里的slideup和slidedown一定要加上引號(hào)
2.蒙層的其它樣式自己寫(xiě)。最主要的是slideup和slidedown的動(dòng)畫(huà)效果的樣式:
@keyframes slidedown {
from {
transform: translateY(0);
}
to {
transform: translateY(100%);
}
}
.slidedown {
animation: slidedown 0.5s linear ;
}
.slideup {
animation: slideup 0.5s linear ;
}
@keyframes slideup {
from {
transform: translateY(100%);
}
to {
transform: translateY(0);
}
}
其它的樣式:list-fix是fixed定位,而in-list是absolute定位。
需要注意的一點(diǎn)是:做的時(shí)候,是從Y軸100%的位置處即最底部開(kāi)始運(yùn)動(dòng)或是從0到100%,所以要設(shè)置z-index,才能實(shí)現(xiàn)在底部運(yùn)動(dòng)起來(lái)的時(shí)候或者回到100%即底部的時(shí)候,蒙層浮在“確認(rèn)下單”這整個(gè)結(jié)構(gòu)的下面。即“確認(rèn)下單”這整個(gè)結(jié)構(gòu)的z-index要大于蒙層的z-index。
3.js
page({
data: {
mengShow:false,//蒙層的顯示與否
aniStyle:true, //動(dòng)畫(huà)效果,默認(rèn)slideup
},
//蒙層的顯示
showMeng:function(e){ //這是“確認(rèn)下單”這整個(gè)購(gòu)物車(chē)導(dǎo)航欄的點(diǎn)擊事件
this.setData({
mengShow:true, //蒙層顯示
aniStyle:true //設(shè)置動(dòng)畫(huà)效果為slideup
})
},
outbtn:function(e){ //這是list-fix的點(diǎn)擊事件,給它綁定事件,是為了實(shí)現(xiàn)點(diǎn)擊其它地方隱藏蒙層的效果
var that=this;
this.setData({
aniStyle:false //設(shè)置動(dòng)畫(huà)效果為slidedown
})
setTimeout(function(){ //延時(shí)設(shè)置蒙層的隱藏,這個(gè)定時(shí)器的時(shí)間,就是slidedown在css動(dòng)畫(huà)里設(shè)置的時(shí)間,這樣就能實(shí)現(xiàn)slidedown動(dòng)畫(huà)完成后,蒙層才消失的效果。不設(shè)置定時(shí)器會(huì)導(dǎo)致動(dòng)畫(huà)效果看不見(jiàn)
that.setData({
mengShow: false
})
},500)
},
inbtn:function(e){ //這個(gè)事件必須有,就算不做什么事情也要寫(xiě)上去,因?yàn)檫@個(gè)事件是為了防止事件冒泡,導(dǎo)致點(diǎn)擊in-list這里面的元素時(shí),點(diǎn)擊事件冒泡到list-fix觸發(fā)它的slidedown事件。
console.log("in")
},
})
這樣就能實(shí)現(xiàn)slidedown和slideup,點(diǎn)擊其它地方隱藏某元素的功能了。
總結(jié):
1.防止冒泡的點(diǎn)擊事件:catchtap=“”
2.點(diǎn)擊父元素除子元素以外的其它地方隱藏父元素的方法:父元素綁定一個(gè)點(diǎn)擊隱藏事件,然后子元素綁定catchtap這種能阻止冒泡的事件
3.巧用定時(shí)器設(shè)置屬性值,可達(dá)到類似上面執(zhí)行一個(gè)動(dòng)畫(huà)之后再執(zhí)行另外一個(gè)動(dòng)畫(huà)的方法。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
舉例講解JavaScript substring()的使用方法
這篇文章主要通過(guò)舉例的方法講解了javaScript substring()的用法,substring() 方法用于提取字符串中介于兩個(gè)指定下標(biāo)之間的字符,感興趣的小伙伴們可以參考一下2015-11-11
javascript實(shí)現(xiàn)的文字加密解密
javascript實(shí)現(xiàn)的文字加密解密...2007-06-06
JavaScript實(shí)現(xiàn)仿Clock ISO時(shí)鐘
這篇文章給大家分享了JavaScript實(shí)現(xiàn)仿Clock ISO時(shí)鐘的方法以及實(shí)例代碼,有興趣的朋友參考學(xué)習(xí)下下。2018-06-06
js中select選擇器的change事件處理函數(shù)詳解
Js操作Select是很常見(jiàn)的,也是比較實(shí)用的,下面這篇文章主要給大家介紹了關(guān)于js中select選擇器的change事件處理函數(shù)的相關(guān)資料,文中給出了詳細(xì)的實(shí)例代碼,需要的朋友可以參考下2023-06-06
詳解JavaScript前端如何實(shí)現(xiàn)截屏功能
這篇文章主要為大家詳細(xì)介紹了JavaScript前端如何實(shí)現(xiàn)截屏功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-04-04
JavaScript中判斷為整數(shù)的多種方式及保留兩位小數(shù)的方法
這篇文章主要介紹了JavaScript中判斷為整數(shù)的多種方式,以及保留兩位小數(shù)的方法,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09
Canvas中繪制Geojson數(shù)據(jù)示例詳解
這篇文章主要為大家介紹了Canvas中繪制Geojson數(shù)據(jù)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11

