欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue 和vue-touch 實現(xiàn)移動端左右導航效果(仿京東移動站導航)

 更新時間:2017年04月22日 08:53:46   作者:大宅廣  
這篇文章主要介紹了vue 和vue-touch 實現(xiàn)移動端左右導航效果(仿京東移動站導航),需要的朋友可以參考下

先給大家展示下效果圖,感覺還不錯請參考實現(xiàn)代碼:

使用技術(shù):vue2.0 webpack vue-touch 一些簡單的javascript;

(注意:vue-touch 使用的是2.0.0版本 需要與vue2.0.0兼容)

vue-touch(地址:https://github.com/vuejs/vue-touch 注意是next 分支)

左側(cè)導航可滑動(右側(cè)視圖窗因為和左邏輯一樣 就沒寫)

var VueTouch = require('vue-touch')
Lib.Vue.use(VueTouch, {name: 'v-touch'})

通過npm 安裝后vuetouch 后引入

我這里Lib,是我的一個方法 你也可以 直接Vue.use()引用

{name:'v-touch'}的作用 聲明一個以vue-touch的標簽

然后 在html內(nèi)寫一個 <vue-touch></vue-touch>就可以,當然后面我們要寫入方法;

附:vue-touch方法

因為vue-touch其實封裝了 hammer.js的方法 其實我們這里介紹的也就是他幾個事件;詳情可以搜索 hammer.js的文檔;

hammer.js主要針對觸屏的6大事件進行監(jiān)聽。如下圖所示:

1、  Pan事件:在指定的dom區(qū)域內(nèi),一個手指放下并移動事件,即觸屏中的拖動事件。這個事件在屏觸開發(fā)中比較常用,如:左拖動、右拖動等,如手要上使用QQ時向右滑動出現(xiàn)功能菜單的效果。該事件還可以分別對以下事件進行監(jiān)聽并處理:

Panstart:拖動開始、Panmove:拖動過程、Panend:拖動結(jié)束、Pancancel:拖動取消、Panleft:向左拖動、Panright:向右拖動、Panup:向上拖動、Pandown:向下拖動

2、  Pinch事件:在指定的dom區(qū)域內(nèi),兩個手指(默認為兩個手指,多指觸控需要單獨設(shè)置)或多個手指相對(越來越近)移動或相向(越來越遠)移動時事件。該事件事以分別對以下事件進行監(jiān)聽并處理:

Pinchstart:多點觸控開始、Pinchmove:多點觸控過程、Pinchend:多點觸控結(jié)束、Pinchcancel:多點觸控取消、Pinchin:多點觸控時兩手指距離越來越近、Pinchout:多點觸控時兩手指距離越來越遠

3、  Press事件:在指定的dom區(qū)域內(nèi)觸屏版本的點擊事件,這個事件相當于PC端的Click事件,該不能包含任何的移動,最小按壓時間為500毫秒,常用于我們在手機上用的“復制、粘貼”等功能。該事件分別對以下事件進行監(jiān)聽并處理:

Pressup:點擊事件離開時觸發(fā)

4、  Rotate事件:在指定的dom區(qū)域內(nèi),當兩個手指或更多手指成圓型旋轉(zhuǎn)時觸發(fā)(就像兩個手指擰螺絲一樣)。該事件分別對以下事件進行監(jiān)聽并處理:

Rotatestart:旋轉(zhuǎn)開始、Rotatemove:旋轉(zhuǎn)過程、Rotateend:旋轉(zhuǎn)結(jié)束、Rotatecancel:旋轉(zhuǎn)取消

5、  Swipe事件:在指定的dom區(qū)域內(nèi),一個手指快速的在觸屏上滑動。即我們平時用到最多的滑動事件。

Swipeleft:向左滑動、Swiperight:向右滑動、Swipeup:向上滑動、Swipedown:向下滑動

6、Tap事件:在指定的dom區(qū)域內(nèi),一個手指輕拍或點擊時觸發(fā)該事件(類似PC端的click)。該事件最大點擊時間為250毫秒,如果超過250毫秒則按Press事件進行處理。

(以上作者毫無節(jié)奏的摘抄一下,其實我也是費好大勁搜索的呀)
這里注意swipe這個方法;我們不需要因為這個滑動和我們需要的滑動是不一樣的;

Panstart 是我們需要的;

展示一下 div 代碼層;

<v-touch class="ul" 
 v-on:pandown="onPanStart" //向下滑動
 v-on:panmove="onPanmove" //滑動結(jié)束
 v-on:panup="onPandup"> //向上滑動
</v-touch>

注意:也可以進行 事件的限制 用戶多長時間可以執(zhí)行

//我沒用到這句
 v-bind:pan-options="{ direction: 'panup', threshold: 100 }">

首先定一個 公共變量

//省去一些 代碼
var lefthe = 0; //檢測滑動的位置
onPanStart:function(data)
 {
 this.positionjson.transition=''
 console.log(data)
 var y = data.deltaY; //事件執(zhí)行 所滑動的距離
 lefthe = y + this.lefthe; //滑動的距離 記錄到 lefthe 方便下次執(zhí)行
 console.log(lefthe)
 if(lefthe >=50)
 {
 //限制 不能一直往上拉 拉到宇宙呢?我這里是寫死的
  lefthe = 0;
 //回彈效果 在 滑動結(jié)束后 執(zhí)行
 return
 }else{
 }
 this.positionjson.top = lefthe +'px';
 },

滑動結(jié)束 事件

 onPanend:function(data)
 {
 if(lefthe ==0)
 {
 console.log('現(xiàn)在是0')
 this.positionjson.top = lefthe +'px';
 //滑動結(jié)束 執(zhí)行 一些事件 lefthe 0 的時候其實也就是下拉到頂?shù)倪^程
 this.positionjson.transition='0.2s ease 0s'
 }else{
 }
 this.lefthe = lefthe;
 },
//上拉代碼塊
onPandup:function(data)
 {
 var domul =document.getElementById('domul');
 this.positionjson.transition=''
 var y = data.deltaY; //下拉的距離
 var boxheight = this.boxheight; //視圖高度 也就是分辨率
 var liheight = document.getElementById('libox').clientHeight; //左側(cè)每個li的高度
 console.log(liheight+'元素的高')
 var zongheight = this.navapi.list.length * 70; //就能得出li父盒子高度
 var bottomheight = -(zongheight - boxheight) + -100; //計算下拉到 滑動盒子的高度 - 視圖高度 =上拉到底的位置
 if(lefthe <= bottomheight)
 {
 // console.log('到底啦啦啦啦啦')
 return;
 }else{}
 lefthe = y + this.lefthe;
 this.positionjson.top = lefthe +'px';
 },

以上所述是小編給大家介紹的vue 和vue-touch 實現(xiàn)移動端左右導航效果(仿京東移動站導航),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • VueCli4項目配置反向代理proxy的方法步驟

    VueCli4項目配置反向代理proxy的方法步驟

    這篇文章主要介紹了VueCli4項目配置反向代理proxy的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-05-05
  • vue 實現(xiàn)強制類型轉(zhuǎn)換 數(shù)字類型轉(zhuǎn)為字符串

    vue 實現(xiàn)強制類型轉(zhuǎn)換 數(shù)字類型轉(zhuǎn)為字符串

    今天小編就為大家分享一篇vue 實現(xiàn)強制類型轉(zhuǎn)換 數(shù)字類型轉(zhuǎn)為字符串,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-11-11
  • vue require.context全局注冊組件的具體實現(xiàn)

    vue require.context全局注冊組件的具體實現(xiàn)

    本文主要介紹了vue require.context全局注冊組件,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-05-05
  • vue實現(xiàn)一個炫酷的日歷組件

    vue實現(xiàn)一個炫酷的日歷組件

    公司業(yè)務(wù)新開了一個商家管理微信H5移動端項目,日歷控件是商家管理員查看通過日程來篩選獲取某日用戶的訂單等數(shù)據(jù)。下面小編給大家?guī)砹嘶趘ue實現(xiàn)一個炫酷的日歷組件,感興趣的朋友參考下吧
    2018-10-10
  • 詳解vue的diff算法原理

    詳解vue的diff算法原理

    這篇文章主要介紹了詳解vue的diff算法原理,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • 安裝多版本Vue-CLI的實現(xiàn)方法

    安裝多版本Vue-CLI的實現(xiàn)方法

    這篇文章主要介紹了安裝多版本Vue-CLI的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • Element-UI實現(xiàn)復雜table表格結(jié)構(gòu)的操作代碼

    Element-UI實現(xiàn)復雜table表格結(jié)構(gòu)的操作代碼

    Element-UI組件el-table用于展示多條結(jié)構(gòu)類似的數(shù)據(jù),可對數(shù)據(jù)進行排序、篩選、對比或其他自定義操作,本文給大家介紹Element-UI實現(xiàn)復雜table表格結(jié)構(gòu)的操作代碼,感興趣的朋友一起看看吧
    2023-12-12
  • 在vue中:style 的使用方式匯總

    在vue中:style 的使用方式匯總

    在Vue開發(fā)中使用:style綁定樣式是常見需求,應(yīng)注意:class與:style的配合使用,錯誤的使用可能導致樣式不生效,正確的方法是使用數(shù)組綁定多個樣式,這些技巧有助于提高開發(fā)效率和保持代碼整潔,感興趣的朋友跟隨小編一起看看吧
    2024-09-09
  • vue使用vuex實現(xiàn)首頁導航切換不同路由的方法

    vue使用vuex實現(xiàn)首頁導航切換不同路由的方法

    這篇文章主要介紹了vue使用vuex實現(xiàn)首頁導航切換不同路由的方法 ,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-05-05
  • vue中的v-touch事件用法說明

    vue中的v-touch事件用法說明

    這篇文章主要介紹了vue中的v-touch事件用法說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03

最新評論