vue better-scroll插件使用详解


Posted in Javascript onJanuary 25, 2018

什么是 better-scroll

better-scroll 是一个移动端滚动的解决方案,它是基于 iscroll 的重写,它和 iscroll 的主要区别在 这里 。better-scroll 也很强大,不仅可以做普通的滚动列表,还可以做轮播图、picker 等等。

在需要的文件中添加

import BScorll from 'better-scroll';

引用的示例代码:

let scroll = new BScroll(Dom对象, {//options
 startX: 0,
 startY: 0
})

Vue获得Dom对象方法,

<div v-el:food-wrapper></div>//定义对象
this.$els.foodWrapper//获取对象

(Vue 更新数据时是异步的,所以在数据未加载完全之前,Bscroll无法获取目标内容的高度,所以会导致无法滚动的现象)

为了解决上面的问题,运用Vue的nextTick();

(简单说,因为DOM至少会在当前tick里面的代码全部执行完毕再更新。所以不可能做到在修改数据后并且DOM更新后再执行,要保证在DOM更新以后再执行某一块代码,就必须把这块代码放到下一次事件循环里面,比如setTimeout(fn, 0),这样DOM更新后,就会立即执行这块代码。)

// DOM 还没有更新
Vue.nextTick(function () {
 // DOM 更新了
})

问题:

PC页面时,点击不会被 better-scroll阻止事件,初始化,给 better-scroll派发事件,使移动端拥有点击事件,因此切换到PC端时,点击事件会被执行两次,

方法:在点击时,传 $event变量,Better-scroll插件中的 event事件和原生 js的 event有属性上得区别,Better-scroll插件派发的事件时event_constructed为true,原生点击事件是没有这个属性的,

selectMenu(index,event){
  if(!event._constructed){//如果不存在这个属性,则不执行下面的函数
    return;
  }
}

使用手册:https://github.com/ustbhuangyi/better-scroll

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
一个简单的js渐显(fadeIn)渐隐(fadeOut)类
Jun 19 Javascript
jquery阻止冒泡事件使用模拟事件
Sep 06 Javascript
JS运动基础框架实例分析
Mar 03 Javascript
解决jQuery uploadify在非IE核心浏览器下无法上传
Aug 05 Javascript
jquery实现美观的导航菜单鼠标提示特效代码
Sep 06 Javascript
jQuery+canvas实现简单的球体斜抛及颜色动态变换效果
Jan 28 Javascript
Angular.js中$apply()和$digest()的深入理解
Oct 13 Javascript
JS中mouseup事件丢失的原因与解决办法
Jun 14 Javascript
基于JavaScript实现无限加载瀑布流
Jul 21 Javascript
打字效果动画的4种实现方法(超简单)
Oct 18 Javascript
详解使用uni-app开发微信小程序之登录模块
May 09 Javascript
vue2配置scss的方法步骤
Jun 06 Javascript
jquery 获取索引值在一定范围的列表方法
Jan 25 #jQuery
MUI 实现侧滑菜单及其主体部分上下滑动的方法
Jan 25 #Javascript
完美解决mui框架off-canvas侧滑超出部分隐藏无法滚动的问题
Jan 25 #Javascript
vue2.0 better-scroll 实现移动端滑动的示例代码
Jan 25 #Javascript
mui框架 页面无法滚动的解决方法(推荐)
Jan 25 #Javascript
vue使用 better-scroll的参数和方法详解
Jan 25 #Javascript
Vue cli+mui 区域滚动的实例代码
Jan 25 #Javascript
You might like
zen cart新进商品的随机排序修改方法
2010/09/10 PHP
编译PHP报错configure error Cannot find libmysqlclient under usr的解决方法
2014/06/27 PHP
图文介绍PHP添加Redis模块及连接
2015/07/28 PHP
Jquery数独游戏解析(一)-页面布局
2010/11/05 Javascript
javascript跑马灯悬停放大效果实现代码
2012/12/12 Javascript
Javascript 加载和执行-性能提高篇
2012/12/28 Javascript
JavaScript日期时间与时间戳的转换函数分享
2015/01/31 Javascript
javascript制作网页图片上实现下雨效果
2015/02/26 Javascript
jQuery实现表格行上移下移和置顶的方法
2015/05/22 Javascript
jQuery实现鼠标经过购物车出现下拉框代码(推荐)
2016/07/21 Javascript
Node.js的文件权限及读写flag详解
2016/10/11 Javascript
使用jquery给指定的table动态添加一行、删除一行
2016/10/13 Javascript
javascript简单写的判断电话号码实例
2017/05/24 Javascript
利用jQuery异步上传文件的插件用法详解
2017/07/19 jQuery
jQuery动态添加.active 实现导航效果代码思路详解
2017/08/29 jQuery
vue中动态添加class类名的方法
2018/09/05 Javascript
Vue实现购物车详情页面的方法
2019/08/20 Javascript
JQuery省市联动效果实现过程详解
2020/05/08 jQuery
vue-i18n实现中英文切换的方法
2020/07/06 Javascript
vue中解决chrome浏览器自动播放音频和MP3语音打包到线上的实现方法
2020/10/09 Javascript
[02:53]2018年度DOTA2最佳战队-完美盛典
2018/12/17 DOTA
[01:08:32]DOTA2-DPC中国联赛 正赛 DLG vs PHOENIX BO3 第二场 1月18日
2021/03/11 DOTA
python使用append合并两个数组的方法
2015/04/28 Python
详解使用CSS3的@media来编写响应式的页面
2017/11/01 HTML / CSS
Huda Beauty官方商店:化妆和美容产品
2020/09/05 全球购物
weblogic面试题
2016/03/07 面试题
2013英文求职信模板范文
2013/11/15 职场文书
校园招聘策划书
2014/01/09 职场文书
工作收入证明模板
2014/10/10 职场文书
2014年英语工作总结
2014/12/20 职场文书
大学生自我推荐信范文
2015/03/24 职场文书
汤姆索亚历险记读书笔记
2015/06/29 职场文书
超市员工管理制度
2015/08/06 职场文书
2019年员工晋升管理制度范本!
2019/07/08 职场文书
Python自动化爬取天眼查数据的实现
2021/06/15 Python
CentOS 7安装mysql5.7使用XtraBackUp备份工具命令详解
2022/04/12 MySQL