vue+swiper实现左右滑动的测试题功能


Posted in Javascript onOctober 30, 2020

最近在做一个测试题,前后可以切换题目,点击按钮选择答案,选择答案的同时改变按钮的背景色,如下图所示:

vue+swiper实现左右滑动的测试题功能

初始代码

我用了vue和swiper。所有的题目是一个对象数组,通过v-for渲染:

<swiper ref="mySwiper" :options="swiperOptions">
 <swiper-slide v-for="(item, index) in listData" :key="index">
  <div class="question-box">
   <div class="idx">- 第{{ index+1 }}题 -</div>
   <div class="question">{{ item.question }}</div>
  </div>
  <button @click="goNext(index, 'a')" :class="item.answer=='a' ? 'active': ''">是</button>
  <button @click="goNext(index, 'b')" :class="item.answer=='b' ? 'active': ''">否</button>
 </swiper-slide>
</swiper>

一开始我把每道题目的answer存放在对象里面,点击的按钮时候切换answer的值,button的动态class监听到值改变后会引发背景色的改变。js部分:

goNext(index, answer) {
 this.$set(this.listData[index], 'answer', answer)
 this.swiper.slideNext(100)
},

发现问题

测试发现这样把点击事件和动态样式互相依赖,会造成大概几百毫秒的延迟才执行slideNext(),是可以直观感受到的延迟。通过调试,发现造成延迟有两方面的原因:

  • this.$set 更改数组
  • 执行完点击事件动态class监听到数据的改变 中间也有延迟。

于是我换了一个思路,不把每个题目的answer放在对像数组里面,而是在data里面定义一个answerMap,这样解决了问题1。为了解决问题2,我选择把动态样式 :class 去掉,改成用原生js在点击事件里面直接修改class。这样两步下来,确实看不到延迟了。

优化后的代码

html部分

<button @click="goNext($event, index, 'a')">是</button>
<button @click="goNext($event, index, 'b')">否</button>

js部分

goNext(e, index, answer) {
 const element = e.target
 const bro = element.parentNode.children
 for (let i = 0; i < bro.length; i++) {
  if (bro[i] !== element) {
   bro[i].classList.remove("active")
  }
 }
 element.classList.add('active')
 this.answerMap[this.listData[index].question] = answer
 this.swiper.slideNext(100)
},

测试结果:可喜可贺,slideNext()不再有肉眼可见的延迟了。

有的时候为了少写点代码,不知不觉牺牲了性能。这次实践,虽然原生JS使我增加了好几行代码,但是带来的性能提升也是非常明显的。经过这次优化,我觉得如果对Vue源码理解透彻的人,大概是能马上知道优化点。我虽然看过一遍源码,但还是理解不够深入。需要学习的还有很多呀~

到此这篇关于vue+swiper实现左右滑动的测试题功能的文章就介绍到这了,更多相关vue左右滑动内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
jquery选择器原理介绍($()使用方法)
Mar 25 Javascript
JavaScript设计模式之单例模式实例
Sep 24 Javascript
简介JavaScript中的sub()方法的使用
Jun 08 Javascript
五种js判断是否为整数类型方式
Dec 03 Javascript
JavaScript编码风格指南(中文版)
Aug 26 Javascript
JavaScript算法系列之快速排序(Quicksort)算法实例详解
Sep 04 Javascript
微信小程序-获得用户输入内容
Feb 13 Javascript
JavaScript运动框架 多值运动(四)
May 18 Javascript
详解用vue2.x版本+adminLTE开源框架搭建后台应用模版
Mar 15 Javascript
微信小程序转发事件实现解析
Oct 22 Javascript
vue中使用vue-print.js实现多页打印
Mar 05 Javascript
使用vue cli4.x搭建vue项目的过程详解
May 08 Javascript
利用vue3+ts实现管理后台(增删改查)
Oct 30 #Javascript
vue项目页面嵌入代码块vue-prism-editor的实现
Oct 30 #Javascript
解决vue侦听器watch,调用this时出现undefined的问题
Oct 30 #Javascript
vue2.0 watch里面的 deep和immediate用法说明
Oct 30 #Javascript
JavaScript实现轮播图效果
Oct 30 #Javascript
vue组件添加事件@click.native操作
Oct 30 #Javascript
解决removeEventListener 无法清除监听的问题
Oct 30 #Javascript
You might like
php提示Call-time pass-by-reference has been deprecated in的解决方法[已测]
2012/05/06 PHP
php获取从html表单传递数组的方法
2015/03/20 PHP
thinkphp5实现无限级分类
2019/02/18 PHP
Javascript SHA-1:Secure Hash Algorithm
2006/12/20 Javascript
javascript 兼容鼠标滚轮事件
2009/04/07 Javascript
不提示直接关闭网页窗口的JS示例代码
2013/12/17 Javascript
jquery ajax 局部无刷新更新数据的实现案例
2014/02/08 Javascript
JavaScript中的普通函数与构造函数比较
2015/04/07 Javascript
JS中JSON对象和String之间的互转及处理技巧
2016/04/06 Javascript
老生常谈JavaScript 函数表达式
2016/09/01 Javascript
jQuery表单元素选择器代码实例
2017/02/06 Javascript
完美解决手机浏览器顶部下拉出现网页源或刷新的问题
2017/11/30 Javascript
使用Vue构建可重用的分页组件
2018/03/26 Javascript
webpack手动配置React开发环境的步骤
2018/07/02 Javascript
jsonp跨域及实现百度首页联想功能的方法
2018/08/30 Javascript
Vue通过配置WebSocket并实现群聊功能
2019/12/31 Javascript
Vue如何实现监听组件原生事件
2020/07/03 Javascript
python操作gmail实例
2015/01/14 Python
Python中利用原始套接字进行网络编程的示例
2015/05/04 Python
Django中对数据查询结果进行排序的方法
2015/07/17 Python
分析Python中设计模式之Decorator装饰器模式的要点
2016/03/02 Python
numpy添加新的维度:newaxis的方法
2018/08/02 Python
Flask框架学习笔记之路由和反向路由详解【图文与实例】
2019/08/12 Python
Tensorflow tf.dynamic_partition矩阵拆分示例(Python3)
2020/02/07 Python
分享一枚pycharm激活码适用所有pycharm版本我的pycharm2020.2.3激活成功
2020/11/20 Python
html5 浏览器支持 如何让所有的浏览器都支持HTML5标签样式
2012/12/07 HTML / CSS
草莓网官网:StrawberryNET
2019/08/21 全球购物
一组SQL面试题
2016/02/15 面试题
数据库设计的包括哪两种,请分别进行说明
2016/07/15 面试题
小区物业门卫岗位职责
2014/04/10 职场文书
个人自查自纠材料
2014/10/14 职场文书
民政工作个人总结
2015/02/28 职场文书
辞职报告(范文三篇)
2019/08/27 职场文书
css 中多种边框的实现小窍门
2021/04/07 HTML / CSS
用python基于appium模块开发一个自动收取能量的小助手
2021/09/25 Python
delete in子查询不走索引问题分析
2022/07/07 MySQL