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 相关文章推荐
根据一段代码浅谈Javascript闭包
Dec 14 Javascript
node.js中的fs.exists方法使用说明
Dec 17 Javascript
不依赖Flash和任何JS库实现文本复制与剪切附源码下载
Oct 09 Javascript
详解AngularJS 模态对话框
Apr 07 Javascript
原生js实现ajax方法(超简单)
Sep 20 Javascript
jQuery插件form-validation-engine正则表达式操作示例
Feb 09 Javascript
Vue-router结合transition实现app前进后退动画切换效果的实例
Oct 11 Javascript
一步步教你利用webpack如何搭一个vue脚手架(超详细讲解和注释)
Jan 08 Javascript
Webpack 之 babel-loader文件预处理器详解
Mar 23 Javascript
基于vue中对鼠标划过事件的处理方式详解
Aug 22 Javascript
详解webpack打包vue项目之后生成的dist文件该怎么启动运行
Sep 06 Javascript
详解 javascript对象创建模式
Oct 30 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
玛琪朵 Macchiato
2021/03/03 咖啡文化
建立文件交换功能的脚本(一)
2006/10/09 PHP
项目中应用Redis+Php的场景
2016/05/22 PHP
实例分析PHP中PHPMailer发邮件
2017/12/13 PHP
JavaScript的变量作用域深入理解
2009/10/25 Javascript
js焦点文字滚动效果代码分享
2015/08/25 Javascript
JQuery通过AJAX从后台获取信息显示在表格上并支持行选中
2015/09/15 Javascript
Bootstrap中文本框的宽度变窄并且加入一副验证码图片的实现方法
2016/06/23 Javascript
AngularJS 作用域详解及示例代码
2016/08/17 Javascript
node.js基于mongodb的搜索分页示例
2017/01/22 Javascript
解决浏览器会自动填充密码的问题
2017/04/28 Javascript
vue+mockjs模拟数据实现前后端分离开发的实例代码
2017/08/08 Javascript
WebStorm ES6 语法支持设置&amp;babel使用及自动编译(详解)
2017/09/08 Javascript
详解如何使用PM2将Node.js的集群变得更加容易
2017/11/15 Javascript
layui动态表头的实现代码
2019/08/22 Javascript
vue点击页面空白处实现保存功能
2019/11/06 Javascript
[01:07:53]RNG vs VG 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
Python2.x中str与unicode相关问题的解决方法
2015/03/30 Python
linux平台使用Python制作BT种子并获取BT种子信息的方法
2017/01/20 Python
pandas 小数位数 精度的处理方法
2018/06/09 Python
查看TensorFlow checkpoint文件中的变量名和对应值方法
2018/06/14 Python
python 实现交换两个列表元素的位置示例
2019/06/26 Python
利用python numpy+matplotlib绘制股票k线图的方法
2019/06/26 Python
django ModelForm修改显示缩略图 imagefield类型的实例
2019/07/28 Python
python3 实现口罩抽签的功能
2020/03/11 Python
CSS3盒子模型详解
2013/04/24 HTML / CSS
美国农场鲜花速递:The Bouqs
2018/07/13 全球购物
美国家居用品和厨具购物网站:DealsDot
2019/10/07 全球购物
SQL Server提供的3种恢复模型都是什么? 有什么区别?
2012/05/13 面试题
社团成立邀请函
2014/01/08 职场文书
留学推荐信怎么写
2014/01/25 职场文书
2014年圣诞节促销方案
2014/03/14 职场文书
网络管理员岗位职责
2014/03/17 职场文书
检讨书范文300字
2015/01/28 职场文书
上班旷工检讨书
2015/08/15 职场文书
记一次Mysql不走日期字段索引的原因小结
2021/10/24 MySQL