当前位置: 首页 > wzjs >正文

绚丽的网站欣赏手机网站分辨率做多大

绚丽的网站欣赏,手机网站分辨率做多大,如何做自己官方网站,建筑效果图用什么软件制作从零用java实现 小红书 springboot vue uniapp(13)实战:用SwiperVideo打造抖音式丝滑视频流 移动端演示 http://8.146.211.120:8081/#/ 管理端演示 http://8.146.211.120:8088/#/ 项目整体介绍及演示 前言 在上一篇文章中我们实现了视频笔记…

从零用java实现 小红书 springboot vue uniapp(13)实战:用Swiper+Video打造抖音式丝滑视频流

移动端演示 http://8.146.211.120:8081/#/

管理端演示 http://8.146.211.120:8088/#/

项目整体介绍及演示

前言

在上一篇文章中我们实现了视频笔记的发布功能,现在,我们将攻克一个更核心的体验功能:创建一个像抖音、快手那样的全屏、可上下滑动切换的视频信息流。这不仅仅是UI的堆砌,背后涉及到 swipervideo 组件的深度联动、视频生命周期的精细化管理、以及数据预加载等关键技术。本文将详细拆解其实现过程。


在这里插入图片描述

核心技术实现

我们的目标是当用户向上或向下滑动时,上一个视频能自动暂停,下一个视频能自动播放,并且列表能无限滚动加载。我们将围绕 videoDetail.vue 文件来展开。

1. 基础布局:Swiper 与 Video 的结合

首先,我们搭建页面的骨架。外层使用 swiper 组件作为滑动容器,并设置其 vertical="true" 来实现垂直滚动。内部通过 v-for 循环渲染 swiper-item,每个 swiper-item 中放置一个全屏的 video 组件。

<template><swiper class="swiper-container" :vertical="true" @change="handleSwiperChange" :current="currentIndex"><swiper-item v-for="(video, index) in videoData" :key="video.noteId"><view class="video-container"><video class="video" :src="video.videoUrl":id="`video_${index}`" :loop="true":controls="false"@timeupdate="handleTimeUpdate"></video><!-- 其他UI元素,如点赞、评论按钮等 --></view></swiper-item></swiper>
</template>
  • @change="handleSwiperChange":这是实现功能的核心,每当滑动切换视频时,该事件会被触发。
  • :id="'video_' + index":为每个video组件设置一个唯一的ID,这是后续通过代码精确控制视频播放/暂停的关键。
2. 视频播放控制:uni.createVideoContext

要用代码控制视频,我们必须先获取到每个视频的实例,即 VideoContext

我们在 data 中创建一个数组 videoContexts: [] 用于存储这些实例。然后,在页面数据加载并渲染完成后,初始化它们。

// script
export default {data() {return {videoData: [],currentIndex: 0,videoContexts: []};},onReady() {// onReady生命周期确保了组件已渲染this.initVideoContexts();},methods: {initVideoContexts() {this.videoContexts = []; // 清空旧实例this.videoData.forEach((item, index) => {// 通过 video 的 id 创建并存储 contextthis.videoContexts[index] = uni.createVideoContext(`video_${index}`, this);});// 自动播放第一个视频if (this.videoContexts[this.currentIndex]) {this.videoContexts[this.currentIndex].play();}}}
}
3. 核心交互:滑动切换与自动播放

所有的关键都发生在 handleSwiperChange 方法中。当用户滑动 swiper 时,我们需要:

  1. 暂停上一个正在播放的视频。
  2. 播放当前显示的新视频。
methods: {handleSwiperChange(event) {const { current } = event.detail;// 记录上一个视频的索引const previousIndex = this.currentIndex;// 暂停上一个视频if (this.videoContexts[previousIndex]) {this.videoContexts[previousIndex].pause();}// 更新当前视频的索引this.currentIndex = current;this.paused = false; // 重置手动暂停状态// 延时播放当前视频,确保滑动手势完成setTimeout(() => {if (this.videoContexts[this.currentIndex]) {this.videoContexts[this.currentIndex].play();}}, 250);},
}
4. 数据流:无限滚动与预加载

为了实现“刷不完”的效果,我们需要在用户快要滑到底部时,提前加载下一页的数据。

数据加载:
我们封装一个 loadVideos 方法,通过分页参数(page, pageSize)从后端获取视频列表,并追加到 videoData 数组中。

触发加载:
我们在 swiper 组件上监听 @scrolltolower 事件(在uniapp中,需要自己根据 currentIndex 模拟)。当用户滑动到倒数N个视频时(例如 preloadThreshold = 2),就调用 loadVideos

// 在 handleSwiperChange 方法的最后调用
handleSwiperChange(event) {// ...上面的播放/暂停逻辑...// 检查是否需要加载更多视频this.checkAndLoadMore();
},methods: {checkAndLoadMore() {// 当滑动到倒数第 preloadThreshold 个视频时,加载更多const isNearEnd = this.currentIndex >= this.videoData.length - this.preloadThreshold;if (isNearEnd && this.hasMore && !this.loading) {this.loadVideos(); // 该方法内部会请求API并追加数据}},loadVideos() {if(this.loading || !this.hasMore) return;this.loading = true;uni.app.get('/auth/getVideoNotes', { page: this.page, limit: this.pageSize }, '', (res => {// ...处理返回的数据...const newVideos = res.data.records || [];this.videoData = [...this.videoData, ...newVideos];this.hasMore = newVideos.length >= this.pageSize;this.page++;this.loading = false;// !! 关键:数据更新后,需要重新初始化新增的 video contextthis.$nextTick(() => {this.initVideoContexts();});}));}
}

注意: 每次加载新数据后,videoData 数组都变了,因此需要重新调用 initVideoContexts 来为新加入的视频创建 VideoContext 实例。


在这里插入图片描述

通过以上四步,我们就完整地实现了一个功能强大且体验流畅的抖音式视频流。

代码地址
https://gitee.com/ddeatrr/springboot_vue_xhs


文章转载自:

http://hyTiFgZa.yrmgh.cn
http://hqADbBqr.yrmgh.cn
http://XGFiHTtQ.yrmgh.cn
http://VYZiqiJg.yrmgh.cn
http://ogn3KsNO.yrmgh.cn
http://QalGXKfz.yrmgh.cn
http://hyXdxCln.yrmgh.cn
http://3bm4zyld.yrmgh.cn
http://xtbZRPhO.yrmgh.cn
http://P7lFOClt.yrmgh.cn
http://efInt3Mo.yrmgh.cn
http://VKWUFl1v.yrmgh.cn
http://mbsDayDW.yrmgh.cn
http://8Co4nAY3.yrmgh.cn
http://PROcq1Ah.yrmgh.cn
http://1aYt2NLm.yrmgh.cn
http://FyloeXFH.yrmgh.cn
http://iHJPaIeB.yrmgh.cn
http://TnDkaL3d.yrmgh.cn
http://VveK3bg6.yrmgh.cn
http://2sUyM3MX.yrmgh.cn
http://bmgqcEL1.yrmgh.cn
http://nm3rNWkb.yrmgh.cn
http://88aWr7nx.yrmgh.cn
http://Kxfy03VE.yrmgh.cn
http://jp1okIYp.yrmgh.cn
http://YtDt2suF.yrmgh.cn
http://I7g9fFmB.yrmgh.cn
http://R56Z3k11.yrmgh.cn
http://akms7yrS.yrmgh.cn
http://www.dtcms.com/wzjs/715346.html

相关文章:

  • 网站没有备案怎么做淘宝客wordpress增加用户组
  • 用于建设教学网站的建站工具有哪些特点国际时事新闻
  • 网站建设 jz.woonl阿里云备案要关网站吗
  • 用网站做微信公众号正规接单赚佣金的平台
  • 申请网站网站百度网页版登录
  • 上海企业建站推荐ASP.NET实用网站开发答案
  • 国外特效网站邢台一天seo
  • 新乡网站开发的公司电话网站建设大概需要多少钱
  • 做ppt的素材免费网站wordpress微信公众号采集
  • 金华建设工程网站编一个公司网址
  • 系统数据库与建设网站吉安微信网站
  • 鄂州网站建设哪家专业上海企业信用网查询
  • 亳州市网站建设中企动力做的网站山西太原
  • 建设部建造师网站聊城定制化网站建设
  • 职业教育专业建设验收网站ztjs登录
  • 网站如何让百度收录做图软件官方网站
  • 兴义网站建设建筑网校排行榜
  • 长沙 汽车 网站建设什么是网络营销调研?它有什么特点?
  • 建设网站页面wordpress主题后门代码检测
  • 静态网站开发的目的如何分析网站关键词
  • 镇海建设交通局网站网站建设主流编程软件
  • 简述网站设计的原则网网站建设与设计
  • django 做的网站国内国际时事写实记录2024
  • 中国的网站做欧美风免费微信小程序模板
  • 淘宝客做连接网站吗360推广开户
  • 网站内容上传要求江西中慧城乡建设开发公司网站
  • 成都有什么好玩的吗牡丹江关键词优化
  • 网站实现多语言简洁大气企业网站
  • 论坛网站建设源码下载广东专业做网站
  • 建设网站的协议范本杭州做商业地产开什么网站好