web蓝桥杯真题:年度明星项目

代码及注释:

javascript 复制代码
//全部数据
var allData = []
// 每次需要加载的数量
var num = 15

// TODO: 请在此补充代码实现项目数据文件和翻译数据文件的请求功能
$.get({url: './js/all-data.json'}).then(res => {
  allData = res
  loading(allData, num)   //初始加载数据
})
$.get({url: './js/translation.json'}).then(res => {
  translation = res
})
// TODO-END

// TODO: 请修改以下代码实现项目数据展示的功能
function loading(data, num) {
  $("ul > li").remove() //对已有的项目置空
  data.forEach((item, index) => { //每次加载num个项目,其中对描述(中文或英文)做出处理
    if(index < num) {  //需要展示的项目数组
      const element = { 
        icon: item.icon,
        description: currLang == "zh-cn" ? item.descriptionCN : item.descriptionEN,
        name: item.name,
        stars: item.stars,
        tags: item.tags,
      };
      // 添加至页面的项目列表中,查看页面可以看到有一行 bun 的项目数据
      $(".list > ul").append(createProjectItem(element));
    }
  })
}
// TODO-END

//点击更多
$(".load-more").click(() => {
  num += 15     //数量加15
  loading(allData, num)   //调用loading函数
  document.querySelector('.load-more').style.display = "none"
})

// 用户点击切换语言的回调
$(".lang").click(() => {
  // 切换页面文字的中英文
  if (currLang === "en") {
    $(".lang").text("English");
    currLang = "zh-cn";
  } else {
    $(".lang").text("中文");
    currLang = "en";
  }
  $("body")
    .find("*")
    .each(function () {
      const text = $(this).text().trim();
      if (translation[text]) {
        $(this).text(translation[text]);
      }
    });
  // TODO: 请在此补充代码实现项目描述的语言切换
  loading(allData, num)   //调用loading函数重新加载
});

知识点:

1.元素移除

element.remove() //删除一个子节点

parent.removeChild(child) //删除一个子节点并返回删除的节点。

2.元素添加

element.append() //添加多个节点,没有返回值

parent.appendChild(child) //追加单个节点,返回追加的 Node 节点

3.子元素选择(.list > ul) //.list类名下的ul标签元素

4.请求ajax.get({url: '...'}).then(res => { ...})

相关推荐
lihaozecq2 分钟前
Agent 开发的 skills 机制设计 - 渐进式披露
前端·agent·ai编程
安妮的小熊呢5 分钟前
CRMEB标准版v6.0: 商城DIY装修新升级,PS级自由设计!
运维·javascript·平面·信息可视化·小程序·开源软件
安生生申5 分钟前
uni-app 连接 JDY-31 蓝牙串口模块实践
c语言·前端·javascript·stm32·单片机·嵌入式硬件·uni-app
Restart-AHTCM10 分钟前
LangChain学习之模型 I/O 与输出解析器 (Output Parsers)(3/8)
前端·学习·langchain
Liu.77410 分钟前
Vue3结合Element Plus封装点击查看大图的自定义指令
javascript·vue.js·elementui
lqj_本人10 分钟前
鸿蒙PC:electron-markdownify 从普通 Electron 迁移到 OpenHarmony Electron HAP 的完整实践
前端·javascript·electron
代码搬运媛8 小时前
Jest 测试框架详解与实现指南
前端
counterxing9 小时前
我把 Codex 里的 Skills 做成了一个 MCP,还支持分享
前端·agent·ai编程
wangqiaowq9 小时前
windows下nginx的安装
linux·服务器·前端
之歆10 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript