vue3 - swiper插件 实现PC端的 视频滑动功能(仿抖音短视频)

 swiper官网

​​​​​​swiper属性/组件查询


vue中使用swiper

  • 步骤:

npm install swiper 安装

② 基础模板:

<div>
    <swiper class="swiper-box" :direction="'vertical'"
                :grabCursor="true" 
                :mousewheel="true" 
                :mousewheelControl="true" 
                :resistanceRatio = "0"
                :observeParents = "true"
                :options="swiperOption">
            <!-- 幻灯片内容 -->
            <swiper-slide class="slide-box" v-for="(item, index) in dataList" :key="index">
                <div><video class="video-box" ref="videos" controls autoplay :videoList="item" :src="item.url" :index="index" ></video></div>
                <div class="info-bar-" >...</div>
                <div class="video-box-right">...</div>
            </swiper-slide>
    </swiper>
</div>
<script>
import { Swiper, SwiperSlide } from 'swiper/vue';
import "swiper/swiper-bundle.css";
export default {
    name: 'VideoList',
    components: {
        Swiper,
        SwiperSlide,
    },
    data() {
        return {...}
    }
}
</script>

  如图:


  • 属性:

direction = " 'vertical' " ,滑动方向,vertical 垂直方向。(注:一定要两对引号包裹着,否则不生效,还要给swiper设置实高)

modules = "modules"

grabCursor="true",鼠标手掌形状,拖动时变抓手形状

slidesPerView = "1",slider容器能够同时显示的slides数量(carousel模式)

mousewheel = "true",鼠标滚轮控制Swiper切换

setWrapperSize="true",swiper使用flexbox布局,这个会在wrapper上   添加等于slides相加的宽和高

observeParents = "true",当Swiper 的祖先元素发生变化时,例如show/hide、第一级子元素增加/删除等,则更新Swiper 并触发 observerUpdate 事件

resistanceRatio: 0,抵抗率。边缘抵抗力的大小比例。值越小抵抗越大越难将slide拖离边缘,0时完全无法拖离。

navigation="true",导航栏

autoplay = "true",自动播放

loop = "true",无限循环播放

space-between,每张轮播图之间的距离,该属性不可以和margin属性同时使用。

pagination = "{ clickable: true }",分页器(是否点击圆点切换轮播)

注:在标签上格式为    :属性=”值“,如 :direction="vertical"

        在 js 中格式为  属性:值 ,如 direction:verical


  •   完整代码:

<script>
import { Swiper, SwiperSlide } from 'swiper/vue';
import "swiper/swiper-bundle.css";
export default {
    name: 'VideoList',
    components: {
        Swiper,
        SwiperSlide,
    },
    data() {
        return {
            page: 1,
            swiperOption: {
                on: {
                    // tap方法 是swiper组件提供的点击方法
                    tap: () => {
                        this.playAction(this.page - 1)
                    },
                    // 上滑(屏幕向上滑时,跳到下一个视频)
                    slideNextTransitionStart: () => {
                        this.page += 1;
                        this.nextVideo(this.page - 1)
                        console.log(this.page);
                    },
                    // 下滑(屏幕向下滑时)
                    slidePrevTransitionEnd: ()=> {
                        if(this.page > 1){
                            this.page -= 1;
                            this.prevVideo(this.page - 1)
                            console.log(this.page);
                        }
                    },
                }
            }
        }
    },
    methods: {
        playAction(index) {     // 入参 是 当前屏幕显示的是第几个视频
            this.$refs.videos[index].playOrStop();
        },
        // 向下
        nextVideo(index){
            this.$refs.videos[index-1].stop()
            this.$refs.videos[index].play()
        },
        // 向上
        prevVideo(index){
            this.$refs.videos[index+1].stop()
            this.$refs.videos[index].play()
        },
    },
    setup(){
    }
}
</script>

<script setup>
import { ref } from 'vue';

const dataList = [
    {
        id: "1",
        url:"http://s32p8v831.hd-bkt.clouddn.com/2023-09-23%2012.00.00_%23%E5%B4%A9%E5%9D%8F%E6%98%9F%E7%A9%B9%E9%93%81%E9%81%93__%23%E8%82%AF%E5%BE%B7%E5%9F%BA%E6%98%9F%E7%A9%B9%E9%93%81%E9%81%93__%23%E5%B8%AE%E5%B8%AE%E6%88%91%E8%82%AF%E5%BE%B7%E5%9F%BA%E7%88%B7%E7%88%B7___%E7%82%B8%E9%B8%A1_%E6%89%A7%E8%A1%8C__KI%E4%B8%8A%E6%A0%A1%E7%AB%9F%E7%84%B6%E4%B9%9F%E6%9C%89%E9%9A%90%E8%97%8F%E7%9A%84%E5%8A%9B%E9%87%8F___KI%E4%B8%8A%E6%A0%A1%E6%88%90%E5%8A%9F%E5%8F%91%E5%8A%A8%E8%82%AF%E5%BE%B7%E5%9F%BA%E7%BB%88%E7%BB%93%E6%8A%80_%E7%8E%B0%E5%9C%BA%E8%B6%85%E9%9C%87%E6%92%BC%E8%A7%86%E9%A2%91%E4%BC%A0%E5%9B%9E_%E4%B8%80%E8%B5%B7%E6%9D%A5%E7%9C%8B%E7%9C%8B%E5%B8%95__video-transcode..mp4",
    },
    {
        id: "2",
        url:"http://s32p8v831.hd-bkt.clouddn.com/2023-09-21%2021.00.08_%23%E8%82%AF%E5%BE%B7%E5%9F%BA%E7%87%83%E6%83%85%E4%BA%9A%E8%BF%90%E5%AD%A3_%E5%92%8C%E5%8F%AF%E7%88%B1%E7%9A%84%E5%90%89%E7%A5%A5%E7%89%A9_%E5%B0%8F%E6%9C%8B%E5%8F%8B%E4%BB%AC%E4%B8%80%E8%B5%B7%E8%B7%B3%E4%BA%9A%E8%BF%90%E5%8A%A0%E6%B2%B9%E6%93%8D_%E4%B8%BA%E4%BA%9A%E8%BF%90%E5%8A%A0%E6%B2%B9%E5%8A%A9%E5%A8%81__video-transcode..mp4",
    },
]

</script>
<template>
    <div class="swiper-wrapper">
        <swiper class="swiper-box" :direction="'vertical'"
                :grabCursor="true" 
                :mousewheel="true" 
                :mousewheelControl="true" 
                :resistanceRatio = "0"
                :observeParents = "true"
                :options="swiperOption">
            <!-- 幻灯片内容 -->
            <swiper-slide class="slide-box" v-for="(item, index) in dataList" :key="index">
                <div><video class="video-box" controls ref="videos" :videoList="item" :src="item.url" :index="index" autoplay></video></div>
                <div class="infobar_warp" ><InfoBar :info-data="item" /></div>
                <div class="video-box-right"><LikeComponent :like-data="item"></LikeComponent></div>
            </swiper-slide>
        </swiper>
    </div>
</template>

<style scoped lang="scss">
.swiper-wrapper {
    /* width: 100vw ;  */
    height: calc(100vh - 100px);
    .swiper-box {
        width: 100%;
        .slide-box {
            .video-box {
                width: 100%;
                height: calc(100vh - 100px);
            }
            .video-box-right {
                position: absolute;
                right: 0;
                bottom: 30vh;
                top: 30vh;
                /* z-index: 80; */
            }
            .infobar_warp {
                position: absolute;
                bottom: 55px;
                left: 0;
            }
        }
    }
}
</style>
  • 比较完整的swiper教程:

vue3中使用swiper7轮播图插件_swiper7实例_爱唱歌的前端的博客-CSDN博客

vue3中使用swiper完整版教程_swiper vue3-CSDN博客

如何在vue3中使用swiper插件(教程)_vue3 安装swiper-CSDN博客


滑动功能 实现参考文章:

vue实战 实现视频类webapp:(十二) 视频评论列表 - 小专栏vue项目中使用swiper(版本3.1.3)实现视频轮播_vue 视频轮播-CSDN博客

基于vue封装移动触摸滑动组件——简易的swiper_vue 滑动-CSDN博客

vue+swiper仿抖音视频滑动_swiper + video 短视频-CSDN博客 (多个播放按钮)

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【Mybatis小白从0到90%精讲】12:Mybatis删除 delete, 推荐使用主键删除!

文章目录 前言XML映射文件方式推荐使用主键删除注解方式工具类前言 在实际开发中,我们经常需要删除数据库中的数据,MyBatis可以使用XML映射文件或注解来编写删除(delete)语句,下面是两种方法的示例。 XML映射文件方式 Mapper: int delete(int id);Mapper.xml:

使用easyui前端框架快速构建一个crud应用

本篇文章将会详细介绍jquery easyui前端框架的使用&#xff0c;通过创建一个crud应用来带大家快速掌握easyui的使用。 easyui是博主最喜欢的前端框架&#xff0c;没有之一&#xff0c;因为它提供了多种主题&#xff0c;而且圆润可爱的组件吸引了我。 快速开始 easyui的官网地址…

css控制卡片内部的左右布局

先放效果图 纯css样式 可以根据需求进行更改 <template> <!-- 卡片盒子 --><div class"card_box "><el-card class"box-card w400" v-for"(item,index) in cardList" :key"index"><div slot"heade…

山西电力市场日前价格预测【2023-11-09】

日前价格预测 预测说明&#xff1a; 如上图所示&#xff0c;预测明日&#xff08;2023-11-09&#xff09;山西电力市场全天平均日前电价为369.84元/MWh。其中&#xff0c;最高日前电价为784.47元/MWh&#xff0c;预计出现在17: 45。最低日前电价为158.90元/MWh&#xff0c;预计…

【Python爬虫库】pytube使用方法

一、pytube库简介 pytube库是一个python第三方库&#xff0c;用于youtube视频的抓取和其他相关操作。官方文档&#xff1a;pytube 二、基本操作 1、显示视频标题 from pytube import YouTube yt YouTube(https://youtube.com/watch?vIAJsZWhj6GI) print(yt.title)说明&am…

分享5款会带来意想不到效果的软件

​ 有时候一些小工具&#xff0c;能给你带来一些意想不到的效果&#xff0c;我们来看看下面这5款工具&#xff0c;你又用过其中几款呢&#xff1f; 1.密码管理器——Bitwarden ​ Bitwarden是一款开源的密码管理器&#xff0c;可以安全地生成、存储和分享密码和其他敏感信息。…

汽车发动机各系统部件构造图解及名称大全(超详细)

我们都知道发动机是汽车的心脏,相信大家都有东拼西凑的学一些发动机知识,今天汽车维修网小编给大家系统的整理整个发动机的基础知识,如果能认真看完,相信肯定有所收获。全文3065字,81幅结构图,建议收藏、分享后再慢慢看。 首先我们来看一下 发动机总成构造图解 发动机…

Excel和Chatgpt是最好的组合。

内容来源&#xff1a;bitfool1 Excel和Chatgpt是最好的组合。 您可以轻松地自动化数据处理。 我向您展示如何在不打字公式的情况下将AI与Excel一起使用&#xff1a; 建立chatgpt 主要目的是使用Chatgpt自动编写Excel宏。 这消除了键入公式的需求&#xff0c;并让您在自然语言…

9.斐波那契数列

斐波那契数列&#xff08;Fibonacci sequence&#xff09;&#xff0c;也称之为黄金分割数列&#xff0c;由意大利数学家列昂纳多・斐波那契&#xff08;Leonardo Fibonacci&#xff09;提出。斐波那契数列指的是这样的一个数列&#xff1a;1、1、2、3、5、8、13、21、34、………

CSS 对齐、组合选择符、伪类、伪元素、导航栏

一、CSS 对齐&#xff1a; 1&#xff09;、元素居中对齐&#xff1a; 水平居中对齐一个元素&#xff0c;可以使用margin&#xff1a;auto&#xff0c;设置到元素的宽度将防止它溢出到容器的边缘。元素通过指定宽度&#xff0c;并将两边的空外边距平均分配。示例&#xff1a; …

mysql之子表查询、视图、连接查询

1、子查询返回的结果只能是某列&#xff0c;不能是多列。where条件in什么&#xff0c;子查询的列就是什么 &#xff08;1&#xff09;多表联查&#xff08;不要超过3张表&#xff09;重点 ①in包含 ②not in取反&#xff08;加上where条件过滤&#xff0c;否则没意义&#xff…

《嵌入式虚拟化技术与应用》:深入浅出阐述嵌入式虚拟机原理,实现“小而能”嵌入式虚拟机!

目录 关于博主前言专家推荐本书适合谁&#xff1f;内容简介书本目录权威作者团队其他 关于博主 &#x1f680;Python爬虫项目实战系列文章&#xff01;&#xff01; ⭐⭐欢迎订阅⭐⭐ 【Python爬虫项目实战一】获取Chatgpt3.5免费接口文末付代码&#xff08;过Authorization认…

uniapp 微信小程序 uni-file-picker上传图片报错 chooseAndUploadFile

这个问题真的很搞&#xff0c; 原因是微信开发者工具更新了&#xff0c;导致图片上传问题。 解决方法&#xff1a; 将微信开发者工具的基础库改为2.33.0一下即可。 在微信开发者工具详情 - 本地设置中&#xff08;记得点击‘推送’按钮&#xff09;&#xff1a;

双十一最值得买什么?双十一怎么买划算?数码年度好物盘点

​双11狂欢的号角已经吹响&#xff0c;各位小伙伴们是否已经做好了“冲锋”的准备&#xff1f;想必早已准备好了各种必买好物、囤货清单&#xff01;为了帮助大家更好地了解数码产品的优惠情况和推荐理由&#xff0c;我们为大家准备了一份双十一数码推荐&#xff0c;帮助大家在…

51单片机-定时计数器

文章目录 前言1 原理2.编程 前言 1 原理 2.编程 定时计算&#xff1a; 50ms501000us 一个机器周期&#xff1a;1.085us 65535 - 501000/1.08546082 故 40082*1.08549998.97 /*定时器1&#xff0c;定时模式 工作模式1 16位计数器&#xff0c; 定时20秒后使能蜂鸣器*/ #include…

Linux CentOS 8(HTTPS的配置与管理)

Linux CentOS 8&#xff08;HTTPS的配置与管理&#xff09; 目录 一、HTTPS 介绍二、SSL 证书的介绍三、实验配置 一、HTTPS 介绍 HTTPS 在 HTTP 的基础下加入 SSL&#xff0c;SSL 是“Secure Sockets Layer”的缩写&#xff0c;中文为“安全套接层”。因此 HTTPS 是以安全为目…

RabbitMQ 消息中间件 消息队列

RabbitMQ1、RabbitMQ简介2、RabbitMQ 特点3、什么是消息队列4、RabbiMQ模式5、集群中的基本概念 单实例安装RabbitMQ安装依赖安装erlang安装rabbitmq开启rabbitmq的web访问界面添加用户修改配置文件重启服务浏览器访问Rabbit-test rabbitMQ集群准备工作&#xff08;三台&#x…

rabbitmq下载安装教程

1.首先需要下载erlang和rabbitmq安装包&#xff1a; 官网下载比较慢&#xff0c;通过网盘下载&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1fM2BrJqefyzUDZD4tfZLIg 提取码&#xff1a;5hsu 2.安装&#xff0c;傻瓜式安装就可以&#xff0c;可以自定义自己要安装的目…

SQL左连接实战案例

要求&#xff1a;用表df1和表df2的数据&#xff0c;得到df3 一、创建表 CREATE TABLE df1 (姓名 varchar(255) DEFAULT NULL,年龄 int DEFAULT NULL,部门 varchar(255) DEFAULT NULL,id int DEFAULT NULL );CREATE TABLE df2 (部门 varchar(255) DEFAULT NULL,年龄 int DEFAU…

探索环保葡萄酒之生物动力

根据生物动力农业和园艺协会的说法&#xff0c;生物动力农业是“一种精神-伦理-生态的农业、园艺、食品生产和营养方法。”生物动力农民将他们的农场或葡萄园视为一个坚固的有机体&#xff0c;一个自我维持的生态系统。这些农业哲学和实践在整个农业周期中应用了一种整体方法。…