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跨浏览器实现将字符串转化为xml对象的方法
Sep 25 Javascript
JavaScript数组对象实现增加一个返回随机元素的方法
Jul 27 Javascript
js父页面中使用子页面的方法
Jan 09 Javascript
AngularJS基础 ng-model-options 指令简单示例
Aug 02 Javascript
Vue2 Vue-cli中使用Typescript的配置详解
Jul 24 Javascript
web前端vue之vuex单独一文件使用方式实例详解
Jan 11 Javascript
vue-cli 构建骨架屏的方法示例
Nov 08 Javascript
微信js-sdk 录音功能的示例代码
Nov 01 Javascript
Vue项目结合Vue-layer实现弹框式编辑功能(实例代码)
Mar 11 Javascript
如何使用vue slot创建一个模态框的实例代码
May 24 Javascript
详解JS预解析原理
Jun 16 Javascript
解决vue初始化项目一直停在downloading template的问题
Nov 09 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 ADODB生成HTML表格函数rs2html功能【附错误处理函数用法】
2018/05/29 PHP
jQuery 技巧小结
2010/04/02 Javascript
jsPDF生成pdf后在网页展示实例
2014/01/16 Javascript
Jquery原生态实现表格header头随滚动条滚动而滚动
2014/03/18 Javascript
jquery序列化表单以及回调函数的使用示例
2014/07/02 Javascript
jQuery Masonry瀑布流插件使用详解
2014/11/17 Javascript
jquery实现相册一下滑动两次的方法
2015/02/09 Javascript
JavaScript中的事件委托及好处
2016/07/12 Javascript
原生js实现网易轮播图效果
2020/04/10 Javascript
理解javascript中的闭包
2017/01/11 Javascript
jQuery阻止移动端遮罩层后页面滚动
2017/03/15 Javascript
JavaScript实现一个空中避难的小游戏
2017/06/06 Javascript
react native与webview通信的示例代码
2017/09/25 Javascript
jQuery实现的鼠标响应缓冲动画效果示例
2018/02/13 jQuery
[01:06:25]Secret vs Liquid 2018国际邀请赛淘汰赛BO3 第一场 8.25
2018/08/29 DOTA
Window 64位下python3.6.2环境搭建图文教程
2018/09/19 Python
Python + selenium + requests实现12306全自动抢票及验证码破解加自动点击功能
2018/11/23 Python
python 将有序数组转换为二叉树的方法
2019/03/26 Python
Python 脚本的三种执行方式小结
2019/12/21 Python
python程序如何进行保存
2020/07/03 Python
Scrapy模拟登录赶集网的实现代码
2020/07/07 Python
CSS3 Columns分列式布局方法简介
2014/05/03 HTML / CSS
美国在线家居装饰店:Belle&June
2018/10/24 全球购物
巴西补充剂和维生素购物网站:Natue
2019/06/17 全球购物
Footshop法国:购买运动鞋
2020/01/19 全球购物
Bandier官网:奢侈、时尚前卫的健身服装首选目的地
2020/07/05 全球购物
小学端午节活动方案
2014/03/13 职场文书
新闻发布会主持词
2014/03/28 职场文书
大学学生会竞选演讲稿
2014/04/25 职场文书
服务承诺书格式
2014/05/21 职场文书
网吧消防安全责任书
2014/07/29 职场文书
客户经理岗位职责
2015/01/31 职场文书
2015应届毕业生求职信范文
2015/03/20 职场文书
Python常遇到的错误和异常
2021/11/02 Python
python中的random模块和相关函数详解
2022/04/22 Python
VUE递归树形实现多级列表
2022/07/15 Vue.js