蓝桥云课-声网编程赛(声网编程竞赛7月专场)题解

news2024/9/27 15:57:58

在这里插入图片描述
比赛题目快速链接:https://www.lanqiao.cn/contests/lqENT02/challenges/

  1. 让时钟转起来(考点:css:transform)
// index.js
function main() {
    // 题解前理解一个东西:
    // 时针每过一小时,转30° 原因,360/12 = 30°
    // 分针每过一分钟,转30° 原因,360/60 = 6°
    // 秒针每过一秒,转6°。
    // 偏移量计算:值 / 分母 * 每过一段度数,例如时偏移量= 分钟值 / 60分母 * 30°
    const nowTime=new Date();
    const nowHoure=nowTime.getHours(); // 当前小时
    const nowMinute=nowTime.getMinutes(); // 当前分钟
    const nowSecond=nowTime.getSeconds(); // 当前秒
    const houreDeg=(nowMinute/60)*30; // 计算时钟偏移量
    const minuteDeg=(nowSecond/60)*6; // 计算当前分钟偏移量
    
    oHoure.style.transform="rotate("+ (nowHoure * 30+houreDeg) + "deg)"; // 转动角度+偏移量就是当前位置
    oMinute.style.transform="rotate("+ (nowMinute * 6+ minuteDeg) + "deg)"; 
    // 请勿删除上方代码
    // 请在下方补充代码,使得时钟的秒针可以转动起来,秒钟一秒转6°
    oSecond.style.transform="rotate("+ (nowSecond * 6) + "deg)";
    
}

  1. 调皮的模态框(考点:事件冒泡 event.stopPropagation())
        <script>
        // 请在这里补充代码,根据需求解决事件冒泡带来的问题,实现模态框的显隐操作。
        let baoming = document.querySelector("#myModal")
        function handleClick(e) {
            baoming.style.display = 'block'
            event.stopPropagation()
        }
        function handleOk(e) {
            baoming.style.display = 'none'
            event.stopPropagation()
        }
        </script>
  1. 由文本溢出引发的“不友好体验(css文本溢出处理,文本溢出处理的三个重要的css属性:overflow、text-overflow、line-clamp)
    <script>
        // 请在下方补充代码,使得文本溢出 2 行时使用省略号
        var text = document.querySelector('.more2_info_name').style='overflow:hidden;text-overflow: ellipsis;-webkit-line-clamp:2;'
    </script>
  1. 下次“绕”过你(localStorage axios)
 <script>
        // 请在修改或填补下方代码:
        // 请实现:在请求数据之前,判断 localStorage 中是否存有名为 historyData 的数据;
        // 1. 没有,则发送请求获取数据;2. 有,则从 localStorage 中获取。

        const data = localStorage.getItem("historyData");
        if (data) {
            renderHtml(JSON.parse(data));
        } else {
            // 请求数据,请勿删除
            axios
                .get("https://labfile.oss.aliyuncs.com/courses/9203/historyData.json")
                .then((res) => {
                    if (res.status === 200) {
                        localStorage.setItem(
                            "historyData",
                            JSON.stringify(res.data.data)
                        );
                        renderHtml(res.data.data);
                    }
                });
        }

        function renderHtml(data) {
            // 将数据写入 HTML 模板,请勿删除
            const html = `${data
                .map(function (item, index) {
                    return `
        <div id="course-9203" class="course-item course-info" data-v-062d7aaa="">
            <div data-v-3ba6c69d="" class="row">
                <div data-v-3ba6c69d="" class="col-lg-4">
                    <div data-v-3ba6c69d="" class="course-img"><a data-v-3ba6c69d="" :href="item.href" class="block" target="_blank"><img data-v-3ba6c69d="" src="${item.imgSrc}" height="160" alt="${item.imgSrc}"></a> <span data-v-23ac173c="" data-v-3ba6c69d=""><span data-v-23ac173c=""></span></span></div>
                    </div>
                <div data-v-3ba6c69d="" class="col-lg-6">
                    <div data-v-3d67ec2c="" data-v-3ba6c69d="" class="course-title"><span data-v-3d67ec2c="">
                                ${item.title}
                            <span data-v-3d67ec2c="">
                            ${item.last}
                        </span></div>
                    <div data-v-3ba6c69d="" class="course-related"><span data-v-3ba6c69d="">
                            ${item.report}篇实验报告
                            <!----></span> <span data-v-3ba6c69d="">
                            ${item.question}个提问
                            <!----></span></div>
                </div>
                <div data-v-3ba6c69d="" class="col">
                    <div data-v-4b66fd24="" data-v-3ba6c69d="" class="operate"><span data-v-4b66fd24="" class="operate-top"><span data-v-4b66fd24="" class="more"> 更多 </span> <span data-v-4b66fd24="" class="delete">
                                删除记录
                            </span></span> <a data-v-4b66fd24="" href="/courses/9203/learning" class="operate-bottom" target="_blank">
                            继续实验
                        </a>
                        
                    </div>
                </div>
            </div>
        </div>
    `;
                })
                .join("")}`;
            // 将 HTML 模板插入到元素中,请勿删除
            document.querySelector(".container").innerHTML = html;
        }
    </script>
  1. 你能看出有多少位吗?(考察千分位,Number.toLocaleString() 可以实现快速千分位,但做时我没有用)
<script>
			$(function(){
				$('.infor-sub').click(function(e){
					$('.layer').hide();
					$('.form').hide();
					e.preventDefault();		//阻止表单提交
				})
				
				$('.shuru').click(function(e){
					$('.layer-content').animate({
						bottom: 0
					}, 200)
					e.stopPropagation();
					// let value = document.getElementById('input-box').innerText
				})
				$('.wrap').click(function(){
					$('.layer-content').animate({
						bottom: '-200px'
					}, 200)
				})
				
				$('.form-edit .num').click(function(){
					var oDiv = document.getElementById("input-box");
					let value = oDiv.innerText + this.innerText
					// 简单的提取 value,接下来对 value 进行处理
					let result = numChange(value)
					oDiv.innerText = result
				})
				$('#remove').click(function(){
					var oDiv = document.getElementById("input-box");
					let value = oDiv.innerText
					value  = value.substring(0, value.length-1)
					// 简单的提取 value,接下来对 value 进行处理
					let  result = numChange(value)
					oDiv.innerText = result
				})
			})
			function numChange(value) {
				value = value.replaceAll(',', '')
				let result = ''
				let arrValue = value.split('').reverse()
				arrValue.forEach((item, index) => {
					if ((index+1) %3 == 0 && index !== arrValue.length-1) {
						result = result + item + ','
					} else {
						result+=item
					}
				})
				return result.split('').reverse().join('')
			}
		</script>
  1. 为图片添加景深效果(css:filter 毛玻璃效果)
    <script>
      // 请在这里编写代码,根据需求,使得图片达到景深效果
	  // 这里打开f12看样式代码可以看出所有的img图层都加上了 filter: blur(2px); 的样式。
	  document.querySelector('.img1').style.filter = "blur(0px)"
	  document.querySelector('.img2').style.filter = "blur(0px)"
    </script>
  1. 验证密码强度
<script>
        // 请在这里补充代码,实现密码强度的验证
		let resultDom = document.querySelector('.result')
		let passwordField = document.getElementById('passwordField')
		let btn  = document.querySelector('.btn-primary')
		
		// 验证点击事件
		btn.addEventListener('click', function() {
			let value = passwordField.value
			console.log(value)
			// 最终校验结果
			var result = ''
			
			// 验证校验
			if (value.length > 8) {
				result = '低'
				Rule2(value)
			} else {
				result = '无效'
			}
			// 中级
			function Rule2(value) {
				let arr = value.split('')
				let rule1 = false // 必须要有一个小写字母
				let rule2 = false // 必须要有一个数字
				for (let i = 0; i < arr.length; i++) {
					let item = arr[i]
					if (item.charCodeAt() >= 97 && item.charCodeAt() <= 122) {
						rule1 = true
					}
					if (Number(item) == item) {
						rule2 = true
					}
				}
				if (rule1 && rule2) {
					result = '中'
					Rule3(value)
				}
			}
			// 高级
			function Rule3(value) {
				let arr = value.split('')
				let rule1 = false // 必须要有一个大写字母
				let rule2 = false // 必须要有一个特殊字符
				for (let i = 0; i < arr.length; i++) {
					let item = arr[i]
					if (item.charCodeAt() >= 65 && item.charCodeAt() <= 90) {
						rule1 = true
					}
					if (item.charCodeAt() < 48 || item.charCodeAt() > 57 ) {
						rule2 = true
					}
				}
				if (rule1 && rule2) {
					result = '高'
				}
			}
			
			resultDom.innerText = result
		}, true)
    </script>
  1. 时间转换工具(考察对象子类型Data的使用)
  <script>
      new Vue({
        el: '#app',
        data: function() {
          return {
            formInline:{
              timeStamp: null, // 时间戳
              date: '' // 时间选择框的值
            }
          }
        },
        mounted() {
        },
        methods: {
			handleTransform() {
				let date = this.formInline.date		// 时间
				let timeStamp = this.formInline.timeStamp		// 时间戳
				if (date && !timeStamp) {
					let newValue = new Date(date)
					this.formInline.timeStamp = newValue.getTime()
				}
				if (!date && timeStamp) {
					timeStamp =  new Number(timeStamp)
					let d = new Date(timeStamp)
					this.formInline.date =  `${d.getFullYear()}-${d.getMonth()+1}-${d.getDate()} ${d.getHours()}:${d.getMinutes()}:${d.getSeconds()}`
					// console.log('转换', s)
				}
			}
        }
      })
  </script>
  1. 表格数据转换(考察:axios使用,element: Table组件formatter属性)
<template>
...
 <el-table-column
          prop="sex"
          label="性别"
          width="180"
		  :formatter="sexFormatter"
		  >
        </el-table-column>
 <el-table-column
          prop="datetime"
          label="注册时间"
          width="180"
		  :formatter="dataFormatter"
		  >
        </el-table-column>
 <el-table-column
          prop="vip"
          label="会员"
		  :formatter="vipFormatter"
		  >
        </el-table-column>
</template>
  <script>
    new Vue({
      el: '#app',
      data: function() {
        return {
          tableData: [],
        }
      },
      mounted() {
		  this.initData()
      },
      methods: {
		initData() {
			axios({ url: './fetchTableData.json' }).then(res => {
				this.tableData = res.data.data
			})
		},
		dataFormatter(row, column, cellValue, index) {
			let valueArr = row.datetime.split('')
			valueArr.splice(4, 0, '-')
			valueArr.splice(7, 0, '-')
			return valueArr
		},
		sexFormatter(row, column, cellValue, index) {
			return	row.sex ?  '男' : '女'
		},
		vipFormatter(row, column, cellValue, index) {
			return	row.vip ?  '是' : '否'
		},
      }
    })
</script>
  1. URL 参数解析并高亮文本内容
<script>
  // 请你在 script 标签中编写代码,实现根据 URL 中的关键字为内容中包含关键字的文本添加 em 标签,以表示高亮。
  
  // 为按钮添加点击事件
  let input = document.getElementsByTagName('input')
  input[1].addEventListener('click', function () {
  	  let queryValue = getValue(input[0].value)
	  clearEm()
	  search(queryValue)
  }, true)
  
  // 1. 提取url中的wd字段的关键字。
	function getValue(url) {
		let left = url.indexOf('wd')
		let right = url.indexOf('&', left)
		console.log(url, left, right)
		let value = url.slice(left + 3, right) // wd= , 3 个字符
		return value
	}
  
  
  // 2. 获取元素内容,高亮后插回dom。
  function search(value) {
	let textDomArr = document.querySelectorAll('.c-title') // 标题高亮
	let contextDomArr = document.querySelectorAll('.content-right') // 内容高亮
	let spanDomArr = document.querySelectorAll('.c-color-gray') // 链接高亮
	textDomArr.forEach(item => {
		let temp = item.innerHTML.replaceAll(value, `<em>${value}</em>`)
		item.innerHTML = temp
	})
	contextDomArr.forEach(item => {
		let temp = item.innerHTML.replaceAll(value, `<em>${value}</em>`)
		item.innerHTML = temp
	})
	spanDomArr.forEach(item => {
		let temp = item.innerHTML.replaceAll(value, `<em>${value}</em>`)
		item.innerHTML = temp
	})
  }
  
  // 清除高亮
  function clearEm() {
	  let textDomArr = document.querySelectorAll('.c-title')
	  let contextDomArr = document.querySelectorAll('.content-right')
	  let spanDomArr = document.querySelectorAll('.c-color-gray')
	  textDomArr.forEach(item => {
	  	let temp = item.innerHTML.replaceAll('<em>', '').replaceAll('</em>', '')
	  	item.innerHTML = temp
	  })
	  contextDomArr.forEach(item => {
	  	let temp = item.innerHTML.replaceAll('<em>', '').replaceAll('</em>', '')
	  	item.innerHTML = temp
	  })
	  spanDomArr.forEach(item => {
	  	let temp = item.innerHTML.replaceAll('<em>', '').replaceAll('</em>', '')
	  	item.innerHTML = temp
	  })
  }
</script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/349779.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

博客等级说明

CSDN 博客等级是按照用户的博客积分数量进行的设定&#xff0c;为 Lv1 至 Lv10 共 10 个等级&#xff0c;不同的等级创作者可以享受到不同的权益待遇。例如&#xff0c;皮肤奖励、自定义域名、客服优先处理、自定义文章标签等特权。您需要提高博客积分进一步提升等级&#xff0…

矩阵理论复习(十二)

已知方阵A的不变因子&#xff1a; 求谱半径求矩阵级数判断矩阵幂级数的收敛性 若矩阵B的某个算子范数小于1&#xff0c;则I-B可逆。 矩阵分析 任何相容矩阵范数都存在与之相容的向量范数。 盖尔圆盘定理一的证明 椭圆范数的证明 若||.||是Cm上的向量范数&#xff0c;A为…

单元测试工具——JUnit的使用

⭐️前言⭐️ 本篇文章主要介绍单元测试工具JUnit的使用。 &#x1f349;欢迎点赞 &#x1f44d; 收藏 ⭐留言评论 &#x1f4dd;私信必回哟&#x1f601; &#x1f349;博主将持续更新学习记录收获&#xff0c;友友们有任何问题可以在评论区留言 &#x1f349;博客中涉及源码…

C++11--lambda表达式

目录 lambda表达式的概念 lambda表达式语法 lambda表达式的书写格式 捕捉列表 参数列表 mutable 返回值类型 函数体 lambda表达式交换两个数 函数对象与lambda表达式 lambda表达式的概念 lambda表达式是一个匿名函数 它能让代码更加地简洁 提高了代码可读性 首先定义…

2021年欧空局10米土地覆盖数据(分省/分市)

土地覆盖数据是我们平时最常用的地理数据之一&#xff0c;土地覆盖数据的来源也有很多种&#xff0c;之前我们介绍共过两个的30米精度的土地覆盖数据&#xff0c;分别为GlobeLand30土地覆盖数据和CLCD土地覆盖数据&#xff0c;&#xff08;可查看之前推送的文章&#xff09;&am…

佳能镜头EOS系统EF协议逆向工程(三)解码算法

目录 数据结构 解码算法 解码效果 这篇文章基于上两篇文章继续&#xff0c; 佳能镜头EOS系统EF协议逆向工程&#xff08;一&#xff09;转接环电路设计_佳能ef自动对焦协议_岬淢箫声的博客-CSDN博客本文属于专栏——工业相机。此专栏首先提供我人工翻译的法语文档部分&…

Python解题 - CSDN周赛第29期 - 争抢糖豆

本期问哥是志在必得&#xff0c;这本算法书我已经觊觎许久&#xff0c;而之前两次因为种种原因未能如愿。因此&#xff0c;问哥这几天花了不少时间&#xff0c;把所有之前在每日一练做过的题目重新梳理了一遍。苦心人&#xff0c;天不负&#xff0c;感谢官方大大&#xff01; 第…

ChatGPT 人工智能革命从实验室走入公众生活

11 月底&#xff0c;人工智能研究实验室OpenAI 发布了 ChatGPT 聊天机器人首个测试版本&#xff0c;这是一款基于人工智能的新型聊天机器人&#xff0c;可以与人类进行对话&#xff0c;经过测试后&#xff0c;新款机器人便踏上了社交网站之旅&#xff0c;尤其是在推特平台上&am…

机器学习+西瓜书笔记第2章【贝叶斯分类器】

机器学习笔记第2章【贝叶斯分类器】一、贝叶斯决策论1.相关知识补充2.生成模型与判别模型贝叶斯公式&#xff1a; 实际上&#xff0c;分母为全概率公式&#xff0c;分子为联合概率。在机器学习中&#xff0c;更常见的形式为 贝叶斯公式的作用在于将P(B|A)的估计转化为估计P(A…

做一个短视频应用,如何选择服务器配置?

大家好我是明杰&#xff0c;最近听说了“两微一抖”这个词。很容易联想到,“两微”指的是微信和微博,“一抖”指的是抖音,它描述的是今年开始互联网行业呈现的一种新的变化。抖音奇迹般地杀出重围,与微博、微信一起造就了流量市场“三权分立”的现象。抖音能与微信、微博齐名,与…

vue全家桶(四)前端工程化

vue全家桶&#xff08;四&#xff09;前端工程化1.模块化的相关规范1.1模块化概述1.2模块化的分类A.浏览器端的模块化B.服务器端的模块化C.ES6模块化1.2.1 Node.js中通过bable体验ES6模块化1.2.2 ES6模块化的基本语法1.2.2.1 默认导出与默认导入1.2.2.2 按需导出与按需导入1.2.…

vue - vue项目中解决 IOS + H5 滑动边界橡皮筋弹性效果

问题: 最近遇到一个问题&#xff0c;我们在企业微信中的 H5 项目中需要用到table表格&#xff08;支持懒加载 上划加载数据&#xff09;。但是他们在锁头、锁列的情况下&#xff0c;依旧会出现边界橡皮筋效果。就会显示的很奇怪。 什么是ios橡皮筋效果&#xff1a; 我们知道元素…

华为MateBook E Go电脑使用U盘怎么安装Win10系统?

华为MateBook E Go电脑使用U盘怎么安装Win10系统&#xff1f;有用户购买这款电脑之后&#xff0c;发现系统默认安装的电脑系统是Win11版本的。但是自己不习惯使用这个系统&#xff0c;所以想要去将系统重新安装到Win10来使用。那么要怎么去进行系统重装呢&#xff1f;一起来看看…

微服务门神-Gateway与Sentinel的集成

目录 引言 概述 集成Sentinel 限流维度 网关集成 Route维度 API分组 精准匹配 前缀匹配 正则匹配 自定义限流返回格式 转视频版 引言 书接上篇&#xff1a;微服务门神-Gateway过滤器Filter&#xff0c;讲完了解Gateway过滤器之后&#xff0c;接下来看下Gateway与…

免费常用IP归属地查询API

引言 因毕设需要&#xff0c;需要使用到根据IP地址查询归属地 经过百度查询&#xff0c;发现如下几个api可以尝试&#xff0c;本人决定使用最后一个api 免费常用IP归属地查询API ip-api.com 可切换显示语言 http://ip-api.com/json/117.136.12.79?langzh-CN {"status…

wodat:一款针对Windows Oracle数据库的渗透测试工具

关于wodat wodat是一款功能强大的针对Windows Oracle数据库的渗透测试工具&#xff0c;该工具基于C# .Net Framework开发&#xff0c;能够帮助广大研究人员对Windows平台下的Oracle数据库执行按摩全渗透测试任务。 注意&#xff1a;请在被授权执行安全测试的情况下使用该工具…

[Apache Hudi] 流转批的场景实践

文章目录1.EventTime计算原理2.案例使用2.1 Maven pom 依赖2.2 设置EventTime2.3 Flink API2.4 Flink SQL2.5 读取EventTime在某些业务场景下&#xff0c;我们需要一个标志来衡量hudi数据写入的进度&#xff0c;比如&#xff1a;Flink 实时向 Hudi 表写入数据&#xff0c;然后使…

vue2版本《后台管理模式》(中)

文章目录前言一、创建一个文件夹 utils 里面新增一个 setToken.js 文件(设置token验证&#xff09;二 、创建一个api文件夹 新增 service.js &#xff08;axios拦截器&#xff09;三、在api文件夹里 新增一个 api.js 来接收数据&#xff08;把api封装哪里需要某项数据直接引入就…

运维服务商低成本提升服务质量解决方案

在信息化高速发展的今天&#xff0c;网络建设的重要性不言而喻&#xff0c;更多客户选择将运维服务外包或托管给运维服务商&#xff0c;市场需求愈大竞争压力愈大&#xff0c;想要脱颖而出势必要优化自身提高服务质量&#xff0c;最好是低成本、大提升&#xff0c;nVisual助力渠…

饕餮 NFT 作品集来袭!

饕餮 NFT 作品集包含 Chili Game 创作的体验《饕餮》第一章中的角色。可以在 The Sandbox 农历新年活动期间&#xff08;01/18/23 至 02/28/23&#xff09;体验。 饕餮的故事植根于中国古代神话&#xff0c;主要灵感来自《山海经》&#xff0c;一个关于捉妖人「青蛙侠」的故事。…