uniapp 小程序 堆叠轮播图 左滑 右滑 自动翻页 点击停止自动翻页

uniapp 小程序 堆叠轮播图 左滑 右滑 自动翻页 点击停止自动翻页 超过指定时间未点击滑动 则继续开始滚动

在这里插入图片描述

  1. 直接上代码 componentSwiper.vue 需要注意页面切换时清除计时器
<template><view><view class="swiperPanel" @touchstart="startMove" @touchend="endMove"><view class="swiperItem" v-for="(item, index) in swiperList" :key="index":style="{transform: itemStyle[index].transform, zIndex: itemStyle[index].zIndex, opacity: itemStyle[index].opacity}"><view class="children" @click="routerTo(item)"><image class="pic" :src="item.url"></image><text class="name">{{item.name}}</text></view></view></view></view>
</template><script>export default {props: {swiperList: {type: Array,default: [{url: 'https://cdn.uviewui.com/uview/goods/1.jpg',name: '这是一个图片'}]},// 自动翻页 间隔2秒timeNum:{type:Number,default:2000},// 点击后 5秒内未操作 自动翻页开启interval:{type:Number,default:5000},},data() {return {slideNote: {x: 0,y: 0},screenWidth: 0,itemStyle: [],timer: null,timer1: null};},watch: {swiperList: {handler(val) {if (val.length) {var macInfo = uni.getSystemInfoSync();this.screenWidth = macInfo.screenWidth;// 计算swiper样式this.swiperList.forEach((item, index) => {this.itemStyle.push(this.getStyle(index))})}},deep: true,immediate: true}},mounted() {this.doSomething()},onUnload() {this.timer = nullthis.timer1 = null},beforeDestroy() {this.timer = nullthis.timer1 = null},methods: {doSomething() {this.$nextTick(() => {this.timer = setInterval(() => {var newList = JSON.parse(JSON.stringify(this.itemStyle))// 向左滑动var last = [newList.pop()]newList = last.concat(newList)this.itemStyle = newList}, this.timeNum)})},routerTo(data) {// 此处为点击逻辑// 或者给父组件抛出事件// this.$emit("方法名字",参数)},getStyle(e) {if (e > this.swiperList.length / 2) {var right = this.swiperList.length - ereturn {transform: 'scale(' + (1 - right / 10) + ') translate(-' + (right * 14) + '%,0px)',zIndex: 100 - right,opacity: 0.8 / right}} else {return {transform: 'scale(' + (1 - e / 10) + ') translate(' + (e * 14) + '%,0px)',zIndex: 100 - e,opacity: 0.8 / e}}},startMove(e) {clearInterval(this.timer)this.timer = nullthis.slideNote.x = e.changedTouches[0] ? e.changedTouches[0].pageX : 0;this.slideNote.y = e.changedTouches[0] ? e.changedTouches[0].pageY : 0;},endMove(e) {var newList = JSON.parse(JSON.stringify(this.itemStyle))if ((e.changedTouches[0].pageX - this.slideNote.x) < -10) {// 向左滑动var last = [newList.pop()]newList = last.concat(newList)} else if ((e.changedTouches[0].pageX - this.slideNote.x) >= 10) {// 向右滑动newList.push(newList[0])newList.splice(0, 1)}this.itemStyle = newList// 清除之前的定时器,以防多次点击clearTimeout(this.timer1);// 设置定时器,5秒后执行doSomething方法this.timer1 = setTimeout(this.doSomething, this.interval);}}}
</script><style lang="scss">.swiperPanel {margin: 20rpx 0;height: 360rpx;width: 100%;overflow: hidden;position: relative;.swiperItem {height: 100%;width: 100%;position: absolute;top: 0;left: 0;transition: all .5s;.children {height: 100%;width: 580rpx;margin: 2rpx auto;position: relative;.pic {height: 100%;width: 100%;border-radius: 20px;// box-shadow: 0 0 10px #333;}.name {position: absolute;width: 100%;bottom: 0;left: 0;background: rgba(0, 0, 0, 0.5);box-shadow: 0rpx 4rpx 21rpx 0rpx rgba(0, 0, 0, 0.07);border-radius: 0 0 20px 20px;height: 85rpx;line-height: 85rpx;font-family: Source Han Sans SC, Source Han Sans SC;font-weight: 400;font-size: 32rpx;color: #FFFFFF;text-align: center;font-style: normal;text-transform: none;}}}}
</style>
  1. 组件使用
	<view class=""><componentSwiper :swiper-list="spotList" /></view>
<script>
import componentSwiper from '@/components/componentSwiper.vue'
export default {components: {componentSwiper},data() {return {spotList:[{url: 'https://cdn.uviewui.com/uview/goods/1.jpg',name: '这是一个图片'},{url: 'https://cdn.uviewui.com/uview/goods/1.jpg',name: '这是一个图片'}]}}
}
  1. 以上为全部代码,希望可以帮到您,您也可以更具自身需求进行修改。
  2. 日常记录!完成。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/35331.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Verilog刷题笔记48——FSM1型异步复位

题目: 解题&#xff1a; module top_module(input clk,input areset, // Asynchronous reset to state Binput in,output out);// parameter A0, B1; reg state, next_state;always (*) begin // This is a combinational always block// State transition logiccase(…

Python Type Hint有啥用

Python 的类型提示&#xff08;Type Hint&#xff09;是 Python 3.5 引入的一种静态类型检查功能。类型提示的主要目的是增强代码的可读性、可维护性和错误检测能力。虽然 Python 仍然是动态类型的语言&#xff0c;但类型提示可以帮助开发者在编码和维护过程中受益匪浅。 类型…

VMware vSphere 8.0 Update 3 发布下载 - 企业级工作负载平台

VMware vSphere 8.0 Update 3 发布下载 - 企业级工作负载平台 vSphere 8.0U3 | ESXi 8.0U3 & vCenter Server 8.0U3 请访问原文链接&#xff1a;https://sysin.org/blog/vmware-vsphere-8-u3/&#xff0c;查看最新版。原创作品&#xff0c;转载请保留出处。 作者主页&am…

【yolov8:报错AttributeError: ‘Segment‘ object has no attribute ‘detect‘】

今天在运行yolov8的Segment模式的val模型测验时报错&#xff1a; AttributeError: ‘Segment’ object has no attribute ‘detect’ 原因是yolov8的版本问题&#xff0c;更新至最新版就可以了&#xff1a; 输入ultralytics查看版本 卸载当前的老版本 然后下载最新版本就可以…

【前端】Vue项目和微信小程序生成二维码和条形码

前言&#xff1a;哈喽&#xff0c;大家好&#xff0c;我是前端菜鸟的自我修养&#xff01;今天给大家分享Vue项目和微信小程序如何生成二维码和条形码&#xff0c;介绍了JsBarcode、wxbarcode等插件&#xff0c;并提供具体代码帮助大家深入理解&#xff0c;彻底掌握&#xff01…

5G与自动驾驶

上篇&#xff08;5G与4G的区别-CSDN博客&#xff09;讲了4G与5G的区别&#xff0c;大家可以看到5G具备高带宽、低时延的特性&#xff0c;可以广泛应用于各种物联网场景。 今天和大家简单聊聊5G与自动驾驶。 自动驾驶依靠人工智能、视觉计算、雷达、监控装置和全球定位系统协同…

Android Gradle开发与应用:Gradle基础

Android Gradle开发与应用&#xff1a;Gradle基础 Gradle是一款开源的自动化构建工具&#xff0c;已成为Android官方首推的自动化构建工具线。以下是关于Gradle在Android开发中的基础知识和应用&#xff0c;将按照几个关键点进行分点表示和归纳。 1. Gradle的基本概念 Proje…

关于mybatis中Mapper对应xml要写参数名的

1. 问题: 当我们在Mapper和xml之中传递参数时,必须要用Param注解来标识参数名, 否则参数就对应不上, 但每个参数都写Param就很烦人, 情况如下: mapper: User findById(Param("id") Long id); xml: <select id"findById" resultType"com.hz.doma…

为什么要学Java?

想要自己教会自己java&#xff0c;从小白成长到架构师。实现硬实力就业&#xff01; 因为Java是全球排名第一的编程语言&#xff0c;Java工程师也是市场需求最大的软件工程师&#xff0c;选择Java&#xff0c;就是选择了高薪。 为什么Java应用最广泛&#xff1f; 从互联网到…

软件测试:实验一 黑盒测试技术

一、实验目的 掌握黑盒测试的基本概念和原理&#xff0c;基本方法和技术。学会运用边界值、等价类划分方法对应用程序进行测试。学会使用测试用例对应用程序进行实际测试&#xff0c;并记录测试结果。 二、实验要求 分析被测应用程序&#xff0c;选定合适的黑盒测试方法。根…

基于FreeRTOS+STM32CubeMX+LCD1602+MCP4141(SPI接口)的数字电位器Proteus仿真

一、仿真原理图: 二、运行效果: 三、软件部分: 1)、SPI读写: 2)、初始化部分: void SystemClock_Config(void) { RCC_OscInitTypeDef RCC_OscInitStruct = {0}; RCC_ClkInitTypeDef RCC_ClkInitStruct = {0}; /** Initializes the CPU, AHB and APB busses clocks …

基于python爬虫对豆瓣影评分析系统的设计与实现

基于python爬虫对豆瓣影评分析系统的设计与实现 Design and Implementation of a Python-based Web Crawler for Analyzing Douban Movie Reviews 完整下载链接:基于python爬虫对豆瓣影评分析系统的设计与实现 文章目录 基于python爬虫对豆瓣影评分析系统的设计与实现摘要第一…

SQL连接与筛选:解析left join on和where的区别及典型案例分析

文章目录 前言数据库在运行时的执行顺序一、left join on和where条件的定义和作用left join on条件where条件 二、left join on和where条件的区别原理不同left join原理&#xff1a;where原理&#xff1a; 应用场景不同执行顺序不同&#xff08;作用阶段不同&#xff09;结果集…

Netty学习(二)——黏包半包、协议设计解析、聊天室

一、粘包与半包 1.1 粘包和半包复现 1、粘包复现&#xff1a; Server代码&#xff1a; public class ProblemServer {public static void main(String[] args) throws InterruptedException {new ServerBootstrap()//若是指定接收缓冲区大小&#xff1a;就会出现黏包、半包…

测试零一万物大模型

听闻李开复先生创业的零一大模型很牛逼&#xff0c;一大早测试了一下。 代码 &#xff08;python) from openai import OpenAI API_BASE "https://api.lingyiwanwu.com/v1" API_KEY "61310vvvvvvc975" client OpenAI(api_keyAPI_KEY,base_urlAPI_BASE…

搜维尔科技:CyberGlove Systems 是数据手套技术的全球领导者,提供市场上最先进的以手为中心的 3D 动作捕捉解决方案

CyberGlove Systems 是数据手套技术的全球领导者&#xff0c;提供市场上最先进的以手为中心的 3D 动作捕捉解决方案 搜维尔科技&#xff1a;快速了解 SenseGlove 的 Nova VR 触觉力反馈手套

Python3 学习笔记——基本知识入门 | 菜鸟教程

Python3 学习笔记——基本知识入门 | 菜鸟教程 目录 Python3 学习笔记——基本知识入门 | 菜鸟教程基础知识标识符python保留字注释行与缩进多行语句数字(Number)类型字符串(String)空行等待用户输入同一行显示多条语句多个语句构成代码组print 输出import 与 from...import命令…

DDR3控制器(一)DDR3 IP调用

目录 一、DDR3 IP核简介 二、DDR3 IP核调用 在千兆以太网通信中用到了DDR3控制器&#xff0c;但是并没有对其做相关介绍。这次准备重新整理一下DDR3控制相关知识&#xff0c;复习巩固一下。 一、DDR3 IP核简介 MIG IP核&#xff08;Memory Interface Generator&#xff09;是…

String buffer和String builder区别

在Java中&#xff0c;StringBuffer和StringBuilder都是用于创建可变的字符序列的类&#xff0c;但它们之间有一些重要的区别&#xff0c;主要体现在线程安全性和性能方面。 StringBuffer 线程安全&#xff1a;StringBuffer中的方法是同步的&#xff08;synchronized&#xff0…

【人工智能】python之人工智能应用篇--数字人生成技术

数字人生成技术概述 数字人生成技术是基于人工智能技术和计算机图形学技术创建的虚拟人物形象的技术。该技术能够模拟人类的外貌、声音、动作和交流能力&#xff0c;为多个领域带来创新的应用可能性。数字人的本质是将所有信息&#xff08;数字和文字&#xff09;通过数字处理…