国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

vue中使用better-scroll實現滑動效果及注意事項

2019-11-19 12:30:33
字體:
來源:轉載
供稿:網友

一、首先需要在項目中引入better-scroll

1. 在package.json 直接寫入 "better-scroll":"^1.11.1"  版本以github上為準(目前最新)

2.cpnm install  在node_modules  可以查看版本是否安裝

3.直接在你的組件里面寫入import BScroll from 'better-scroll';

二、better-scroll優點

1.體驗像原生:滾動非常流暢,而且沒有滾動條。

2.滾動位置固定:在vue中通過路由切換頁面時組件會自動滾動到頂部,需要監聽滾動行為才能讓滾動位置固定,better-scroll解決了這個問題。

三、下面是在項目中的使用

先給大家介紹最終要實現的效果

        就是移動端很常見的效果,當滑動右邊部分的時候,左邊會聯動顯示與當前內容相符合的標題高亮,當點擊左邊某一個標題的時候,右邊會自動滑動到相應的內容。

實現及說明

1.滾動效果

better-scroll在使用的時候需要在dom元素渲染完成之后初始化better-scroll的實例,初始化的時候,先要獲取需要滑動的元素,然后在初始化的時候將獲取到的元素傳遞給初始化函數,此時便可實現滑動效果

2.左右聯動效果

左右聯動效果的實現,是better-scroll通過監聽事件實現的。

首先獲取到右邊內容盒子的高度,然后獲取到該盒子中每一項的高度并做前n項高度累加(第n項的高度是前n項的高度和)存儲到listHeight數組中。在初始化的時候傳遞屬性probeType=3 (探針的效果,時時獲取滾動高度),并給右邊的內容盒子對象監聽scroll事件,從而時時獲取Y軸位置,來與listHeight數組中的數據做比較,時時計算當前的索引值,并給對邊對應索引值的項添加背景色高亮,從而實現右邊滑動,聯動左邊。

當點擊左邊的每一項的時候,獲取到當前的索引值,并根據當前的索引值獲取到與右邊內容盒子中對應索引的元素,右邊的盒子元素通過監聽scrollToElement,并傳遞獲取到的對應索引元素和動畫時間,從而實現點擊左邊,實現右邊聯動;

實現代碼如下:

html結構

demo中用到的數據結構

demo中用到的方法

方法的調用

屬性計算


樣式不做過多介紹

需要注意的是,該頁面的這一部分給了固定的高度,且超出部分overflow:hidden;

3.better-scroll實現水平滑動效果

項目中經常會遇到需要水平滑動的需求,現在就用better-scroll來實現它

better-scroll的使用方式跟上邊的說明是一樣,只是配置項發生了變化,下面將代碼貼出來,就明了了。

template部分

js部分

css部分

注意事項:

1.tab_content是內容的盒子,他的長度就是內容的寬度;

2.由于內容的盒子是需要滑動的,所以在內容盒子的外邊還需要在加一層盒子,寬度為100%。

better-scroll插件git地址https://github.com/ustbhuangyi/better-scroll

總結

以上所述是小編給大家介紹的vue中使用better-scroll實現滑動效果及注意事項,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 永靖县| 泗洪县| 象州县| 东莞市| 鄄城县| 霍城县| 丰都县| 诸暨市| 沈丘县| 阿合奇县| 淮北市| 开封县| 洪泽县| 靖州| 中卫市| 泽库县| 施秉县| 江北区| 武城县| 卓资县| 凯里市| 顺平县| 五原县| 五寨县| 长垣县| 宜川县| 内丘县| 色达县| 灵武市| 连州市| 株洲县| 韶关市| 华坪县| 绵阳市| 临清市| 元阳县| 赞皇县| 富裕县| 肥东县| 仙桃市| 潼南县|