微信小程序?qū)崿F(xiàn)卡片層疊滑動效果
本文實(shí)例為大家分享了微信小程序之卡片層疊滑動效果的具體代碼,供大家參考,具體內(nèi)容如下
代碼:
js:
// index/gun/jsSwiper2/jsSwiper2.js Page({ /** * 頁面的初始數(shù)據(jù) */ data: { startX: 0, endX: 0, iCenter: 3, datas: [{ id: 1, zIndex: 2, opacity: 0.2, left: 40, iamge: "../../images/1.jpg", animation: null }, { id: 2, zIndex: 4, opacity: 0.4, left: 80, iamge: "../../images/2.jpg", animation: null }, { id: 3, zIndex: 6, opacity: 0.6, left: 120, iamge: "../../images/3.jpg", animation: null }, { id: 4, zIndex: 8, opacity: 1, left: 160, iamge: "../../images/4.jpg", animation: null }, { id: 5, zIndex: 6, opacity: 0.6, left: 200, iamge: "../../images/5.jpg", animation: null }, { id: 6, zIndex: 4, opacity: 0.4, left: 240, iamge: "../../images/6.jpg", animation: null }, { id: 7, zIndex: 2, opacity: 0.2, left: 280, iamge: "../../images/7.jpg", animation: null }, ], order: [] }, /** * 生命周期函數(shù)--監(jiān)聽頁面加載 */ onLoad: function (options) { this.__set__(); this.move(); }, /** * 生命周期函數(shù)--監(jiān)聽頁面初次渲染完成 */ onReady: function () { }, /** * 生命周期函數(shù)--監(jiān)聽頁面顯示 */ onShow: function () { }, /** * 生命周期函數(shù)--監(jiān)聽頁面隱藏 */ onHide: function () { }, /** * 生命周期函數(shù)--監(jiān)聽頁面卸載 */ onUnload: function () { }, /** * 頁面相關(guān)事件處理函數(shù)--監(jiān)聽用戶下拉動作 */ onPullDownRefresh: function () { }, /** * 頁面上拉觸底事件的處理函數(shù) */ onReachBottom: function () { }, /** * 用戶點(diǎn)擊右上角分享 */ onShareAppMessage: function () { }, move: function () { var datas = this.data.datas; /*圖片分布*/ for (var i = 0; i < datas.length; i++) { var data = datas[i]; var animation = wx.createAnimation({ duration: 200 }); animation.translateX(data.left).step(); this.setData({ ["datas[" + i + "].animation"]: animation.export(), ["datas[" + i + "].zIndex"]: data.zIndex, ["datas[" + i + "].opacity"]: data.opacity, }) } }, /**左箭頭 */ left: function () { // var last = this.data.datas.pop(); //獲取數(shù)組的最后一個(gè) this.data.datas.unshift(last);//放到數(shù)組的第一個(gè) var orderFirst = this.data.order.shift(); this.data.order.push(orderFirst); this.move(); }, /** */ right: function () { var first = this.data.datas.shift(); //獲取數(shù)組的第一個(gè) this.data.datas.push(first);//放到數(shù)組的最后一個(gè)位置 var orderLast = this.data.order.pop(); this.data.order.unshift(orderLast); this.move(); }, /**點(diǎn)擊某項(xiàng) */ choose: function (e) { var that = this; var id = e.currentTarget.dataset.id; var order = that.data.order; var index = 0; for (var i = 0; i < order.length; i++) { if (id == order[i]) { index = i; break; } } if (index < that.data.iCenter) { for (var i = 0; i < that.data.iCenter - index; i++) { this.data.datas.push(this.data.datas.shift()); //獲取第一個(gè)放到最后一個(gè) this.data.order.unshift(this.data.order.pop()); // this.right() } } else if (index > that.data.iCenter) { for (var i = 0; i < index - that.data.iCenter; i++) { this.data.datas.unshift(this.data.datas.pop()); //獲取最后一個(gè)放到第一個(gè) this.data.order.push(this.data.order.shift()); // this.left(); } } this.move(); }, /**新的排列復(fù)制到新的數(shù)組中 */ __set__: function () { var that = this; var order = that.data.order; var datas = that.data.datas; for (var i = 0; i < datas.length; i++) { that.setData({ ["order[" + i + "]"]: datas[i].id }) } }, //手指觸發(fā)開始移動 moveStart: function (e) { console.log(e); var startX = e.changedTouches[0].pageX; this.setData({ startX: startX }); }, //手指觸摸后移動完成觸發(fā)事件 moveItem: function (e) { console.log(e); var that = this; var endX = e.changedTouches[0].pageX; this.setData({ endX: endX }); //計(jì)算手指觸摸偏移劇距離 var moveX = this.data.startX - this.data.endX; //向左移動 if (moveX > 20) { this.left(); } if (moveX < -20) { this.right(); } }, })
wxml:
<view class="teachers_banner"> <view class="container clearfix teachers_b"> <view class="slide" id="slide" bindtouchstart='moveStart' bindtouchend='moveItem'> <block wx:for="{{datas}}"> <li animation="{{item.animation}}" style="z-index: {{item.zIndex}} ;opacity:{{item.opacity}};" bindtap="choose" data-id="{{item.id}}"> <image src="{{item.iamge}}"></image> </li> </block> </view> </view> </view>
wxss:
.teachers_banner { width: 100%; height: 650px; background-size: cover; position: relative; overflow: hidden; } .teachers_b { position: relative; margin-top: 80px; } #slide { margin: 0 auto; width: 100%; height: 350px; position: relative; } image { width: 400rpx; height: 550rpx; } #slide li { position: absolute; width: 400rpx; display: -webkit-box; display: -webkit-flex; display: flex; align-items: flex-start; -webkit-box-align: flex-start; -webkit-align-items: flex-start; overflow: hidden; box-shadow: 0 0 20px #1d374d; } #slide li img { width: 100%; height: 100%; } .slide_right { padding: 40px; -webkit-box-flex: 1; -webkit-flex: 1; flex: 1; min-width: 0; } .slide_right dl { padding-top: 10px; } .arrow .prev, .arrow .next { position: absolute; width: 50px; top: 38%; z-index: 9; font: 700 96px 'simsun'; opacity: 0.3; color: #fff; cursor: pointer; }
效果:
1.左右滑動時(shí),向相應(yīng)方向移動一個(gè)卡片位置;
2.點(diǎn)擊某一項(xiàng)時(shí),將點(diǎn)擊項(xiàng)位置移動到中間位置;
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
原生JS實(shí)現(xiàn)列表內(nèi)容自動向上滾動效果
這篇文章主要介紹了原生JS實(shí)現(xiàn)列表內(nèi)容自動向上滾動效果,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-05-05使用javascript實(shí)現(xiàn)頁面加載loading動畫(附完整源碼)
由于項(xiàng)目中多處要給ajax提交的時(shí)候增加等待動畫效果,所以就寫了一個(gè)簡單的通用js方法,這篇文章主要給大家介紹了關(guān)于如何使用javascript實(shí)現(xiàn)頁面加載loading動畫的相關(guān)資料,需要的朋友可以參考下2024-06-06Javascript節(jié)流函數(shù)throttle和防抖函數(shù)debounce
這篇文章主要介紹了Javascript節(jié)流函數(shù)throttle和防抖函數(shù)debounce,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-12-12JavaScript獲取對象在頁面中位置坐標(biāo)的方法
這篇文章主要介紹了JavaScript獲取對象在頁面中位置坐標(biāo)的方法,涉及JavaScript操作頁面元素屬性的相關(guān)技巧,需要的朋友可以參考下2016-02-02JS獲取整個(gè)頁面文檔的實(shí)現(xiàn)代碼
就是在當(dāng)前頁面用AJAX請求當(dāng)前頁面,返回的就是整個(gè)頁面的HTML··既然是整個(gè)頁面,所以也包括文檔聲明2011-12-12JavaScript+node實(shí)現(xiàn)三級聯(lián)動菜單
這篇文章主要為大家詳細(xì)介紹了JavaScript+node實(shí)現(xiàn)三級聯(lián)動菜單,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07jfinal與bootstrap的登錄跳轉(zhuǎn)實(shí)戰(zhàn)演習(xí)
這篇文章給大家分享jfinal與bootstrap之間的登錄跳轉(zhuǎn),具體內(nèi)容包含有點(diǎn)擊登錄彈出模態(tài)框、點(diǎn)擊登錄確認(rèn)按鈕后的validate、jfinal的validate、jfinal的session管理、ajax請求與返回信息處理、頁面間智能跳轉(zhuǎn)。感興趣的朋友跟著小編一起看看吧2015-09-09