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动态设置form表单的enctype值(实现代码)
Jul 04 Javascript
JavaScript中的单引号和双引号报错的解决方法
Sep 01 Javascript
JavaScript模拟重力状态下抛物运动的方法
Mar 03 Javascript
jquery ztree异步搜索(搜叶子)实践
Feb 25 Javascript
微信小程序开发之Tabbar实例详解
Jan 09 Javascript
[原创]SyntaxHighlighter自动识别并加载脚本语言
Feb 07 Javascript
vue+vuex+axio从后台获取数据存入vuex实现组件之间共享数据
Apr 22 Javascript
将angular.js项目整合到.net mvc中的方法详解
Jun 29 Javascript
从vue基础开始创建一个简单的增删改查的实例代码(推荐)
Feb 11 Javascript
使用Vue制作图片轮播组件思路详解
Mar 21 Javascript
vue解决一个方法同时发送多个请求的问题
Sep 25 Javascript
javascript实现点击星星小游戏
Dec 24 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
Yii 框架入口脚本示例分析
2020/05/19 PHP
彪哥1.1(智能表格)提供下载
2006/09/07 Javascript
jQuery之字体大小的设置方法
2014/02/27 Javascript
告诉你什么是javascript的回调函数
2014/09/04 Javascript
jQuery unbind()方法实例详解
2016/01/19 Javascript
BootStrap智能表单实战系列(六)表单编辑页面的数据绑定
2016/06/13 Javascript
JS基于面向对象实现的拖拽功能示例
2016/12/20 Javascript
js点击任意区域弹出层消失实现代码
2016/12/27 Javascript
javascript设计模式之策略模式学习笔记
2017/02/15 Javascript
jQuery EasyUI tree增加搜索功能的实现方法
2017/04/27 jQuery
vue打包的时候自动将px转成rem的操作方法
2018/06/20 Javascript
微信小程序开发之自定义tabBar的实现
2018/09/06 Javascript
JavaScript实现获取两个排序数组的中位数算法示例
2019/02/26 Javascript
原生js实现表格翻页和跳转
2020/09/29 Javascript
vue 导航守卫和axios拦截器有哪些区别
2020/12/19 Vue.js
[55:25]VGJ.T vs Optic Supermajor小组赛D组 BO3 第三场 6.3
2018/06/04 DOTA
Python解决鸡兔同笼问题的方法
2014/12/20 Python
Python决策树分类算法学习
2017/12/22 Python
解决tensorflow1.x版本加载saver.restore目录报错的问题
2018/07/26 Python
pytorch 自定义卷积核进行卷积操作方式
2019/12/30 Python
python 实现在无序数组中找到中位数方法
2020/03/03 Python
PyCharm 无法 import pandas 程序卡住的解决方式
2020/03/09 Python
opencv+python实现鼠标点击图像,输出该点的RGB和HSV值
2020/06/02 Python
HTML5图片层叠的实现示例
2020/07/07 HTML / CSS
玉兰油美国官网:OLAY美国
2018/10/25 全球购物
美国最大的户外装备和服装购物网站:Backcountry
2019/10/15 全球购物
用你熟悉的语言写一个连接ORACLE数据库的程序,能够完成修改和查询工作
2012/06/11 面试题
下面代码从性能上考虑,有什么问题
2015/04/03 面试题
物业经理求职自我评价
2013/09/22 职场文书
数学国培研修感言
2014/02/13 职场文书
国贸专业自荐信范文
2014/03/02 职场文书
师范生见习报告
2014/10/31 职场文书
城南旧事观后感
2015/06/11 职场文书
狂人日记读书笔记
2015/06/30 职场文书
Python OpenCV快速入门教程
2021/04/17 Python
laravel ajax curd 搜索登录判断功能的实现
2021/04/17 PHP