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

vue循环渲染动态展示内容案例(“更多”按钮功能)

当我们在网页浏览时,常常会有以下情况:要展示的内容太多,但展示空间有限,比如我们要在页面的一部分空间中展示较多的内容放不下,通常会有两种解决方式:分页,“更多”按钮

今天我们的案例用于更多按钮的功能实现。

比如我们要展示这样的效果:

fedc8924d64147ae87b68518cc7467d4.png

红框框是我们要展示的内容,当我们点击更多时,就会依次排列更多的红色框框。

 比如我们有这样一些内容要展示:

const newCourseList = ref([{id:"1",name:"英特尔实时计算中级课程",type:"",videoNum:"10",studyNum:"5946",imgUrl:"src/assets/images/newcourse/newcourse1.png"},{id:"2",name:"英特尔实时计算初级课程",type:"",videoNum:"10",studyNum:"6682",imgUrl:"src/assets/images/newcourse/newcourse2.png"},{id:"3",name:"OpenCV高级认证课程",type:"",videoNum:"10",studyNum:"8963",imgUrl:"src/assets/images/newcourse/newcourse3.jpg"},{id:"4",name:"OpenCV初级认证课程",type:"",videoNum:"10",studyNum:"5869",imgUrl:"src/assets/images/newcourse/newcourse4.jpg"},{id:"5",name:"英特尔® OpenVINO™工具套件初级课程——2024焕新版",type:"",videoNum:"10",studyNum:"5869",imgUrl:"src/assets/images/newcourse/newcourse5.jpg"},{id:"6",name:"英特尔® OpenVINO™工具套件中级课程",type:"",videoNum:"10",studyNum:"5869",imgUrl:"src/assets/images/newcourse/newcourse6.png"},{id:"7",name:"英特尔® OpenVINO™工具套件高级课程",type:"",videoNum:"10",studyNum:"5869",imgUrl:"src/assets/images/newcourse/newcourse7.jpg"},{id:"8",name:"英特尔® Smart Edge Open初级认证课程",type:"",videoNum:"10",studyNum:"5869",imgUrl:"src/assets/images/newcourse/newcourse8.png"},{id:"9",name:"1",type:"",videoNum:"10",studyNum:"5869",imgUrl:"src/assets/images/newcourse/newcourse8.png"},{id:"10",name:"2",type:"",videoNum:"10",studyNum:"5869",imgUrl:"src/assets/images/newcourse/newcourse8.png"},{id:"11",name:"3",type:"",videoNum:"10",studyNum:"5869",imgUrl:"src/assets/images/newcourse/newcourse8.png"},{id:"12",name:"4",type:"",videoNum:"10",studyNum:"5869",imgUrl:"src/assets/images/newcourse/newcourse8.png"},{id:"13",name:"5",type:"",videoNum:"10",studyNum:"5869",imgUrl:"src/assets/images/newcourse/newcourse8.png"},{id:"14",name:"6",type:"",videoNum:"10",studyNum:"5869",imgUrl:"src/assets/images/newcourse/newcourse8.png"},{id:"15",name:"7",type:"",videoNum:"10",studyNum:"5869",imgUrl:"src/assets/images/newcourse/newcourse8.png"},{id:"16",name:"8",type:"",videoNum:"10",studyNum:"5869",imgUrl:"src/assets/images/newcourse/newcourse8.png"},
])

一共16条数据,但是我们最初始要展示七条数据,当单击一次更多按钮要展示13条数据。也就是每次单击都再展示6条数据。

首先我们要对布局分析,我们可以将整个布局看成一行,左边第一个元素独占一列。右边的其他元素可以占整体一个列,然后再分行分列。这里我们用到elementui中的格子模式,每行占24个格子。整体看,每行有4个元素。比如第一个元素我们给6个格子。那么其他位置我们需要每行展示3个元素,后边自己分一行就又是24个格子,三个元素,每个元素8个格子。

我们要确定,前七条数据先怎么展示出来,这里有个问题就是第一个框框的大小跟其他的不一样,而且第一个一直就是那唯一的一个,所以我们就不将第一个元素写在循环渲染内,除了第一个,其他都用循环写。

那么第一个元素我们可以这样写:

<el-row :span="24" style="width: 1240px;margin: 0px auto;" :gutter="15"><el-col :span="6">  <div style="height: 530px;width: 100%;background-color: #fff;border-radius: 5px;margin-bottom:10px;"><RouterLink :to="`/course/coursecontent/${newCourseList[0].id}`"><img style="width: 100%;height: 400px;border-radius: 5px 5px 0px 0px;" v-img-lazy="newCourseList[0].imgUrl" alt="" /><div><div style="padding: 20px; font-size: 16px;font-family: PingFangSC-Regular, sans-serif;text-overflow: ellipsis;white-space: nowrap;overflow: hidden;">{{ newCourseList[0].name }}</div><div style="font-size: 12px;margin-left: 20px;" ><el-icon size="20" style="position:relative;top:5px;margin: 0 5px 0 0px"><VideoCamera/></el-icon><span>{{newCourseList[0].videoNum}}</span></div></div></RouterLink></div></el-col>
<el-row>

说明:el-row是elementui中的行元素代表一个行,el-col代表一个列,:span后面是代表这个行/列占得格子数。

newCourseList的第一个元素也就是newCourseList[0],打点调用每条数据中的内容。上述代码就将第一个元素展示出来了。

其他元素我们就需要用到循环渲染了

因为第一个元素占了6个格子,后面其他元素一起占一列,那就是18个格子。内部再分行,那么每行又是24个格子,所以一个元素是8个格子。

<el-col :span="18"><el-row :span="24"><el-col :span="8" v-for="course in newCourseList" :key="course.id"><div style="height: 256px;width: 100%;background-color: #fff;border-radius: 5px;margin-bottom:10px;"><RouterLink :to="`/course/coursecontent/${course.id}`"><img style="width: 100%;height: 160px;border-radius: 5px 5px 0px 0px;" v-img-lazy="course.imgUrl" alt="" /><div><div style="padding: 20px; font-size: 16px;font-family: PingFangSC-Regular, sans-serif;text-overflow: ellipsis;white-space: nowrap;overflow: hidden;">{{ course.name }}</div><div style="font-size: 12px;margin-left: 20px;" ><el-icon size="20" style="position:relative;top:5px;margin: 0 5px 0 0px"><VideoCamera/></el-icon><span>{{course.videoNum}}</span></div></div></RouterLink></div></el-col></el-row></el-col>

我们在内部列中使用了循环渲染,这样实现了显示的功能,但是有个问题:这样写右侧不会只显示6个元素,而是将所有数据展示出来。

为了解决这个问题我们可以建立一个新对象,来装我们要展示的六条数据,然后去循环展示这个新对象,注意:循环时是从第二条数据开始的,因为第一条数据不参与循环。

创建对象:

const listCopy=ref(newCourseList.value.slice(1,7))

上述代码我们创建了一个对象listCopy,初始值用来装newCourseList的下标值为1-6的数据。

修改后的代码

<el-col :span="18"><el-row :span="24"><el-col :span="8" v-for="course in listCopy" :key="course.id"><div style="height: 256px;width: 100%;background-color: #fff;border-radius: 5px;margin-bottom:10px;"><RouterLink :to="`/course/coursecontent/${course.id}`"><img style="width: 100%;height: 160px;border-radius: 5px 5px 0px 0px;" v-img-lazy="course.imgUrl" alt="" /><div><div style="padding: 20px; font-size: 16px;font-family: PingFangSC-Regular, sans-serif;text-overflow: ellipsis;white-space: nowrap;overflow: hidden;">{{ course.name }}</div><div style="font-size: 12px;margin-left: 20px;" ><el-icon size="20" style="position:relative;top:5px;margin: 0 5px 0 0px"><VideoCamera/></el-icon><span>{{course.videoNum}}</span></div></div></RouterLink></div></el-col></el-row></el-col>

接下来又有一个问题,就是怎么在单击“更多”时,多展示六条数据。

我们可以为“更多”设置一个单击事件,然后触发一个函数修改被循环的对象:listCopy的值。

<el-row style="background-color:#f6f8fb; height: 150px;" justify="center" align="middle" type="flex"><div style="width:200px;background: transparent;border: 1px solid #999;color: #999;text-align: center;font-size: 12px;padding: 18px 75px;border-radius: 4px;" @click="changeList()">更多竞赛</div></el-row>

我设置了名为changeList的函数。

接下来我们需要考虑两种情况:

1、剩余数据大于6条,2、剩余数据不足6条

第一种情况,我们需要控制listCopy的数据只增加6条。

第二种情况,剩余几条增加几条就可以。

函数内部代码:

const changeList=()=>{let count=listCopy.value.length+1;let maxCount=newCourseList.value.length-1;let sub=maxCount-count>6?6:maxCount-count;for(let i=0;i<sub;i++){listCopy.value.push(newCourseList.value[count+i])}}

说明:count变量用来装我们需要newCourseList的哪个下标值开始增加给listCopy。maxCount用来装剩余数据的最大下标值sub用来装我们要追加几条数据:如果大于6,sub就是6,如果不大于6就是剩余数据的最大下标值减去从哪个下标值开始,也就是还剩几条。

for循环就是对listCopy对象的数值进行追加。

例如第一次:count的值为7,也就是从id为8的数据开始追加给listCopy。maxCount值为15,一共16条,最大下标值为15。sub值为6,因为maxCount-count=15-7=8,8>6所以sub的值为6。那么for循环将执行6次。第一次向listCopy中push:newCourseList下标值为7的数据,第二次是newCourseList下标值为8的数据。

这样我们就实现了最初的功能。

页面效果:f2becdded46d4ac2ab11af66457f1832.png

单击一次:

 192a5de88761434f9a1156491eebaed9.png

单击两次:

953b3e6ff16741fd87a31574c0f9af0a.png

相关文章:

vue循环渲染动态展示内容案例(“更多”按钮功能)

当我们在网页浏览时&#xff0c;常常会有以下情况&#xff1a;要展示的内容太多&#xff0c;但展示空间有限&#xff0c;比如我们要在页面的一部分空间中展示较多的内容放不下&#xff0c;通常会有两种解决方式&#xff1a;分页&#xff0c;“更多”按钮。 今天我们的案例用于…...

好用的工具网址

代码类&#xff1a; 1,json解析&#xff1a;JSON在线解析及格式化验证 - JSON.cn 2.传参转化编码 在线url网址编码、解码器-BeJSON.com 日常&#xff1a; 1.莆田医院查询&#xff1a;滚蛋吧&#xff01;莆田系...

【Temporal】方法规范

在workflow或者childWorkflow的方法代码中&#xff0c;不能使用golang的一些库方法&#xff0c;比如sleep&#xff0c;go协程等&#xff0c;必须使用其对应的封装方法&#xff0c;比如对应关系如下&#xff1a; time.Sleep -> workflow.Sleepgo xx -> workflow.Go(xx) 这…...

Python实现图形学曲线和曲面的Bezier曲线算法

目录 使用Python实现图形学曲线和曲面的Bezier曲线算法引言Bezier曲线的数学原理1. Bezier曲线定义2. Bezier曲线的递归形式 Python实现Bezier曲线算法1. 代码实现 代码详解使用示例Bezier曲线的特点Bezier曲面的扩展Bezier曲面类实现 总结 使用Python实现图形学曲线和曲面的Be…...

Unity数据持久化4——2进制

概述 基础知识 各类型数据转字节数据 文件操作相关 文件相关 文件流相关 文件夹相关 练习题 using System; using System.Collections; using System.Collections.Generic; using System.IO; using System.Text; using UnityEngine;public class Exercises1 : MonoBehaviour {/…...

经典sql题(八)SQL 查询详细指南总结一

SQL 查询详细指南 SQL&#xff08;Structured Query Language&#xff09;是一种用于管理和操作关系数据库的标准语言。本文将详细介绍 SQL 中的一些常见操作及其用法&#xff0c;包括 DISTINCT 去重、LIMIT 限制、排序、开窗函数、NULL 值替换、JOIN 与 UNION 等。 1. DISTI…...

用Python实现时间序列模型实战——Day 30: 学习总结与未来规划

在第30天&#xff0c;我们将对整个学习过程进行总结&#xff0c;复习关键知识点&#xff0c;并展望未来的学习与应用方向。我们将涵盖时间序列分析过程中涉及的主要模型、技术和工具&#xff0c;总结它们的优势和应用场景。此外&#xff0c;规划未来如何进一步深入学习&#xf…...

ChatGPT居然主动勾引用户,OpenAI又测试新功能? 一文教你学会订阅

有网友表示&#xff0c;他收到了ChatGPT主动给他发送的消息&#xff0c;询问“你高中的第一周过得怎么样&#xff1f;还适应吗&#xff1f;” 他很懵逼的回了一句“你刚才是给我发消息吗&#xff1f;”。也就是说&#xff0c;在没有任何先前文本提示下&#xff0c;ChatGPT主动…...

基于SpringBoot+Vue的考研百科网站系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、SSM项目源码 精品专栏&#xff1a;Java精选实战项目源码、Python精…...

深度之眼(三十)——pytorch(一)--深入浅出pytorch(附安装流程)

文章目录 一、前言一、pytoch二、六个部分三、如何学习四、学习路径&#xff08;重要)五、安装pytorch5.1 坑15.2 坑2 一、前言 我看了下目录 第一章和第二章都是本科学的数字图像处理。 也就是这一专栏&#xff1a;数字图像实验。 所以就不准备学习前两章了&#xff0c;直接…...

麒麟银河桌面版,成功安装cuda12.6,mysql

一、 要卸载并禁用 nouveau 驱动程序&#xff0c;可以按照以下步骤进行&#xff1a; 1. 确认 nouveau 驱动的当前状态&#xff1a; 首先&#xff0c;你可以使用以下命令查看 nouveau 驱动是否正在运行&#xff1a; lsmod | grep nouveau如果有输出&#xff0c;说明 nouveau …...

CentOS 7 YUM源不可用

CentOS 7 操作系统在2024年6月30日后将停止官方维护&#xff0c;并且官方提供的YUM源将不再可用。 修改&#xff1a;nano /etc/yum.repos.d/CentOS-Base.repo # CentOS-Base.repo [base] nameCentOS-$releasever - Base baseurlhttp://mirrors.aliyun.com/centos/$rel…...

Java反序列化利用链篇 | URLDNS链

文章目录 URLDNS链调用链分析Payload编写 系列篇其他文章&#xff0c;推荐顺序观看~ Java反序列化利用链篇 | JdbcRowSetImpl利用链分析Java反序列化利用链篇 | CC1链_全网最菜的分析思路Java反序列化利用链篇 | CC1链的第二种方式-LazyMap版调用链Java反序列化利用链篇 | URLD…...

Android 短信验证码自动填充

本文主要介绍国外google上线的app 短信自动填充方案。 本方案主要是使用google提出的&#xff0c;防止开发者使用SMS相关权限造成的用户信息泄露 目录 注意点&#xff1a; 1、本方式不适合华为手机&#xff0c;华为有自己的获取方式 2、本方式不需要添加任何短信权限 3、…...

数据库 MySQL 是否需要容器化?

容器的定义&#xff1a;容器是为了解决“在切换运行环境时&#xff0c;如何保证软件能够正常运行”这一问题。 目前&#xff0c;容器和 Docker 依旧是技术领域最热门的词语&#xff0c;无状态的服务容器化已经是大势所趋&#xff0c;同时也带来了一个热点问题被大家所争论不以…...

Kettle的安装及简单使用

Kettle的安装及简单使用一、kettle概述二、kettle安装部署和使用Windows下安装案例1&#xff1a;MySQL to MySQL案例2&#xff1a;使用作业执行上述转换&#xff0c;并且额外在表stu2中添加一条数据案例3&#xff1a;将hive表的数据输出到hdfs案例4&#xff1a;读取hdfs文件并将…...

Golang | Leetcode Golang题解之第420题强密码检验器

题目&#xff1a; 题解&#xff1a; func strongPasswordChecker(password string) int {hasLower, hasUpper, hasDigit : 0, 0, 0for _, ch : range password {if unicode.IsLower(ch) {hasLower 1} else if unicode.IsUpper(ch) {hasUpper 1} else if unicode.IsDigit(ch)…...

面试金典题3

URL化。编写一种方法&#xff0c;将字符串中的空格全部替换为%20。假定该字符串尾部有足够的空间存放新增字符&#xff0c;并且知道字符串的“真实”长度。 示例 1&#xff1a; 输入&#xff1a;"Mr John Smith ", 13 输出&#xff1a;"Mr%20John%20Smith&…...

FFmpeg开发笔记(五十六)使用Media3的Exoplayer播放网络视频

Android早期的MediaPlayer控件对于网络视频的兼容性很差&#xff0c;所以后来单独推出了Exoplayer库增强支持网络视频&#xff0c;在《Android Studio开发实战&#xff1a;从零基础到App上线(第3版)》一书第14章的“14.3.3 新型播放器ExoPlayer”就详细介绍了Exoplayer库的详细…...

Python使用总结之py-docx将word文件中的图片保存,并将内容返回

Python使用总结之py-docx将word文件中的图片保存&#xff0c;并将内容返回 使用py-docx读取word文档的内容&#xff0c;其中包含标题、文本和图片等信息。该方法将标题和内容返回&#xff0c;并将文件中的图片保存到指定的文件夹中。 实现步骤 加载文件内容读取文件的段落对文…...

Windows LTSC应用商店增强工具:从功能缺失到体验升级的完整方案

Windows LTSC应用商店增强工具&#xff1a;从功能缺失到体验升级的完整方案 【免费下载链接】LTSC-Add-MicrosoftStore Add Windows Store to Windows 11 24H2 LTSC 项目地址: https://gitcode.com/gh_mirrors/ltscad/LTSC-Add-MicrosoftStore 你是否遇到过这样的困境&a…...

nli-distilroberta-base案例集锦:12个已落地NLI应用场景与技术实现要点

nli-distilroberta-base案例集锦&#xff1a;12个已落地NLI应用场景与技术实现要点 1. 项目概述 nli-distilroberta-base是一个基于DistilRoBERTa模型的自然语言推理(NLI)Web服务&#xff0c;专门用于判断两个句子之间的关系。这个轻量级但强大的模型能够快速准确地分析句子对…...

Z-Image-Turbo_UI界面场景应用:快速制作电商产品概念图

Z-Image-Turbo_UI界面场景应用&#xff1a;快速制作电商产品概念图 1. 引言&#xff1a;电商产品概念图制作的新选择 在电商行业&#xff0c;产品概念图的制作一直是设计师和运营人员的痛点。传统方式需要专业设计软件和大量时间投入&#xff0c;而Z-Image-Turbo_UI界面提供了…...

YALMIP求解器报错看不懂?从verbose到debug,教你快速定位并解决优化问题

YALMIP求解器报错看不懂&#xff1f;从verbose到debug&#xff0c;教你快速定位并解决优化问题 当你满怀期待地运行YALMIP优化代码&#xff0c;却看到命令行突然跳出一片红色报错信息时&#xff0c;那种挫败感每个优化工程师都深有体会。"No feasible solution found"…...

5个技巧让旧MacBook Pro重获新生:OpenCore Legacy Patcher完全指南

5个技巧让旧MacBook Pro重获新生&#xff1a;OpenCore Legacy Patcher完全指南 【免费下载链接】OpenCore-Legacy-Patcher 体验与之前一样的macOS 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 随着科技的快速迭代&#xff0c;许多经典Ma…...

遇到复杂车线桥耦合分析总被建模效率卡脖子?试试Simpack+Abaqus/ANSYS这套组合拳,咱们直接上干货聊聊那些提效黑科技

simpack abaqus ansys车线桥耦合高效建模分析工具 1.快速生成非线性柔性轨节点处mark 2.桥梁纵向轨底处的对应的mark及坐标 3.快速建立力元并设置preload方向 4.免安装运行环境点击exe输入 5.基于ansys或者abaqus和simpack联合仿真的5跨、3跨简支梁车线桥耦合分析实例轨节点标记…...

ollama-QwQ-32B模型微调:提升OpenClaw任务执行准确率的实战方法

ollama-QwQ-32B模型微调&#xff1a;提升OpenClaw任务执行准确率的实战方法 1. 为什么需要微调模型来优化OpenClaw 上周三凌晨3点&#xff0c;我被一阵刺耳的提示音惊醒——OpenClaw又闯祸了。它本应自动整理我的项目文档&#xff0c;却误删了3个关键文件夹&#xff0c;还把桌…...

【BLE系列-第四篇】数据链路层(LL)实战:广播与连接参数优化指南

1. BLE数据链路层核心参数解析 低功耗蓝牙&#xff08;BLE&#xff09;的数据链路层&#xff08;LL&#xff09;就像交通系统中的红绿灯和道路规划&#xff0c;它决定了设备间如何高效、稳定地建立通信。在实际开发中&#xff0c;我经常遇到工程师对着几十个参数发愁&#xff1…...

基于模型参考的滑模控制/MRSMC 基于模型参考的滑模控制(MRSMC, Model Refe...

基于模型参考的滑模控制/MRSMC 基于模型参考的滑模控制&#xff08;MRSMC, Model Reference Sliding Mode Control&#xff09;是一种结合了模型参考控制和滑模控制优点的控制策略。 它通常用于系统的鲁棒控制&#xff0c;尤其是在面对模型不确定性和外部扰动时。 在simulink中…...

【菜鸟飞】Conda环境管理与vscode无缝协作实战指南

1. Conda环境管理入门&#xff1a;从零搭建Python工作区 第一次接触Conda时&#xff0c;我被它强大的环境隔离能力惊艳到了。想象你正在装修房子&#xff0c;Conda就像给你的每个项目分配了独立的房间——在这个房间里&#xff0c;你可以随意摆放家具&#xff08;安装依赖包&am…...