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 相关文章推荐
jquery 层次选择器siblings与nextAll的区别介绍
Aug 02 Javascript
JSON+HTML实现国家省市联动选择效果
May 18 Javascript
JavaScript获取一个范围内日期的方法
Apr 24 Javascript
JavaScript中reduce()方法的使用详解
Jun 09 Javascript
js绘制圆形和矩形的方法
Aug 05 Javascript
js实现点击图片自动提交action的简单方法
Oct 16 Javascript
AngularJS出现$http异步后台无法获取请求参数问题的解决方法
Nov 03 Javascript
微信小程序开发的四十个技术窍门总结(推荐)
Jan 23 Javascript
node.js中express-session配置项详解
May 31 Javascript
基于js 各种排序方法和sort方法的区别(详解)
Jan 03 Javascript
解决layui laydate 时间控件一闪而过的问题
Sep 28 Javascript
浅谈实现在线预览PDF的几种解决办法
Aug 10 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
PHP 递归效率分析
2009/11/24 PHP
php获取本地图片文件并生成xml文件输出具体思路
2013/04/27 PHP
PHP在引号前面添加反斜杠(PHP去除反斜杠)
2013/09/28 PHP
PHP中UNIX时间戳和日期间的转换与计算实例
2014/11/19 PHP
PHP封装的数据库保存session功能类
2016/07/11 PHP
JavaScript 对象链式操作测试代码
2010/04/25 Javascript
JS链式调用的实现方法
2013/03/07 Javascript
jquery操作复选框(checkbox)的12个小技巧总结
2014/02/04 Javascript
弹出窗口并且此窗口带有半透明的遮罩层效果
2014/03/13 Javascript
jquery动态改变form属性提交表单
2014/06/03 Javascript
JavaScript中的console.dir()函数介绍
2014/12/29 Javascript
JavaScript运算符小结
2015/06/03 Javascript
Node.js中的process.nextTick使用实例
2015/06/25 Javascript
AngularJS基础 ng-keydown 指令简单示例
2016/08/02 Javascript
import与export在node.js中的使用详解
2017/09/28 Javascript
jQuery中ajax获取数据赋值给页面的实例
2017/12/31 jQuery
tweenjs缓动算法的使用实例分析
2019/08/26 Javascript
用JS实现一个简单的打砖块游戏
2019/12/11 Javascript
vue使用element-ui实现表单验证
2020/12/13 Vue.js
jQuery实现tab栏切换效果
2020/12/22 jQuery
[03:55]DOTA2完美大师赛选手传记——LFY.MONET
2017/11/18 DOTA
python中使用mysql数据库详细介绍
2015/03/27 Python
Python中使用第三方库xlrd来读取Excel示例
2015/04/05 Python
Python使用matplotlib和pandas实现的画图操作【经典示例】
2018/06/13 Python
对python特殊函数 __call__()的使用详解
2019/07/02 Python
解决Pytorch 训练与测试时爆显存(out of memory)的问题
2019/08/20 Python
CentOS7下安装python3.6.8的教程详解
2020/01/03 Python
一款纯css3实现的动画加载导航
2014/10/08 HTML / CSS
巧克力蛋糕店创业计划书
2014/01/14 职场文书
护士长竞聘书
2014/03/31 职场文书
小学校园广播稿(3篇)
2014/09/19 职场文书
幼儿园见习报告范文
2014/10/30 职场文书
幼儿园大班教师个人工作总结
2015/02/05 职场文书
2015小学毕业班工作总结
2015/07/21 职场文书
医院病假条范文
2015/08/17 职场文书
Python包管理工具pip的15 个使用小技巧
2021/05/17 Python