前言
我們可以經(jīng)常看到手機(jī)app里有的菜單欄是懸浮在首頁的,用戶可以拖動(dòng)和點(diǎn)擊菜單欄進(jìn)行交互,今天代碼君就教大家利用小程序的控件,實(shí)現(xiàn)一個(gè)可移動(dòng)的菜單,效果圖是這樣的,要實(shí)現(xiàn)這樣的效果,需要引出我們今天的重要人物movable-view
movable-view屬性介紹
屬性名 | 作用 | 參數(shù)值 |
---|---|---|
direction | 設(shè)置movable-view的移動(dòng)方向 | 屬性值有all、vertical、horizontal、none |
inertia | movable-view是否帶有慣性 | true/false 默認(rèn)是false |
out-of-bounds | 超過可移動(dòng)區(qū)域后,movable-view是否還可以移動(dòng) | true/false 默認(rèn)是false |
x | 定義x軸方向的偏移,如果x的值不在可移動(dòng)范圍內(nèi),會(huì)自動(dòng)移動(dòng)到可移動(dòng)范圍;改變x的值會(huì)觸發(fā)動(dòng)畫 | number |
y | 定義y軸方向的偏移,如果y的值不在可移動(dòng)范圍內(nèi),會(huì)自動(dòng)移動(dòng)到可移動(dòng)范圍;改變y的值會(huì)觸發(fā)動(dòng)畫 | number |
damping | 阻尼系數(shù),用于控制x或y改變時(shí)的動(dòng)畫和過界回彈的動(dòng)畫,值越大移動(dòng)越快 | number 默認(rèn)是20 |
friction | 摩擦系數(shù),用于控制慣性滑動(dòng)的動(dòng)畫,值越大摩擦力越大,滑動(dòng)越快停止;必須大于0,否則會(huì)被設(shè)置成默認(rèn)值 | number默認(rèn)是2 |
實(shí)現(xiàn)可移動(dòng)菜單
一、wxml界面的實(shí)現(xiàn)
<view class='title-line'>movable</view><movable-area class="moveArea"><movable-view class='moveView' x="{{x}}" y="{{y}}" damping="40" direction="all" inertia='true'>菜單</movable-view></movable-area><button class='button' type='primary' size='mini' bindtap='moveView'>點(diǎn)我隨機(jī)滾動(dòng)小方塊</button><button class='button' type='primary' size='mini' bindtap='stopMove'>點(diǎn)我停止隨機(jī)滾動(dòng)</button>
界面布局比較簡(jiǎn)單,需要注意的幾點(diǎn)
二、xxx.js隨機(jī)移動(dòng)實(shí)現(xiàn)的邏輯
Page({data: {x: 0,y: 0,isStop:false,},moveView:function(e){var that = this;setTimeout(function () {that.move(that);}, 1000);},stopMove: function (e) {this.setData({isStop: true})},move: function (that){var randowX = that.GetRandomNum(1, 200);var randowY = that.GetRandomNum(1, 400);that.setData({x: randowX,y:randowY,})if(!that.data.isStop){setTimeout(function () {that.move(that);}, 100);}},//隨機(jī)函數(shù)GetRandomNum: function (Min, Max) {var Range = Max - Min;var Rand = Math.random();return (Min + Math.round(Rand * Range));},
js里面需要講解的內(nèi)容比較多
三、wxss樣式
.moveArea {height: 400px;width:200px;background: red;margin: 10px;}.moveView {height: 100rpx;width: 100rpx;line-height: 100rpx;background: blue;border-radius: 50%;text-align: center;margin: 10rpx;}
今天講解的樣式有一下幾個(gè)
如何把圖形從方形變成圓形?
border-radius 這是今天的主角,把他的值設(shè)置成50%,就由方形變成圓形了,這個(gè)屬性是設(shè)置圓角的,設(shè)置10%,是有一點(diǎn)圓角的方形
設(shè)置內(nèi)容垂直居中方法
這是代碼君的一個(gè)小竅門,把height和line-height設(shè)置成一樣,他自動(dòng)會(huì)垂直居中
總結(jié)
今天講解的是可移動(dòng)的菜單,本身實(shí)現(xiàn)是沒什么難度的,我又引入了幾個(gè)知識(shí)點(diǎn),一個(gè)是推遲事件函數(shù)的使用還有就是幾個(gè)css樣式設(shè)置的小竅門,讀者回去認(rèn)真記住使用規(guī)則,后面我們陸續(xù)會(huì)用上,好啦,今天的課程就到這~
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持VEVB武林網(wǎng)。
新聞熱點(diǎn)
疑難解答
圖片精選