14届蓝桥杯web职高院校组省赛真题解析


目录

1.电影院排座位

2.图片水印生成

3.收集帛书碎片

4. ⾃适应⻚⾯

5.  外卖给好评

6. 视频弹幕

7. ISBN转换与⽣成 

8. 全球新冠疫情数据统计 

9.  ⻣架屏

10. 组课神器  


 1.电影院排座位

介绍

随着⼈们⽣活⽔平的⽇益提升,电影院成为了越来越多的⼈休闲娱乐,周末放松的好去处。各个城市的 电影院数量也随着市场的需求逐年攀升。近⽇,⼜有⼀个电影院正在做着开张前期的准备,⼩蓝作为设 计⼯程师,需要对电影院的座位进⾏布局设计。 本题需要在已提供的基础项⽬中,使⽤ CSS 完成⻚⾯中电影院座位布局。

准备

开始答题前,需要先打开本题的项⽬代码⽂件夹,⽬录结构如下:

├── css

│      └── style.css

└── index.html

其中: index.html 是主⻚⾯。 css/style.css 是需要补充样式的⽂件。 在浏览器中预览 index.html ,显示如下所示

⽬标

请在 css/style.css ⽂件中的 TODO 下补全样式代码,最终达到预期布局效果,需要注意:

  座位区域和荧幕间隔 50px。
  座位区域每⼀⾏包含 8 个座位。
  第 2 列和第 6 列旁边都是⾛廊,需要和下⼀列间隔 30px,其他列都只需要间隔       10px。
完成后的效果如下:

       

 规定

 请勿修改 css/style.css ⽂件外的任何内容。
 请严格按照考试步骤操作,切勿修改考试默认提供项⽬中的⽂件名称、⽂件夹路径、class名、id 名、图⽚名等,以免造成判题⽆法通过。
 完成答题后,考⽣需将题⽬对应代码⽂件夹压缩成 zip 格式后上传提交,其他压缩包格式为 0 分。
 判分标准

 本题完全实现题⽬⽬标得满分,否则得 0 分。

/* TODO:待补充代码 */

/* 弹性布局 */
.seat-area{
  display: flex;
  flex-wrap: wrap;
  margin-top: 40px;
}

.seat{
  margin-left: 10px;
  margin-top: 10px;
}

.seat:nth-child(8N + 1){
  margin-left: 0;
}

.seat:nth-child(8N + 2){
  margin-right: 20px;
}

.seat:nth-child(8N + 7){
  margin-left: 30px;
}

运行结果:

2.图片水印生成

介绍

很多⽹站都会通过给图⽚添加⽔印的形式来标记图⽚来源,维护版权。前端⽣成⽔印通常是通过 canvas 实现,但实际上我们也可以直接利⽤ CSS 来实现图⽚⽔印,这样做会有更好的浏览器兼容 性。

本题中你将封装⼀个创建⽂字⽔印的函数。

准备

开始答题前,需要先打开本题的项⽬代码⽂件夹,⽬录结构如下:

├── css

│      └── style.css

├── images

│      └── origin.png

├── index.html

└── js

       ├── dom-to-image.min.js

       └── index.js

其中:

index.html 是主⻚⾯。
css/style.css 是样式⽂件。
js/index.js 是需要补充代码的 js ⽂件。
js/dom-to-image.min.js 是⽣成图⽚的第三⽅库,此⽂件⽆需修改。
images/origin.png 是项⽬中的原始图⽚⽂件。
在浏览器中预览 index.html ⻚⾯效果如下所示:

 ⽬标

请完善 js/index.js ⽂件中的 TODO 部分,实现创建⽔印函数的功能 ,创建的⽔印需要使⽤ <span>标签展示。

createWatermark 函数参数说明:

 完成后的效果如下:

 规定

请严格按照考试步骤操作,切勿修改考试默认提供项⽬中的⽂件名称、⽂件夹路径、class 名、id 名、图⽚名等,以免造成判题⽆法通过。
完成答题后,考⽣需将题⽬对应代码⽂件夹压缩成 zip 格式后上传提交,其他压缩包格式为 0 分。
判分标准

本题完全实现题⽬⽬标得满分,否则得 0 分。

/**
 * 创建一个文字水印的div
 * @param  {string} text - 水印文字
 * @param  {string} color - 水印颜色
 * @param  {number} deg - 水印旋转角度
 * @param  {number} opacity - 水印透明度
 * @param  {number} count - 水印数量
 */
function createWatermark(text, color, deg, opacity, count) {
  // 创建水印容器
  const container = document.createElement("div");
  container.className = "watermark";
  // TODO: 根据输入参数创建文字水印
  for(let i=0;i<count;i++){
    container.innerHTML += `<span style="color:${color};transform:rotate(${deg}deg);opacity:${opacity};">${text}</span>`;
  }
  return container;
  
}

3.收集帛书碎片

介绍

三叔在外出考古途中⽆意发现了⼀份战国帛书,帛书边缘有被明显裁剪过的痕迹,单从帛书⽚段,提到 记录了神秘⽂物的地点,⽆奈帛书不完整,为了早⽇将⽂物带回博物馆,三叔号召当地村⺠闷油瓶、王 胖⼦、潘⼦共同寻找剩余帛书碎⽚,相约⼀炷⾹后再聚。

本题需要在已提供的基础项⽬中使⽤ JS 知识封装⼀个函数,达到收集帛书碎⽚的要求。

准备 开始答题前,需要先打开本题的项⽬代码⽂件夹,⽬录结构如下:

├── js

│      └── collect-puzzle.js

├── css

│      └── style.css

├── images

└── index.html

其中:

index.html 是主⻚⾯。
css/style.css 是样式⽂件。
images 是图⽚⽂件夹。
js/collect-puzzle.js 是需要补充代码的 js ⽂件。
在浏览器中预览 index.html ⻚⾯,显示如下所示:

 目标:

请在 collect-puzzle.js ⽂件中补全函数 collectPuzzle 中的代码,返回包含不同帛书碎⽚的数 组,最终拼出完整的战国帛书,需要注意:

同⼀个⼈收集的帛书碎⽚可能是有重复的。
同⼀组内不同的⼈收集的帛书碎⽚也可能是有重复的。
⼯具函数需要统计所有⼈获取的不同帛书碎⽚,⽽不是帛书碎⽚数量。
例如:

 // 不同组内的帛书碎⽚不能重复计算

var arr1 = ["灾变", "四时运转", "天象"];

var arr2 = ["四时运转"];

var result1 = collectPuzzle(arr1, arr2);

console.log(result1); // 输出:["灾变","四时运转","天象"]

// 同⼀组内的帛书碎⽚不能重复计算

var arr3 = ["灾变", "灾变", "天象"];

var arr4 = ["灾变", "⽉令禁忌", "天象"];

var result2 = collectPuzzle(arr3, arr4);

console.log(result2); // 输出:["灾变", "天象","⽉令禁忌"]

上述仅为示例代码,判题时会随机提供数组对该函数功能进⾏检测。

在题⽬所提供的数据的情况下,点击合成按钮,完成后的效果如下:

 规定

请勿修改 collect-puzzle.js ⽂件外的任何内容。
判题时会随机提供数组对该函数功能进⾏检测,请保证函数的通⽤性,不能仅对测试数据有效。
请严格按照考试步骤操作,切勿修改考试默认提供项⽬中的⽂件名称、⽂件夹路径、class 名、id 名、图⽚名等,以免造成判题⽆法通过。
完成答题后,考⽣需将题⽬对应代码⽂件夹压缩成 zip 格式后上传提交,其他压缩包格式为 0 分。
判分标准

 完全实现题⽬⽬标得满分,否则得 0 分。

function collectPuzzle(...puzzles) {
  // TODO: 在这里写入具体的实现逻辑
 let result = []
 for(let i=0;i<puzzles.length;i++){
  result.push(...puzzles[i])
 }
 
 result = [...new Set(result)]  //去重

 return result
}

 4. ⾃适应⻚⾯

介绍

响应式布局是在 2010 年 5 ⽉份提出的⼀个概念,这个概念是为解决移动互联⽹浏览⽽诞⽣的。简⽽⾔ 之,就是⼀个⽹站能够兼容多个终端——⽽不是为每个终端做⼀个特定的版本。通过响应式布局可以为 不同终端的⽤户提供更加舒适的界⾯和更好的⽤户体验,⽽且随着⼤屏幕移动设备的普及,⽤“⼤势所 趋”来形容也不为过。因此越来越多的设计师采⽤这个技术。

本题需要在已提供的基础项⽬中,使⽤ CSS 或者 DOM 操作达到 Menu 和内容⻚⾃适应的效果。

准备

开始答题前,需要先打开本题的项⽬代码⽂件夹,⽬录结构如下:

├── css

│      └── style.css

├── images

│      ├── C++_course.png

│      ├── linux_course.png

│      └── python_course.png

├── index.html

├─── js

│        └── jquery-3.6.0.min.js

├── default.gif

└── effect.gif

其中:

index.html 是主⻚⾯。
css/style.css 是需要补充样式的⽂件。
js/jquery-3.6.0.min.js 是 jQuery 库⽂件。
images 是图⽚⽂件夹。
default.gif 是 PC 端默认效果图。
effect.gif 是移动端⾃适应效果图。
在浏览器中预览 index.html ⻚⾯,默认 PC 端⻚⾯显示如下所示:

 ⽬标:

初始⻚⾯已经具备基础的布局和交互效果,包含 hover ⾼亮,展示⼆级菜单等。效果⻅⽂件夹下⾯的 gif 图,图⽚名称为 default.gif (提示:可以通过 VS Code 或者浏览器预览 gif 图⽚)。

请通过补全 css/style.css 中代码或结合 jQuery 操作 DOM 的⽅式,达到根据屏幕⼤⼩显示不同布局 的效果。

以 800px 为界限, 800px 以上显示 PC 端布局,否则显示移动端布局,需要实现移动端布局样式 如下:
       

移动端 Menu 由左上侧按钮(即 class 包含 icon-menu 的 label 标签)控制显隐,按钮⼤⼩已 经默认提供,⽆需⼿动设置⼤⼩。且 Menu 按钮展示时,需要浮动在内容卡⽚上⽅,不能被遮挡, 移动端和 PC 端顶部导航栏⾼度⼀致,均为 54px 。
移动端导航栏的菜单项每⼀项独占⼀⾏。
显示移动端布局时,卡⽚描述和对应图⽚各占⼀⾏,且都撑满 #tutorials 容器。
移动端⻚⾯展开菜单栏效果如下所示:

 最终效果可参考⽂件夹下⾯的 gif 图,图⽚名称为 effect.gif(提示:可以通过 VS Code 或者浏览器预览 gif 图⽚)。

考⽣可以根据需要使⽤ jQuery 实现脚本控制,也可以只使⽤纯 CSS 实现。

规定

请严格按照考试步骤操作,切勿修改考试默认提供项⽬中的⽂件名称、⽂件夹路径、class 名、id 名、图⽚名等,以免造成判题⽆法通过。
完成答题后,考⽣需将题⽬对应代码⽂件夹压缩成 zip 格式后上传提交,其他压缩包格式为 0 分。
判分标准

本题完全实现题⽬⽬标得满分,否则得 0 分。


/* TODO:待补充代码 */
@media (max-width : 800px) {
  input.menu-btn,
  input[type="checkbox"].menu-btn ~ .collapse{
    display: block;
  }

  label.menu-btn{
    color: #959595;
    cursor: pointer;
    display: block;
    padding: 16px 32px;
  }

  label.menu-btn:hover{
    color: #fff;
  }

  .menu li{
    display: block;
  }

  .collapse{
    position: absolute;
    background: #252525;
    width: 100%;
  }

  .dropdown ul{
    position: relative;
  }

  .row{
    display: block;
  }

  #tutorials img{
    width: 100%;
    margin: 0;
  }
}

 5.  外卖给好评

介绍

外卖是现代⽣活中必备的⼀环。收到外卖后,各⼤平台软件常常会邀请⽤户在⼝味,配送速度等多个⽅ ⾯给与评分。在 element-ui 组件中,已经有相应的 Rate 组件,但是已有组件只能对单⼀维度进⾏评 分,在外卖评分这种场景中,样式基本上是固定的,功能也基本⼀样。若每写⼀个⻚⾯都要去复制⼀份 类似代码,就会产⽣⼤量重复的代码,既不利于后期的维护,代码也不够简洁。为此需要前端⼯程师对 element-ui 的原 Rate 组件进⾏⼆次封装。

准备

开始答题前,需要先打开本题的项⽬代码⽂件夹,⽬录结构如下:

├── element-ui-2.6.2

│      ├── element-icons.ttf

│      ├── element-icons.woff

│      ├── element-ui.min.js

│      └── element-ui.style.min.css

├── index.html

├── js

│      ├── http-vue-loader.min.js

│      └── vue.min.js

├── my-rate.vue

└── effect.gif

其中:

index.html 是主⻚⾯。
element-ui-2.6.2 ⽂件夹中存放的是 element-ui 库相关的脚本⽂件、样式⽂件及字体。
js ⽂件夹中存放的是 vue 及 http-vue-loader 库相关⽂件。
my-rate.vue 是待封装的评分组件⽂件。
effect.gif 是完成后的效果图。
在浏览器中预览 index.html ⻚⾯,显示如下所示:

 ⽬标

请在 my-rate.vue ⽂件中补充代码,具体要求如下:

1. my-rate.vue 组件能够对不同的维度进⾏评分。
2. my-rate.vue 组件对外抛出 change 事件,在三项评分均完成后,触发 change 事件, change 事件包含⼀个参数,⽤于传递改变后的分数值,其类型是对象,包含以下属性: { speed: number; flavour: number; pack: number; }
最终效果可参考⽂件夹下⾯的 gif 图,图⽚名称为 effect.gif(提示:可以通过 VS Code 或者浏览器预览 gif 图⽚)。

实现该功能所需的 el-rate 组件 api 如下:

 规定

请勿修改 my-rate.vue ⽂件外的任何内容。
请严格按照考试步骤操作,切勿修改考试默认提供项⽬中的⽂件名称、⽂件夹路径、class 名、id 名、图⽚名等,以免造成判题⽆法通过。
完成答题后,考⽣需将题⽬对应代码⽂件夹压缩成 zip 格式后上传提交,其他压缩包格式为 0 分。
判分标准

完全实现题⽬⽬标得满分,否则得 0 分。

<!-- TODO: 补全 el-rate 属性 -->
<li>
   送餐速度:<el-rate v-model="speed" show-score></el-rate>
</li>
<li >
   <!-- TODO: 补全 el-rate 属性 -->
   外卖口味:<el-rate v-model="flavour" show-score></el-rate>
</li>
<li>
   <!-- TODO: 补全 el-rate 属性 -->
   外卖包装:<el-rate v-model="pack" show-score></el-rate>
</li>
module.exports = {
  data() {
    return {
      speed: 0, // 送餐速度
      flavour: 0, // 外卖口味
      pack: 0, // 外卖包装
    };
  },
  /* TODO:待补充代码 */
  updated(){
    if(this.checkRateFinished()){
      this.emitRateChange()
    }
  },
  methods:{
    checkRateFinished(){
      return this.speed !==0 && this.flavour !==0 && this.pack !==0
    },
    emitRateChange(){
      this.$emit('change',{
        speed:this.speed,
        flavour:this.flavour,
        pack:this.pack
      })
    }
  }
};

6. 视频弹幕

介绍

弹幕指直接显现在视频上的评论,可以以滚动、停留甚⾄更多动作特效⽅式出现在视频上,是观看视频 的⼈发送的简短评论。通过发送弹幕可以给观众⼀种“实时互动”的错觉,弹幕的出现让观看过程充满乐 趣。本题需要在已提供的基础项⽬中,完成视频弹幕的功能。

准备

开始答题前,需要先打开本题的项⽬代码⽂件夹,⽬录结构如下:

├── effect.gif

├── css

│      └── style.css

├── video

│      └── video1.webm

├── index.html

└── js

        └── index.js

在浏览器中预览 index.html ⻚⾯,显示如下所示:

 ⽬标

请在 js/index.js ⽂件中补全代码。具体需求如下:

1. 补全 renderBullet 函数中的代码,控制弹幕的显示颜⾊和移动。功能说明如下:

每个弹幕内容包裹在 span 标签中,作为⼦节点插⼊到 #video 元素节点内。
⽣成的 span 元素节点相对于 #video 元素绝对定位 ,初始位置的 left 是 #video 元素的 宽, top 是 #video 元素的⾼内的随机数。 注意:需求中所需样式可直接通过已提供的 getEleStyle ⽅法获取。
弹幕每隔 bulletConfig.time (弹幕配置对象) 时间,向左移动距离为 bulletConfig.speed (弹幕配置对象)。
当弹幕最右端完全移出 #video 元素时,移除 span 元素。
2. 补全 #sendBulletBtn 元素的绑定事件,点击发送按钮,输⼊框中的⽂字出现在弹幕中,样式不 同于普通弹幕(样式红⾊字体红⾊框已设置,类名为 create-bullet )。通过调⽤ renderBullet ⽅法和正确的传参实现功能。

最终效果可参考⽂件夹下⾯的 gif 图,图⽚名称为 effect.gif(提示:可以通过 VS Code 或者浏览器预览 gif 图⽚)。

规定

请勿修改 js/index.js ⽂件外的任何内容。
请严格按照考试步骤操作,切勿修改考试默认提供项⽬中的⽂件名称、⽂件夹路径、class 名、id 名、图⽚名等,以免造成判题⽆法通过。
完成答题后,考⽣需将题⽬对应代码⽂件夹压缩成 zip 格式后上传提交,其他压缩包格式为 0 分。
判分标准

本题完全实现题⽬⽬标得满分,否则得 0 分
 

/**
 * @description 根据 bulletConfig 配置在 videoEle 元素最右边生成弹幕,并移动到最左边,弹幕最后消失
 * @param {Object} bulletConfig 弹幕配置
 * @param {Element} videoEle 视频元素
 * @param {boolean} isCreate 是否为新增发送的弹幕,为 true 表示为新增的弹幕
 *
 */
function renderBullet(bulletConfig, videoEle, isCreate = false) {
  const spanEle = document.createElement("SPAN");
  spanEle.classList.add(`bullet${index}`);
  if (isCreate) {
    spanEle.classList.add("create-bullet");
  }
  // TODO:控制弹幕的显示颜色和移动,每隔 bulletConfig.time 时间,弹幕移动的距离  bulletConfig.speed
  spanEle.innerHTML = bulletConfig.value

  spanEle.style.display = 'block'

  let {width:vwidth, height:vheight} = getEleStyle(videoEle)

  spanEle.style.left = vwidth+'px'
  spanEle.style.top = getRandomNum(vheight)+'px'

  videoEle.appendChild(spanEle)

  let timer = setInterval(()=>{
      spanEle.style.left = parseInt(spanEle.style.left) - bulletConfig.speed+'px'
      if(parseInt(spanEle.style.left) <= -64){
        if(spanEle){
          videoEle.removeChild(spanEle)
        }
        clearInterval(timer)
      }
  },bulletConfig.time)
}
document.querySelector("#sendBulletBtn").addEventListener("click", () => {
  // TODO:点击发送按钮,输入框中的文字出现在弹幕中
  let val = document.querySelector('#bulletContent').value;
  renderBullet({
    ...bulletConfig,
    isCreate:true,
    value:val,
  },
    videoEle,
    true
  )
  document.querySelector('#bulletContent').value = ''
});

 7. ISBN转换与⽣成 

介绍

国际标准书号(International Standard Book Number),简称 ISBN ,是专⻔为识别图书等⽂献⽽设计 的国际编号。2007 年 1 ⽉ 1 ⽇之前,ISBN 由 10 位数字组成,包括四个部分:组号(国家、地区、语 ⾔的代号),出版者号,书序号和检验码。2007 年 1 ⽉ 1 ⽇起,实⾏新版 ISBN,新版 ISBN 由 13 位 数字组成。新版 ISBN 编码增加了 EAN·UCC 前缀,这是为了与国际条形码编码 EAN·UCC 系统接轨。

本题请实现⼀个 ISBN-10 (旧版 10 位 ISBN )到 ISBN-13 (新版 13 位 ISBN )码的转换⼯具。

准备

开始答题前,需要先打开本题的项⽬代码⽂件夹,⽬录结构如下:

├── css

│     └── style.css

├── effect.gif

├── images

│      ├── check-one.png

│      ├── close-one.png

│      └── fail-picture.png

├── index.html

└── js

       ├── JsBarcode.ean-upc.min.js

       ├── index.js

       └── vue.min.js

其中:

css/style.css 是样式⽂件。
index.html 是主⻚⾯。
images ⽂件夹内包含了⻚⾯使⽤的 icon。
js/JsBarcode.ean-upc.min.js 是项⽬使⽤的条形码⽣成库。
js/index.js 是⻚⾯ js ⽂件。
js/vue.min.js 是 vue ⽂件。
effect.gif 是⻚⾯最终的效果图。
在浏览器中预览 index.html ⻚⾯效果如下

 ⽬标:

请在 js/index.js ⽂件中补全代码,具体需求如下:

 1. 补充 getNumbers 函数,剔除输⼊参数 str 中除了数字和⼤写 X 之外的其他字符,将其转       换为 只有纯数字和⼤写 X 字⺟的字符串。

 2. 补充 validISBN10 函数,判断输⼊参数 isbn 是否是⼀个有效的 ISBN-10 字符串,并将判       断结 果( true 或 false )返回。有效的 ISBN-10 判断⽅法如下:

 有效的 ISBN-10 字符串是只有纯数字和⼤写 X 字⺟的字符串,其前九位是 0-9 之间的任意数字,最后⼀位校验位的值取决于前九位数字。
校验位计算⽅法:⽤ 1-9 这 9 个数依次乘以前⾯的 9 位数,然后求它们的和除以 11 的余数。 如果余数为 10,则校验码⽤ X 表示,否则,校验码⽤该余数表示。
以 7-5600-3879-4 为例,它的前 9 位数是 7、5、6、0、0、3、8、7、9,则其校验码的计算 过程如下:
        1x7+2x5+3x6+4x0+5x0+6x3+7x8+8x7+9x9

        = 7+10+18+0+0+18+56+56+81

        = 246

        246 % 11 = 4

        因此,这个 ISBN-10 字符串的校验码就是4。

 以 2-5600-3879-X 为例,它的前 9 位数是 2、5、6、0、0、3、8、7、9,则其校验码的计算 过程如下:
       1x2+2x5+3x6+4x0+5x0+6x3+7x8+8x7+9x9

       = 2+10+18+0+0+18+56+56+81

       = 241 241 % 11

       = 10

       因此,这个 ISBN-10 字符串的校验码就是X。

 3. 补充 ISBN10To13 函数,将输⼊参数 isbn (⼀个有效的 ISBN-10 字符串) 转化为对应的           ISBN-13 字符串,并将转化后的字符串返回。转化步骤如下:

将 ISBN-10 字符串的最后⼀位校验位去掉,剩下前九个数字。
在字符串开头增加 978 三个数字,获得⻓度为 12 的数字字符串。
计算最后⼀位校验位。 ISBN-13 的校验码计算规则如下:⽤1分别乘书号的前12位中的奇数 位, ⽤3乘以偶数位,然后求它们的和除以10的余数,最后⽤10减去这个余数,就得到了校验 码。如果余数为0,则校验码为0。
⽐如,7-5600-3879-4 在 ISBN-13 中,就是 978-7-5600-3879-7。它的校验码计算⽅法如 下:
       9x1+7x3+8x1+7x3+5x1+6x3+0x1+0x3+3x1+8x3+7x1+9x3

       = 9+21+8+21+5+18+0+0+3+24+7+27

       = 143

       143 % 10 = 3

       10 - 3 = 7

      因此,这个 ISBN-13 字符串的校验码就是7。

下⾯是⼏个有效的 ISBN-10 号码,可供测试⻚⾯使⽤

7-5600-3879-4
0198534531
3 5982 1508 8
上述 3 个需求正确实现后⻚⾯的最终效果⻅⽂件夹下⾯的 gif 图,图⽚名称为 effect.gif (提示:可 以通过 VS Code 或者浏览器预览 gif 图⽚)。

规定

请严格按照考试步骤操作,切勿修改考试默认提供项⽬中的⽂件名称、⽂件夹路径、class 名、id 名、图⽚名等,以免造成判题⽆法通过。
完成答题后,考⽣需将题⽬对应代码⽂件夹压缩成 zip 格式后上传提交,其他压缩包格式为 0 分。
判分标准

完成⽬标 1,得 5 分
完成⽬标 2,得 10 分
完成⽬标 3,得 5 分

// 将用户输入的带分隔符的 isbn 字符串转换只有纯数字和大写 X 字母的字符串
// 入参 str 为转换为包含任意字符的字符串
function getNumbers(str) {
  // TODO: 待补充代码
  return str.replace(/[^0-9X]/g,"").toUpperCase()
}

// 验证当前 ISBN10 字符串是否有效
// 入参 str 为待判断的只有纯数字和大写 X 字母的字符串
function validISBN10(str) {
  // TODO: 待补充代码
  if(str.length !== 10){
    return false
  }
  let pre = str.slice(0,9);
  let last = 0;

  for(let i=0;i<pre.length;i++){
    last += (i+1)*parseInt(pre[i])
  }
  last %= 11

  if(last === 10){
    last = "X"
  }
  if(str.slice(-1) == last){
    return true
  }else{
    return false
  }
}

// 将用户输入的 ISBN-10 字符串转化为 ISBN-13 字符串
// 入参 isbn 为有效的 ISBN-10 字符串
function ISBN10To13(isbn) {
  // TODO: 待补充代码
  let pre = "978" + isbn.slice(0,9)
  let last = 0
  for(let i=0;i<pre.length;i++){
    if(i%2 === 0){
      last += parseInt(pre[i])
    }else{
      last += parseInt(pre[i])*3
    }
  }
pre += last % 10 !== 0 ? 10-(last%10) : 0
return pre
}

 8. 全球新冠疫情数据统计 

介绍

新冠疫情席卷全球,在此期间有很多免费的 API 和⽹站为⼈们提供了各个国家疫情数据的查询功能,这 些免费公开的数据体现出了互联⽹作为信息媒介的优越性,帮助全球⼈⺠更好的了解⼀线疫情信息。 本题请实现⼀个可以对各个国家的新冠疫情数据统计的⻚⾯。

准备

开始答题前,需要先打开本题的项⽬代码⽂件夹,⽬录结构如下:

├── css

│ └── style.css

├── effect.gif

├── index.html

└── js

       ├── axios.min.js

       ├── covid-data.json

       ├── echarts.min.js

       └── vue.min.js

其中:

css/style.css 是样式⽂件。
index.html 是主⻚⾯。
js/axios.min.js 是 axios ⽂件。
js/vue.min.js 是 vue2.x ⽂件。
js/echarts.min.js 是 echarts ⽂件。
js/covid-data.json 是⻚⾯所⽤到的新冠数据。
effect.gif 是⻚⾯最终的效果图。
在浏览器中预览 index.html ⻚⾯效果如下:

⽬标:

请在 index.html ⽂件中补全代码,具体需求如下:

1. 在组件加载时利⽤ axios 请求地址为 ./js/covid-data.json (必须使⽤该路径请求,否则可能 会请求不到数据) ⽂件中的数据。并将所有国家名称在 select 标签下的 option 元素进⾏渲染 (保留默认选项 “Select Country”),效果如下

 covid-data.json 数据参数说明:

 

 2. 当⽤户改变 select 筛选器的选择时,根据⽤户的选择改变⻚⾯中展示的国家名以及确诊和死亡⼈ 数数据。如果⽤户没有选择任何国家,则展示默认值 0 和默认标题 “请选择国家”。以选择法国为 例:

 3. ⻚⾯底部的 ECharts 图表希望显示各个国家的累计确诊⼈数,请修改 initChart 函数的内容, 使得图表 x 轴数据为国家简称,y 轴数据为累计确诊⼈数,效果如下:

 最终效果可参考⽂件夹下⾯的 gif 图,图⽚名称为 effect.gif(提示:可以通过 VS Code 或者浏览器预览 gif 图⽚)。

规定

请严格按照考试步骤操作,切勿修改考试默认提供项⽬中的⽂件名称、⽂件夹路径、class 名、id 名、图⽚名等,以免造成判题⽆法通过。
完成答题后,考⽣需将题⽬对应代码⽂件夹压缩成 zip 格式后上传提交,其他压缩包格式为 0 分。
判分标准

完成⽬标 1,得 5 分。
完成⽬标 2,得 10 分。
完成⽬标 3,得 5 分。

<!-- TODO: 请修改以下代码实现不同国家的数据展示功能 -->
        <div class="title">
          <h2>请选择国家</h2>
        </div>
        <div class="boxes">
          <div class="box1">
            <h3>确诊</h3>
            <div class="number">
              <span class="font-bold">新增:</span>
              {{currentData ? currentData.NewConfirmed : 0 }}
            </div>
            <div class="number">
              <span class="font-bold">总计:</span>
              {{currentData ? currentData.TotalConfirmed : 0 }}
             
            </div>
          </div>
          <div class="box2">
            <h3>死亡</h3>
            <div class="number">
              <span class="font-bold">新增:</span>
              {{currentData ? currentData.NewDeaths : 0 }}
              
            </div>
            <div class="number">
              <span class="font-bold">总计:</span>
              {{currentData ? currentData.TotalDeaths : 0 }}
              
            </div>
          </div>
        </div>
        <select v-model="currentCountry" @change="selectChange">
          <option value="">Select Country</option>
          <!-- 请在此渲染所有国家选项 -->
          <option v-for="country in countries" :key="country" :value="country">{{ country }}</option>
        </select>
<script>
    var vm = new Vue({
      el: "#app",
      data:{
        countries:[],
        allData:[],
        Xdata:[],
        Ydata:[],
        currentData:null,
        currentCountry:''
      },
      methods: {
        // TODO: 请修改该函数代码实现题目要求
        initChart() {
          // 初始化图表
          this.chart = echarts.init(document.getElementById("chart"));
          this.chartOptions = {
            title: {
              text: "全球感染人数前30国家累计确诊人数统计",
              x: "center",
            },
            tooltip: {
              trigger: "axis",
              axisPointer: {
                type: "shadow",
                label: {
                  show: true,
                },
              },
            },
            // 设置x轴数据
            xAxis: {
              // 这里需要显示国家名称缩写,因为有些国家的全称太长,会导致界面不美观
              data: this.Xdata,
              axisLabel: {
                show: true,
                interval: 0,
              },
            },
            yAxis: {
              type: "value",
              name: "确诊数量",
            },
            // 设置y轴数据
            series: [
              {
                data: this.Ydata,
                type: "bar",
                itemStyle: {
                  normal: {
                    color: "#a90000",
                  },
                },
              },
            ],
          };
          // 调用此方法设置 echarts 数据
          this.chart.setOption(this.chartOptions);
        },
        selectChange(){
          if(this.currentCountry != ''){
            this.allData.forEach(item => {
              if(item.Country === this.currentCountry){
                this.currentData = item
              }
            });
          }else{
            this.currentCountry = null
          }
        }
      },
      // TODO: 请在此添加代码实现组件加载时数据请求的功能
      mounted() {
        axios.get("./js/covid-data.json").then(res=>{
          this.countries = res.data.map(item=>item.Country)
          this.allData = res.data
          this.Xdata = res.data.map(item=>item.CountryCode)
          this.Ydata = res.data.map(item=>item.TotalConfirmed)
          console.log(this.allData)
          this.initChart();
        })
      },
    });
  </script>

9.  ⻣架屏

介绍

在⽹络较慢,需要⻓时间等待加载的情况下,⻣架屏可以在详细⻚⾯元素未展现时,把 DOM 结构通过 简单的⽅块或圆形勾勒出来,相对于传统的转圈等待与⽩屏来说,⽤户体验更好。下⾯请根据题⽬要 求,使⽤ Vue 封装⼀个灵活的⻣架屏组件。

准备

开始答题前,需要先打开本题的项⽬代码⽂件夹,⽬录结构如下:

├── components

│     ├── List

│     │      ├── content.js

│     │      └── index.js

│     └── Skeleton

│             ├── index.js

│             └── item.js

├── css

│      └── style.css

├── effect.gif

├── index.html

└── js

        └── vue.min.js

其中:

index.html 是主⻚⾯。
components/list 是提供的列表组件。
components/Skeleton 是⻣架屏组件。
js 是存放项⽬依赖的⽂件夹。
css 是存放项⽬样式的⽂件夹。
effect.gif 是项⽬⽬标完成效果图。
在浏览器中预览 index.html ⻚⾯,显示如下所示:

 ⽬标:

找到 Skeleton/item.js 中的 TODO 部分,完成以下⽬标:

1. 使⽤ index.html 中传递过去的数据 paragraph ,并结合 Vue 递归组件的知识,完成⻣架屏组件 的编写。

paragraph 中的属性说明如下:

 本题中的⻣架屏结构图及说明如下:

 第⼀⾏(标记 1)为 1 个矩形占位。
第⼆⾏(标记 2)分为两列(蓝⾊框),左边⼀列为三⾏组成,右边⼀列为 1 个矩形占位。
第⼆⾏左边⼀列分别为如下构成:第⼀⾏(标记 ①)为 1 个矩形占位,第⼆⾏(标记 ②)为 2 个 矩形占位,第三⾏(标记 ③)为 4 个圆形+1 个矩形占位。
type 和 DOM 结构的对应关系如下:

<div class="ske-${type}-container">
  <div class="ske ske-${type}" :style="style">
     <!-- ...... 根据类型判断此处是否需要添加元素。TIPS: row ⾥⾯可以继续嵌套 row -->
  </div>
</div>
在上⾯的示例中:

${type} 的值为对应的容器类型 row 、 col 、 rect 或 circle 。
style 表示 class="ske ske-${type}" 的元素对应的样式:
如果 ${type} 是 rect 或 circle 则使⽤ style 属性。其 DOM 结构如下:

<div class="ske-rect-container">
  <div class="ske ske-rect" :style="style"></div>
</div>
rows/cols 以及 rowStyle/colStyle 使⽤示例如下:

<!-- rowStyle/colStyle 使⽤示例 -->
<div class="ske ske-row" :style="row.rowStyle" v-for="row in paragraph.rows">
  <!--此处代码省略...-->
</div>
2. 使⽤ index.html 中传递过去的数据 active 完成⻣架屏组件的闪烁功能:如果 active 为 true , 则给容器类型 type 为 rect (矩形)或 circle (圆形)的组件内层class="ske ske-rect" 或 class="ske ske-circle" 的元素添加类名 .ske-ani ;否则不添加。

最终效果可参考⽂件夹下⾯的 gif 图,图⽚名称为 effect.gif (提示:可以通过 VS Code 或者浏览 器预览 gif 图⽚)。

规定

请严格按照考试步骤操作,切勿修改考试默认提供项⽬中的⽂件名称、⽂件夹路径、class 名、id 名、图⽚名等,以免造成判题⽆法通过。
完成答题后,考⽣需将题⽬对应代码⽂件夹压缩成 zip 格式后上传提交,其他压缩包格式为 0 分。
判分标准

本题完全实现题⽬⽬标得满分,否则得 0 分

let ItemTemplate = ``;
// TODO: 请补充完整Template,完成组件代码编写
ItemTemplate =`<div>
<div v-if="paragraph.type === 'row'" class="ske-row-container">
<div class="ske ske-row" :style="row.rowstyle" v-for="row in paragraph.rows">
<!--递归调用1tem组件来渲染子节点,传递row和act1ve属性-->
<item paragraph="row" :active="active"></item>
</div>
</div>
<div v-else-if="paragraph.type ==='col'" class="ske-col-container">
<div class="ske ske-col" :style="col.colstyle" v-for="col in paragraph.cols">
<!-一递归调用1tem组件来渲染子节点,传递co1和active属性-->
<item :paragraph="col" :active="active"></item>
</d1v>
</div>
<div v-else-if="paragraph.type =='rect'" class="ske-rect-container">
<!-一以矩形形式渲染当前节点-一>
<div class="ske ske-rect" :class="['ske-ani':active)" :style="paragraph.style"></div>
</div>
<div v-else-if="paragraph.type ==='circle'" class="ske-circle-container">
<!-一以圆形形式宣染当前节点一>
<div class="ske ske-circle" :class="{'ske-ani':active)" :style="paragraph.style"></div>
</div>
</div>
`

10. 组课神器  

介绍

在很多教育⽹站的平台上,课程的章节⽬录会使⽤树型组件呈现,为了⽅便调整菜单,前端⼯程师会为 其赋予拖拽功能。本题需要在已提供的基础项⽬中,完成可拖拽树型组件的功能。

准备

├── effect.gif

├── css

│      └── style.css

├── index.html

├── images

└── js

       ├── data.json

       ├── axios.min.js

       └── index.js

其中:

index.html 是主⻚⾯。
images 是图⽚⽂件夹。
js/index.js 是需要补充代码的 js ⽂件。
js/data.json 是存放数据的 json ⽂件。
js/axios.min.js 是 axios ⽂件。
css/style.css 是样式⽂件。
effect.gif 是完成的效果图。
在浏览器中预览 index.html ⻚⾯,显示如下所示

 ⽬标

请在 js/index.js ⽂件中补全代码。具体需求如下:

1. 补全 js/index.js ⽂件中 ajax 函数,功能为根据请求⽅式 method 不同,拿到树型组件的数 据并返回。具体如下:

当 method === "get" 时,判断 localStorage 中是否存在 key 为 data 的数据,若存在,则 从 localStorage 中直接获取后处理为 json 格式并返回;若不存在则从 ./js/data.json (必须 使⽤该路径请求,否则可能会请求不到数据)中使⽤ ajax 获取并返回。
当 method === "post" 时,将通过参数 data 传递过来的数据转化为 json 格式的字符串,并保 存到 localStorage 中, key 命名为 data 。
最终返回的数据格式如下:

[
{
"id": 1001,
"label": "第⼀章 Vue 初体验",
"children": [ ... ]
},
{
"id": 1006,
"label": "第⼆章 Vue 核⼼概念",
"children": [
{
"id": 1007,
"label": "2.1 概念理解",
"children": [
{
"id": 1008,
"label": "聊⼀聊虚拟 DOM",
"tag":"⽂档 1"
},
...
]
},
{
"id": 1012,
"label": "2.2 Vue 基础⼊⻔",
"children": [
{
"id": 1013,
"label": "Vue 的基本语法",
"tag":"实验 6"
},
...
]
}
]
}
]

2. 补全 js/index.js ⽂件中的 treeMenusRender 函数,使⽤所传参数 data ⽣成指定 DOM 结构 的模板字符串(完整的模板字符串的 HTML 样例结构可以在 index.html 中查看),并在包含 .tree-node 的元素节点上加上指定属性如下:

3. 补全 js/index.js ⽂件中的 treeDataRefresh 函数,功能为:根据参数列表 { dragGrade, dragElementId }, { dropGrade, dropElementId } 重新⽣成拖拽后的树型组件 数据 treeData ( treeData 为全局变量,直接访问并根据参数处理后重新赋值即可)。

⽅便规则描述,现将 data.json 中的数据扁平化处理,得到的数据顺序如下:

[
{ grade: "1", label: "第⼀章 Vue 初体验", id: "1001" },
{ grade: "2", label: "1.1 Vue 简介", id: "1002" },
{ grade: "3", label: "Vue 的发展历程", id: "1003" },
{ grade: "3", label: "Vue 特点", id: "1004" },
{ grade: "3", label: "⼀分钟上⼿ Vue", id: "1005" },
{ grade: "1", label: "第⼆章 Vue 核⼼概念", id: "1006" },
{ grade: "2", label: "2.1 概念理解", id: "1007" },
{ grade: "3", label: "聊⼀聊虚拟 DOM", id: "1008" },
{ grade: "3", label: "感受⼀下虚拟 DOM", id: "1009" },
{ grade: "3", label: "聊⼀聊 MVVM 设计模式", id: "1010" },
{ grade: "3", label: "Vue 中的 MVVM 设计模式", id: "1011" }, // 即将被拖拽的元素节点
{ grade: "2", label: "2.2 Vue 基础⼊⻔", id: "1012" },
{ grade: "3", label: "Vue 的基本语法", id: "1013" },
{ grade: "3", label: "第⼀步,创建 Vue 应⽤实例", id: "1014" },
];

拖拽前后的规则说明如下:

情况⼀:若拖拽的节点和放置的节点为同级,即 treeDataRefresh 函数参数列表中 dragGrade == dropGrade ,则将 id == dragElementId (例如: 1011 )的节点移动到 id==dropElementId (例如: 1008 )的节点后,作为其后第⼀个邻近的兄弟节点。最终⽣成的数 据顺序如下:
[
{ grade: "1", label: "第⼀章 Vue 初体验", id: "1001" },
{ grade: "2", label: "1.1 Vue 简介", id: "1002" },
{ grade: "3", label: "Vue 的发展历程", id: "1003" },
{ grade: "3", label: "Vue 特点", id: "1004" },
{ grade: "3", label: "⼀分钟上⼿ Vue", id: "1005" },
{ grade: "1", label: "第⼆章 Vue 核⼼概念", id: "1006" },
{ grade: "2", label: "2.1 概念理解", id: "1007" },
{ grade: "3", label: "聊⼀聊虚拟 DOM", id: "1008" },
// 在⽬标元素节点下⽅插⼊
{ grade: "3", label: "Vue 中的 MVVM 设计模式", id: "1011" },
{ grade: "3", label: "感受⼀下虚拟 DOM", id: "1009" },
{ grade: "3", label: "聊⼀聊 MVVM 设计模式", id: "1010" },
// 移除被拖拽的元素节点
{ grade: "2", label: "2.2 Vue 基础⼊⻔", id: "1012" },
{ grade: "3", label: "Vue 的基本语法", id: "1013" },
{ grade: "3", label: "第⼀步,创建 Vue 应⽤实例", id: "1014" },
];

情况⼆:若拖拽的节点和放置的节点为上下级,即 treeDataRefresh 函数参数列表中 dragGrade - dropGrade == 1 ,则将 id == dragElementId (例如: 1011 )的节点移动到 id==dropElementId (例如: 1002 )的节点下,并作为其第⼀个⼦节点。最终⽣成的数据顺序如 下:
[
{ grade: "1", label: "第⼀章 Vue 初体验", id: "1001" },
{ grade: "2", label: "1.1 Vue 简介", id: "1002" },
// 在⽬标元素节点下⽅插⼊
{ grade: "3", label: "Vue 中的 MVVM 设计模式", id: "1011" },
{ grade: "3", label: "Vue 的发展历程", id: "1003" },
{ grade: "3", label: "Vue 特点", id: "1004" },
{ grade: "3", label: "⼀分钟上⼿ Vue", id: "1005" },
{ grade: "1", label: "第⼆章 Vue 核⼼概念", id: "1006" },
{ grade: "2", label: "2.1 概念理解", id: "1007" },
{ grade: "3", label: "聊⼀聊虚拟 DOM", id: "1008" },
{ grade: "3", label: "感受⼀下虚拟 DOM", id: "1009" },
{ grade: "3", label: "聊⼀聊 MVVM 设计模式", id: "1010" },
// 移除被拖拽的元素节点
{ grade: "2", label: "2.2 Vue 基础⼊⻔", id: "1012" },
{ grade: "3", label: "Vue 的基本语法", id: "1013" },
{ grade: "3", label: "第⼀步,创建 Vue 应⽤实例", id: "1014" },
];

最终效果可参考⽂件夹下⾯的 gif 图,图⽚名称为 effect.gif (提示:可以通过 VS Code 或者浏览 器预览 gif 图⽚)

规定

请勿修改 js/index.js ⽂件外的任何内容。
请严格按照考试步骤操作,切勿修改考试默认提供项⽬中的⽂件名称、⽂件夹路径、class 名、id 名、图⽚名等,以免造成判题⽆法通过。
完成答题后,考⽣需将题⽬对应代码⽂件夹压缩成 zip 格式后上传提交,其他压缩包格式为 0 分。
判分标准

完成⽬标 1,得 5 分。
完成⽬标 2,得 10 分。
完成⽬标 3,得 10 分。

 

 


 结语:赛后复盘才发现题目确实还行,除了最后一题实在是不理解。上面最后一题代码是蓝桥杯官方真题详解的答案,仅供参考

  • 7
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值