备赛蓝桥杯之第XX届职业院校组省赛第七题:Github 明星项目统计

news/2025/3/13 18:50:34/

提示:本篇文章仅仅是作者自己目前在备赛蓝桥杯中,自己学习与刷题的学习笔记,写的不好,欢迎大家批评与建议


由于个别题目代码量与题目量偏大,请大家自己去蓝桥杯官网【连接高校和企业 - 蓝桥云课】去寻找原题,在这里只提供部分原题代码

本题目为:2024年十五届省赛职业院校组真题第七题:Github 明星项目统计


题目:

需要考生作答的代码段如下:

                <!-- TODO: 待补充代码 --><select name="language" id="language" @change="changeHandle" v-model="language"><option value="All">All</option></select>
            // 语言筛选改变时或页面数字输入框数字改变时的处理函数const changeHandle = () => {// TODO:待补充代码initChart();};

题目要求:

  1. 将可供筛选的语言列表 `languages` 在 `select` 标签下的 `option` 元素进行渲染, **`option` 的 `value` 值必须对应绑定 `languages` 数组中的值**。效果如下:

  2. 完善 `changeHandle` 函数,当用户选择语言和输入显示位次的时候都会调用此函数。当用户改变 `select` 筛选器的选项或改变展示项目的位次输入时,根据用户的**选择**和**输入的位次**重新渲染图表。注意:**重新渲染图表必须通过修改 `xData` 和 `yData` 的值进行,不要修改变量名称**。

答案:

                <!-- TODO: 待补充代码 --><select name="language" id="language" @change="changeHandle" v-model="language"><option v-for="lang in languages" :value="lang" :index="lang">{{lang}}</option></select>
            // 语言筛选改变时或页面数字输入框数字改变时的处理函数const changeHandle = () => {// TODO:待补充代码let newData = chartData.value.filter((item) => {return item.language == language.value})if (language.value === 'All') newData = chartData.value;newData = newData.slice(pageStart.value - 1, pageEnd.value);xData.value = newData.map(item => item.name);yData.value = newData.map(item => item.stars);initChart();};

拓展学习

本题作者想说

目标1:

  1. v-for="lang in languages":这是一个Vue.js的循环指令,用于遍历languages数组,为数组中的每个元素生成一个<option>元素。
  2. :value="lang":将每个<option>元素的value属性设置为当前循环到的lang值。
  3. :index="lang":将每个<option>元素的index属性设置为当前循环到的lang值。注意,这里:index并不是Vue.js的标准属性,可能是自定义属性,用于在JavaScript中获取当前选项的索引。
  4. {{lang}}:将当前循环到的lang值显示为<option>元素的文本内容。

目标2:

实现原理

  1. 过滤数据:首先,通过chartData.value.filter方法,根据language.value的值来过滤chartData中的数据。如果language.value等于'All',则不过滤,直接使用所有数据。

  2. 分页数据:接着,使用slice方法对过滤后的数据进行分页处理。pageStart.value - 1pageEnd.value定义了要显示的数据范围。

  3. 更新图表数据:通过map方法,将分页后的数据映射到xData.valueyData.value中,分别表示图表的横轴和纵轴数据。

  4. 初始化图表:最后,调用initChart函数来重新初始化图表,以反映最新的数据。


感谢观看此篇文章,谢谢大家的支持,本片文章只是我自己学习的历程,有些写的不好地方欢迎大家交流改动。

长路漫漫,我们还需努力!


http://www.ppmy.cn/news/1578853.html

相关文章

pdf修改内容:分享5款好用的工具

pdf修改内容用什么软件&#xff1f;PDF内容修改工具的便捷性很大地提升了我们的工作效率。通过这些工具&#xff0c;我们可以轻松地对PDF文档进行文字编辑、图片替换、页面调整等操作&#xff0c;无需繁琐的转换步骤。这些修改工具不仅操作简便&#xff0c;而且功能强大&#x…

Electron使用WebAssembly实现CRC-32 常用标准校验

Electron使用WebAssembly实现CRC-32 常用标准校验 将C/C语言代码&#xff0c;经由WebAssembly编译为库函数&#xff0c;可以在JS语言环境进行调用。这里介绍在Electron工具环境使用WebAssembly调用CRC-32 常用标准格式校验的方式。 CRC-32 常用标准校验函数WebAssembly源文件…

Kotlin 中实现静态方法的几种方式

在 Kotlin 中&#xff0c;与 Java 不同&#xff0c;Kotlin 并不直接支持在类中定义静态方法&#xff08;static 方法&#xff09;。不过&#xff0c;Kotlin 提供了多种替代方式来实现类似的功能&#xff0c;例如通过 object 单例、companion object 伴生对象 或 顶级函数。以下…

2025年渗透测试面试题总结-华顺某信安-安全服务工程师(题目+回答)

网络安全领域各种资源&#xff0c;学习文档&#xff0c;以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各种好玩的项目及好用的工具&#xff0c;欢迎关注。 华顺某信安-安全服务工程师 红蓝队经验 对于shiro漏洞了解多少 APP测试经历 xposed用的什么框架&#xff0c;有…

项目上传到Gitee过程

在gitee上新建一个仓库 点击“克隆/下载”获取仓库地址 电脑上要装好git 在电脑本地文件夹右键“Git Bash Here” 依次执行如下命令 git init git remote add origin https://gitee.com/qlexcel/stm32-simple.git git pull origin master git add . git commit -m ‘init’…

网络安全之tcpdump工具

引言 wireshark是一款非常不错的抓包软件&#xff0c;在图形化界面占绝对统治地位&#xff1b;尽管其在字符界面下有些许选项可供使用&#xff0c;但终究不太方便&#xff0c;下面我再介绍一款NB的终端抓包工具 tcpdump 1、混杂模式 linux的网卡有混杂模式一说&#xff0c;当开…

20天 - TCP 和 UDP 有什么区别?说说 TCP 的三次握手?TCP 是用来解决什么问题?

TCP 和 UDP 有什么区别&#xff1f; TCP&#xff08;传输控制协议&#xff09;和 UDP&#xff08;用户数据报协议&#xff09;都是传输层的网络协议&#xff0c;它们的主要区别如下&#xff1a; 连接方式 TCP&#xff1a;面向连接的协议&#xff0c;类似于打电话&#xff0c…

《Python实战进阶》No17: 数据库连接与 ORM(SQLAlchemy 实战)

No17: 数据库连接与 ORM&#xff08;SQLAlchemy 实战&#xff09; 摘要 本文深入探讨SQLAlchemy在复杂场景下的高级应用&#xff0c;涵盖四大核心主题&#xff1a; 会话生命周期管理&#xff1a;通过事件钩子实现事务监控与审计追踪混合继承映射&#xff1a;结合单表/连接表继…