位置: IT常识 - 正文

【蓝桥杯Web】第十四届蓝桥杯(Web 应用开发)模拟赛 1 期-大学组 | 精品题解(蓝桥杯2021出结果)

编辑:rootadmin
【蓝桥杯Web】第十四届蓝桥杯(Web 应用开发)模拟赛 1 期-大学组 | 精品题解

推荐整理分享【蓝桥杯Web】第十四届蓝桥杯(Web 应用开发)模拟赛 1 期-大学组 | 精品题解(蓝桥杯2021出结果),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:蓝桥杯答疑,蓝桥杯b组2021,蓝桥杯2021年,蓝桥杯答疑,蓝桥杯官方,蓝桥杯官方,蓝桥杯资料,蓝桥杯答疑,内容如对您有帮助,希望把文章链接给更多的朋友!

🧑‍💼 个人简介:一个不甘平庸的平凡人🍬 🖥️ 蓝桥杯专栏:蓝桥杯题解/感悟 🖥️ TS知识总结:十万字TS知识点总结 👉 你的一键三连是我更新的最大动力❤️! 📢 欢迎私信博主加入前端交流群🌹

📑 目录🔽 前言1️⃣ 数据类型检测2️⃣ 渐变色背景生成器3️⃣ 水果叠叠乐4️⃣ element-ui 组件二次封装5️⃣ http 模块应用6️⃣ 新课上线啦7️⃣ 成语学习8️⃣ 学海无涯9️⃣ 逃离二向箔🔟 梅楼封的一天🔼 结语🔽 前言

新一期的蓝桥杯大赛开始报名已经有一段时间了,最近博主的粉丝朋友们有很多都已经在积极备考了,也有很多朋友私信我说让我多发发题解,于是我就去蓝桥杯官网碰碰运气,看能不能找到好的题目(因为今年是蓝桥杯开放Web应用开发方向的第二年,官网上的备赛题目比较少),正巧发现蓝桥杯正在举行线上模拟赛,我便花了一些时间做题、总结、写作,于是这篇文章就诞生了。

如标题所见,这是 Web 应用开发模拟赛 1 期大学组 的题解,关于蓝桥杯更多的题解博主会在之后的文章中陆续更新,欢迎大家关注订阅!

话不多说,开撕!

本篇只会大概提出题目要求,关于题目的更多细节可自行去模拟赛主页查询:Web 应用开发模拟赛 1 期大学组

1️⃣ 数据类型检测

这一题大致的意思就是写一个能够判断参数数据类型的函数,咋一看感觉非常的简单,可再仔细一看题目要求,足足需要判断14种类型!如果你的基础知识不牢固是有很大机率通不过这题的,从题目的通过率就可以看出:

作为第一题,虽然只有5分,并且挑战人数是10道题中最多的,但通过率确是10道题中最低的,这恰恰反应了大家的基础核心知识不牢固,所以还是简易大家多补补基础核心知识。

要求:

虽然有14种类型需要判断,但其实只需要一行代码就能通过这题:

/** * @description: 数据类型检测 * @param {*} data 传入的待检测数据 * @return {*} 返回数据类型 */function getType(data) { // TODO:待补充代码 return Object.prototype.toString.call(data).slice(8,-1)}

JavaScript中判断数据类型主要有以下几种方式:

typeof 可以用来区分除了null类型以外的原始数据类型(undefined、number、string、symbol、boolean)和对象类型中的函数,针对其它类型时typeof一律返回object类型。

instanceof 运算符用于检测构造函数的 prototype 属性是否出现在某个实例对象的原型链上,所以它不能用来判断原始数据类型的数据。

并且instanceof的结果并不一定是可靠,因为在ES7的规范中可以通过自定义Symbol.hasInstance方法来覆盖insanceof的默认行为

Object.prototype.toString.call 能够满足大部分场景下的需求,但它无法区分数字类型和数字对象类型(同理还有字符串类型和字符串对象类型等,)

Object.prototype.toString.call(2).slice(8,-1) // "Number"// new Number(2)实际是一个数字对象类型Object.prototype.toString.call(new Number(2)).slice(8,-1) // "Number"

ES7规范中可以使用Symbol.toStringTag自定义Object.prototype.toString方法的行为,所以该方法判断数据类型也不一定是完全可靠的。

Array.isArray 用来判断是否是数组

所以这题对于知道Object.prototype.toString.call方法的同学来说,几乎就是秒解!

如果非要深究性能的话,可以结合使用typeof和Object.prototype.toString.call,两者运行时间比较如下:

结合使用:

function getType(data) { // TODO:待补充代码 if(typeof data !== "object"){ return typeof data; } return Object.prototype.toString.call(data).slice(8,-1);}2️⃣ 渐变色背景生成器

这题所实现的渐变色背景生成器还是非常有意思的,推荐大家去看一下它完整的源码(代码非常少):

主要考察的就是通过JavaScript来修改自定义的 CSS 变量,题中主要的代码如下(并不是全部代码,不需要我们了解与实现的代码这里就没有贴出,原题可自行查阅蓝桥官网)

HTML:

<div class="controls"> <input id="color1" type="color" name="color1" value="#00dbde" /> <input id="color2" type="color" name="color2" value="#fc00ff" /> </div>

CSS:

/* 注意这里定义的 CSS 变量,它们会用于生成渐变色背景 */:root { --color1: #00dbde; --color2: #fc00ff;}const inputs = document.querySelectorAll(".controls input");/** * 上面已经选取了两个取色器 * 请添加相应的 JS 事件处理函数并绑定到合适的事件监听器上(提示:change 事件) * 这样我们就可以用取色器选取颜色来生成下方的渐变色背景啦 * */ inputs.forEach((item)=>{ item.addEventListener("change",function (e) { document.querySelector("html").style.setProperty(`--${e.target.id}`, e.target.value); }) })

遍历获取到的两个取色盘元素(input.color),分别对其添加change事件,然后通过document.querySelector("html").style.setProperty方法修改html元素(根元素,也即是:root)上css变量的值即可。

这一题题目参考信息中给出了如何使用CSS变量的介绍,根据这个提示来做这题还是非常简单的。

3️⃣ 水果叠叠乐

这简直就是简易般的羊了个羊:

这一题有个坑,就是点击元素时是需要将这个被点击的元素克隆一份添加到下方的栏中,而不是直接将被点击的元素移动到下方的栏中。

具体实现代码如下

HTML:

<ul id="card"> <li data-id="1" id="fruit-one"> <img src="./images/pineapple.svg" alt="" /> </li> <!-- 多个li... --></ul><!-- 图片位置 --><!-- 卡槽位置 --><div class="fixed"> <div class="gradient-border" id="box"></div></div>

JavaScript:

$("#card li").on("click", function (e) { // TODO: 待补充代码 if($("#box li").length === 7) return; // 向box中添加当前点击元素的克隆 $("#box").append($(this).clone()); // 隐藏当前点击元素 $(this).hide(); // 找到与当前点击元素类别一样的其它所有元素 const list = $(`#box li[data-id=${this.getAttribute('data-id')}]`); if (list.length >= 3) { // each是jQuery遍历元素的方法 list.each((i,item) => { // 移除元素 item.remove() }) }});

我们知道DOM的事件处理函数中的this指的是触发事件的DOM元素,我这里使用$()包裹this($(this))的目的是使this变成JQ对象,从而能够使用jQuery提供的方法,如clone克隆元素。

4️⃣ element-ui 组件二次封装

需要封装element-ui 的表格组件,实现点击表格组件左侧radio时选中该行,题目要求说了一大堆,其实通过这题只需修改两行代码就行:

<!-- TODO:完善单选按钮组件,实现需求(DOM 结构不能修改) --><template slot-scope="scope"> <el-radio v-model="currentRow" :label="scope.$index">&nbsp;</el-radio></template>【蓝桥杯Web】第十四届蓝桥杯(Web 应用开发)模拟赛 1 期-大学组 | 精品题解(蓝桥杯2021出结果)

这样做虽然能通过检测,但它存在以下bug (说明题目答案检测不严格):

点击选中第二行时,第二行前面的radio并没有被选中点击取消选中时已经选中的radio并没有被取消

并且在查看代码时会发现题中给了我们一个setCurrent方法用来设置当前选中行,并且题目中也明确提示我们redio有一个change方法:

所以严谨来说当radio状态改变时是应该调用setCurrent方法的

综上所述,最终的代码应该这样写:

<!-- TODO:完善单选按钮组件,实现需求(DOM 结构不能修改) --><template slot-scope="scope"><!-- 绑定change方法调用setCurrent --><el-radio v-model="currentRow" :label="scope.$index" @change="setCurrent(scope.row)">&nbsp;</el-radio></template>methods: { setCurrent(row) { this.currentRow = this.tableData.indexOf(row) // 新增 this.$refs.singleTable.setCurrentRow(row); // 设置当前选中行 },},

表格的数据是在props的tableData中,setCurrent方法接收的row代表的是当前行的数据,当调用setCurrent方法时在tableData中查找row的下标赋值给currentRow即可(因为el-radio v-model绑定的是currentRow),这样就解决了上面说的BUG。

5️⃣ http 模块应用

要求就是使用原生http模块,搭建起来一个简单的Node服务器,并返回 “hello world” ,考察的就是基础的原生知识,如果你对Node还不了解,可以订阅我的 Node.js从入门到精通专栏(私信进群能够享返现活动)。

// TODO: 待补充代码const http = require("http");const app = http.createServer();app.on("request",function (req,res) { res.end("hello world")})app.listen(8080)6️⃣ 新课上线啦

就是按照官方给的最终效果图,去实现下面这个页面:

没啥技术含量,全靠堆HTML和CSS,这里就不放代码了。

但这个题是我认为是整场模拟赛里最坑人的题,特别废时间,我建议这个题要么放到最后再写(因为完成度50%以上就能得到分,其它题不行),要么完成差不多后就直接去做下面的题,别死扣细节,不然吃亏的都是你!

7️⃣ 成语学习

这个题也是非常的有意思,不过需要我们写的代码并不多,大多都是官方已经给出了。

//TODO 点击文字后,在idiom从左到右第一个空的位置加上改文字getSingleWord(val) { for (let i = 0; i < this.idiom.length; i++) { if (!this.idiom[i]) { this.idiom[i] = val this.$set(this.idiom, i, val) return } }}// TODO 校验成语是否输入正确答案// 猜中成语 result 为 true;// 猜错成语 result 为 false;// 例1:tip=‘形容非常感激或高兴’,idiom=["热","泪","盈","眶"],则result返回true// 例2:tip=‘形容非常感激或高兴’,idiom=["泪","眼","盈","眶"],则result返回false// 例3:tip=‘在繁忙中抽出空闲来’,idiom=["忙","里","偷","闲"],则result返回trueconfirm() { const target = this.arr.find(item => item.tip === this.tip); this.result = target.word === this.idiom.join('');}

这里使用的是vue2,需要注意的一点就是当我们直接修改data里的数组中的元素时,视图并不会响应式更新,如果你了解vue2的响应式原理,应该明白这是vue2响应式的一个缺陷所在,我们必须使用$set来修改触发从而引发视图更新。

其实题中原有的代码已经显示了这一点,如clear函数:

clear(i) { this.idiom[i] = "" this.$set(this.idiom, i, "")},8️⃣ 学海无涯

这一题稍微有点复杂,但只要自己理清楚思路,还是能够做出来的,先看一下效果:

题中使用了Echarts,了解Echarts的朋友知道 Echarts 的表格有x轴和y轴的数据(都是数组形式),所以我们知道只要将题中给我们的数据转换成对应的格式就行了。

复杂的地方在于数据处理,原数据如下:

"data": { "2月": [ 30, 40, 30, 20, 10, 20, 30, 69, 86, 12, 32, 12, 23, 40, 50, 61, 39, 28, 20, 35, 20, 38, 43, 52, 30, 39, 52, 70 ], "3月": [ 36, 48, 52, 30, 39, 52, 20, 18, 25, 33, 21, 36, 44, 63, 32, 89, 98, 23, 25, 36, 29, 31, 42, 23, 45, 56, 98, 83, 25, 28, 48 ]}

我的思路就是将原数据转换成两个对象,一个代表周的x轴y轴数据,一个代表月的x轴y轴数据,所以两个对象的结构是一模一样,转成后的两个对象如下:

// 周数据weekData = { x: ['2月第1周', '2月第2周', '2月第3周', '2月第4周', '3月第1周', '3月第2周', '3月第3周', '3月第4周', '3月第5周'], y: [180, 274, 253, 324, 277, 240, 332, 378, 101]}// 月数据monthData = { x: ['2月', '3月'], y: [1031, 1328]}

现在我们根据代码来一点点了解我是如何转换的:

// TODO:待补充代码let weekData ={ x:[], y:[]}, monthData ={ x:[], y:[]};// 定义一个函数:用来修改option对象并重置Echarts图标function mySetOption(data) { // 修改x轴数据 option.xAxis.data = data.x; // 修改y轴数据 option.series[0].data = data.y; // 重置图表 myChart.setOption(option);}// 添加点击事件document.querySelector(".tabs").addEventListener("click",function (e) { if (e.target.id === "week") { mySetOption(weekData); }else if(e.target.id === "month") { mySetOption(monthData); }})// 获取数据axios.get('./data.json').then(res=>{ const data = res.data.data; for (const key in data) { // weekCount代表一周数据的和,monthCount代表一月数据的和,weekNum代表第几周 let weekCount = monthCount = 0, weekNum = 1; for (let i = 0; i < data[key].length; i++) { // 数据累加 weekCount += data[key][i]; monthCount += data[key][i]; // 每一周的最后一天或不足一周的最后一天进行push数据 if ((i+1) % 7 === 0 || ((data[key].length - i <= 7) && (i === data[key].length - 1))) { weekData.x.push(`${key}第${weekNum++}周`); weekData.y.push(weekCount); // 重置周数据的和为0 weekCount = 0; } } monthData.x.push(key); monthData.y.push(monthCount); } // 获取到数据后调用一次mySetOption重置图表 mySetOption(weekData);})

代码不算难,相信大家根据代码里的注释都能够理解,着重说一下上面我使用的 if 表达式:

(i+1) % 7 === 0 || ((data[key].length - i <= 7) && (i === data[key].length - 1))

要明白我们求每一周的总数居时需要在第二周开始前将weekCount归零,我选择了在每周的最后一天(且已经push了数据)重置weekCount,而不是在每周的第一天(计算数据之前)重置weekCount,是因为我感觉这样做判断比较好写。

首先(i+1) % 7 === 0判断了是每星期的最后一天,如:第一周的星期日,在数组中下标为6,加上1对7取余就得0。

((data[key].length - i <= 7) && (i === data[key].length - 1)中data[key].length - i <= 7代表剩余的数据不足7条,i === data[key].length - 1代表到了数组最后一项。之所以做这么一个判断,是为了适配天数不是7的倍数的情况,如3月31天,计算完前4周的数据后剩余3天的数据(31-4x7),这3天也要求和作为第5周的数据,所以需要在最后一天结算这三天。

其实上面这个写的复杂了,我们可以巧妙改变 for 循环的步长,并使用数组切片(slice)和求和(reduce)来简化代码:

// TODO:待补充代码let weekData ={ x:[], y:[]}, monthData ={ x:[], y:[]};// 定义一个函数:用来修改option对象并重置Echarts图标function mySetOption(data) { // 修改x轴数据 option.xAxis.data = data.x; // 修改y轴数据 option.series[0].data = data.y; // 重置图表 myChart.setOption(option);}// 添加点击事件document.querySelector(".tabs").addEventListener("click",function (e) { if (e.target.id === "week") { mySetOption(weekData); }else if(e.target.id === "month") { mySetOption(monthData); }})// 获取数据axios.get('./data.json').then(res=>{ const data = res.data.data; for (const key in data) { // i每次递增为7,即递增一周 // w代码当前第几周,每次递增1 for (let i = 0,w = 1; i < data[key].length; i += 7,w++) { // 一周数据总和 // 利用data[key].slice(i,i+7) 获取这一周7天的数据,再使用reduce累加 let weekCount = data[key].slice(i,i + 7).reduce((prev,next) => prev + next); // push周的数据 weekData.x.push(`${key}第${w}周`); weekData.y.push(weekCount); } // push月的数据 monthData.x.push(key); monthData.y.push(data[key].reduce((prev,next)=>prev + next)); } // 获取到数据后调用一次mySetOption重置图表 mySetOption(weekData);})9️⃣ 逃离二向箔

这个题目很有意思,让我瞬间想起了三体宇宙,顿时感觉这题不简单,结果还正如我所想,题中考察的是promise以及JavaScript中的事件执行机制(先执行同步代码再执行异步代码),对于promise,相信大多数人都会比较头疼,这一题考察的角度也比较刁钻,让我们一起来看一看吧!

题目的大致要求就是有一个数组,里面存放了很多需要发射的飞船(一个返回promise对象的函数),然后给了我们一个最大数量,我们只能一次性发送这个最大数量的飞船,当有一个飞船发射成功(promise执行结束),我们才能继续发射下一个飞船。

完整代码:

// 使用 promise 模拟请求 + 3000ms后完成得到发射后结果function createRequest(i) { return function () { return new Promise((resolve, reject) => { const start = Date.now(); setTimeout(() => { if (Math.random() >= 0.05) { resolve( `第${i + 1}艘曲率飞船达到光速,成功逃离,用时${Date.now() - start}` ); } else { reject( `第${i + 1}艘曲率飞船出现故障,无法达到光速,用时${ Date.now() - start }` ); } }, 3000 + i * 100); }); };}class RequestControl { constructor({ max, el }) { this.max = max; this.requestQueue = []; this.el = document.querySelector(el); setTimeout(() => { this.requestQueue.length > 0 && this.run(); }); this.startTime = Date.now(); } addRequest(request) { this.requestQueue.push(request); } run() { // TODO:待补充代码 // promiseI代表已经发送飞船的数量,只要一有飞船发射(promise执行)promiseI就加一 let promiseI = 0 // 先遍历执行max数量的promise for(let i = 0;i < this.max;i++) { this.requestQueue[i]().then(res=>{ this.render(res) // 执行成功代表发射飞船成功,这时就调用sentNext执行下一个未执行的promise sentNext() }).catch(res=>{ // 到了catch代表执行失败,但这也算是执行完成了,所以也需要调用sentNext this.render(res) sentNext() }) promiseI++; } // 定义一个发送下一个未发送飞船的函数 const sentNext = ()=> { // promiseI大于等于总数量时,代表全部飞船都已经发射出去,就不需要执行下面的了,直接return if (promiseI >= this.requestQueue.length) return; this.requestQueue[promiseI]().then(res=>{ this.render(res) // 执行完成就递归调用 sentNext() }).catch(res=>{ this.render(res) sentNext() }) promiseI++; } } render(context) { const childNode = document.createElement("li"); childNode.innerText = context; this.el.appendChild(childNode); }}let requestControl = new RequestControl({ max: 10, el: "#app" }); for (let i = 0; i < 25; i++) { const request = createRequest(i); requestControl.addRequest(request); }module.exports = { requestControl,};

我这里定义了一个变量promiseI存储已经执行过的promise的数量,同时能直接将promiseI当作requestQueue数组的下标,以此来调用requestQueue数组中下一个未被执行的promise,这里大家可以好好理解一下。

需要注意的一点就是this.requestQueue[promiseI]函数的调用是同步代码(这个函数的调用代表开始发射了飞船),调用它之后返回的promise的执行才是异步代码(这个promise的执行代表飞船的发射过程,promise执行完就代表飞船发射成功了),所以 promiseI++的执行永远都是在this.requestQueue[promiseI]函数执行之后,这也就是promiseI能够精确表示已发射出去飞船数量的原因。

这道题值得大家好好思考!

一开始做这道题时我秉持的是不修改原始数据(如requestQueue),但在官方的解答中我发现可能是我想错了,给大家看看官方给出的更简单的解法:

run() { // TODO:待补充代码 let reqLength = this.requestQueue.length; if (!reqLength) return; let min = Math.min(reqLength,this.max); // 遍历,逐个发射,每次最多发射max个,但当reqLength小于max时就最多只能发射reqLength个,所以上面需要取两者最小值 for (let i = 0; i < min; i++) { // 发射一个,max--,意味着发射名额少一个 this.max--; // 获取发射队列中的第一个并将其从发射队列中清除,shift删除数组中第一项并返回这个被删除的项, let req = this.requestQueue.shift(); // 发射 req().then((res)=>{ this.render(res) }).catch((err)=>{ this.render(err) }).finally(()=>{ // 不管promise最后的状态,在执行完then或catch指定的回调函数以后,都会执行finally方法指定的回调函数。 // 发射完成后,就max++,意味着发射名额空出一个 this.max++; // 发射完成后递归调用,开始下一轮的发射 this.run(); }) }}🔟 梅楼封的一天

要求就是实现一个脱敏函数,函数入参要求:

第一个参数为字符串(任意字符串)。第二个参数为脱敏规则,可以是字符串,也可以是数组。第三个参数是字符串,表示用什么来占位脱敏文字(默认为:*)。第四个参数是:是否将手机号(11 位数字)进行脱敏,默认为 true(规则是:保留前三位和后三位,中间脱敏占位)。

出参要求:

第一个参数不存在返回 null。

第一个参数存在,第二个参数不存在,返回原字符串。

第一个参数和第二个参数都存在,返回脱敏后的新字符串以及被脱敏的文本位置,返回格式是一个对象( 注意:无论手机号是否脱敏处理,都不会返回手机号的被脱敏时的位置 ),格式如下:

{ "ids": [], "newStr": ""}

这题我利用了正则和字符串的replace方法来实现,本来我使用new Array(word.length).fill(symbol).join('')来生成与违规字符**相同数量(长度)**的脱敏字符(*),但最后想到字符串本身有一个repeat方法能很方便的实现这一效果:

/** * @description: * @param {*} str * @param {*} rule * @param {*} symbol * @param {*} dealPhone * @return {*} */ const toDesensitization = (str, rule, symbol = "*", dealPhone = true) => { if(!str) return null; if (str && !rule) return str; const obj = { ids: [], newStr: str } // 定义一个获取新字符串的方法 function getNewStr(ru) { // 生成正则,注意要带上'g'表示全局匹配,这样它就能配合字符串的replace方法运用 // g全局匹配,i忽略大小写,m多行匹配 const reg = new RegExp(ru,'gim'); obj.newStr = obj.newStr.replace(reg,function (word,index) { // word代表匹配到的字符,index代表出现的位置 obj.ids.push(index); // new Array(word.length)生成word.length长度的数组,再fill(symbol)代表将数组内的元素全部设置为symbol的值,再调用join转换为字符串 // return new Array(word.length).fill(symbol).join('') // repeat() 构造并返回一个新字符串,该字符串包含被连接在一起的指定数量的字符串的副本。 return symbol.repeat(word.length) }) } if (Array.isArray(rule)) { // 如果rule是数组,则遍历 for (const ru of rule) { getNewStr(ru) } }else { getNewStr(rule) } if (dealPhone) { // 因为题目要求手机号是11位数字且测试用例比较简单,我这里就直接使用11位的数字代表 // 如果题目要求比较严格,可以将reg替换为严格的匹配手机号的正则 // const reg = /\d{11}/g // obj.newStr = obj.newStr.replace(reg,function (word) { // return word.slice(0,3)+new Array(5).fill(symbol).join('')+word.slice(-3) // }) const reg2 = /(1[35789]+\d{1})\d{5}(\d{3})/g; // replace第二次参数代表替换内容,$1是reg2中第一个括号匹配到的内容,$2是reg2中第二个括号匹配到的内容 obj.newStr = obj.newStr.replace(reg2,`$1${symbol.repeat(5)}$2`) } return obj};module.exports = toDesensitization;

整体的思路很清晰,有一点就是replace函数的第二个参数是一个函数时的用法(以及上述$1和$2的用法)大家可能不太清楚,这里可以查阅:MDN的说明

🔼 结语

至此,第十四届蓝桥杯(Web 应用开发)模拟赛 1 期-大学组的题解就结束了,这期模拟赛整体上来说并不算很难,但考察的知识点还是比较多的,特别是对基础知识的考察(相信你在做题的过程中也能察觉到),所以博主还是建议大家在做题的过程中好好总结,好好复习,祝大家都能在正式比赛中取得满意的成绩!

因为没做什么准备,只是在寝室拿起电脑随便做了一下,最终耗时257分钟,比正式比赛要求的4小时超了17分钟,但幸好最后的成绩还不错。 总结来说,比较耗时的题就是第6题了,大家可以注意一下,在正式比赛时做好规划。

如果本篇文章对你有所帮助,还请客官一件四连!❤️

本文链接地址:https://www.jiuchutong.com/zhishi/299853.html 转载请保留说明!

上一篇:前端搭建猜数字游戏(内附源码)(javascript猜数字游戏+表单)

下一篇:做了8年前端,细说那些曾经让你浴霸不能的后端(做了几年前端基础还是很差)

  • 红外遮挡通知怎么关闭vivo(红外遮挡通知怎么处理)

    红外遮挡通知怎么关闭vivo(红外遮挡通知怎么处理)

  • 荣耀30pro怎么使用3.5mm的耳机(荣耀30pro怎么使用红外功能)

    荣耀30pro怎么使用3.5mm的耳机(荣耀30pro怎么使用红外功能)

  • 支付宝账号挂失有什么用(支付宝账号挂失多久注销)

    支付宝账号挂失有什么用(支付宝账号挂失多久注销)

  • 钉钉卡住算观看时间么(钉钉卡住算观看时长吗)

    钉钉卡住算观看时间么(钉钉卡住算观看时长吗)

  • 华为智慧助手可以关闭吗(华为智慧助手可以定位别人的车)

    华为智慧助手可以关闭吗(华为智慧助手可以定位别人的车)

  • 抖音可以卖酒吗(抖音可以卖酒水吗)

    抖音可以卖酒吗(抖音可以卖酒水吗)

  • 右上角tel什么意思(tel在右上角)

    右上角tel什么意思(tel在右上角)

  • 什么是网络的心脏(什么是网络的心脏它提供了网络最基本的核心功能)

    什么是网络的心脏(什么是网络的心脏它提供了网络最基本的核心功能)

  • ipad可以钉钉打卡吗(ipad上钉钉可以打卡吗)

    ipad可以钉钉打卡吗(ipad上钉钉可以打卡吗)

  • 苹果手机微信发不了图片是怎么回事(苹果手机微信发消息怎么换行)

    苹果手机微信发不了图片是怎么回事(苹果手机微信发消息怎么换行)

  • 群里发消息为什么看不到(群里发消息为什么撤回了手机还显示)

    群里发消息为什么看不到(群里发消息为什么撤回了手机还显示)

  • vivo共享实时位置怎么修改(vivo共享实时位置)

    vivo共享实时位置怎么修改(vivo共享实时位置)

  • 小米一键换机要插卡吗(小米一键换机要注意什么)

    小米一键换机要插卡吗(小米一键换机要注意什么)

  • 字符串定义(c语言字符串定义)

    字符串定义(c语言字符串定义)

  • 手机语音不能用咋回事(手机语音发不出去怎么回事)

    手机语音不能用咋回事(手机语音发不出去怎么回事)

  • 京东申诉实名认证多久(京东申诉实名认证怎么弄)

    京东申诉实名认证多久(京东申诉实名认证怎么弄)

  • 数据线断了能接吗(数据线断了接上充电速度慢)

    数据线断了能接吗(数据线断了接上充电速度慢)

  • 手机储存空间怎么变大(手机储存空间怎么切换成内存卡储存)

    手机储存空间怎么变大(手机储存空间怎么切换成内存卡储存)

  • mac切换不了中文咋办? mac没有将文字转换为简体中文解决办法(mac切换不了中文怎么回事)

    mac切换不了中文咋办? mac没有将文字转换为简体中文解决办法(mac切换不了中文怎么回事)

  • 卷积神经网络学习—Resnet50(论文精读+pytorch代码复现)(卷积神经网络课程)

    卷积神经网络学习—Resnet50(论文精读+pytorch代码复现)(卷积神经网络课程)

  • 帝国cms如何实现当前栏目高亮(帝国cms教程官方完整版)

    帝国cms如何实现当前栏目高亮(帝国cms教程官方完整版)

  • Ant Design Vue 走马灯实现单页多张图片轮播(ant design vue2.0)

    Ant Design Vue 走马灯实现单页多张图片轮播(ant design vue2.0)

  • 水电怎么开票
  • 报销为什么不能多家赔付
  • 利润分配未分配利润借贷方表示什么
  • 营业执照办理税务登记需要什么资料
  • 装修工程一切险
  • 借方是收入还是支出 正负号
  • 国内增值税专用发票造假第一大案
  • 付境外公司佣金怎么做账
  • 以前年度损益调整会计分录
  • 非居民企业直接投资居民企业取得股息
  • 除了缴纳的税金还有什么
  • 经营租赁租赁费会计分录
  • 发票已认证还能作废吗2020
  • 股权转让印花税税目怎么填
  • 不应抵扣的进项税抵扣了怎么办
  • 支付的水电费属于什么会计科目
  • 境外工资薪金
  • 增值税发票增量流程网上怎么申请
  • 上个月有留抵税这个月怎么结转税金
  • 进口设备属于货物贸易吗
  • 分公司的款汇入总公司得出什么证明
  • 公司商品房出售流程
  • 收到融资租赁发票怎么做账
  • 如何解决win10系统安装不兼容驱动的问题
  • 注册表关闭微软yes改成no
  • 新会计规定工会会计制度
  • smartypig
  • 出租商品计入什么科目
  • PHP:mb_strrpos()的用法_mbstring函数
  • php中字符串函数
  • 股东帮企业还款违法吗
  • 担保公司未到期责任准备金会计及税务处理案例
  • 向境外支付技术提成费需要提交什么材料
  • element - - - - - 你不知道的loading使用方式
  • 详解16型人格
  • axure简单教程
  • free命令看到的内存
  • 待抵扣进项税额的账务处理
  • 进项税发票可以跨年认证吗
  • 所有者权益总计怎么算沙盘
  • 查账征收利润50万交多少税
  • 残疾人保证金怎么报税
  • 织梦怎么用
  • 设计模式代理模式
  • dedecms 收费
  • 将表里的数据批量删除
  • layuitablechecked获取选中数据方式
  • 防暑降温费用发放标准
  • 普票加专票超过45万怎么交税
  • 股东撤资如何退还资金,用途写什么
  • 困难行业企业包括哪四大类
  • 一般纳税人购进税控设备如何抵扣
  • 税金及附加没有设置二级科目,有啥影响吗
  • 对公账户汇款怎么原路退回
  • 支票为什么不能取钱
  • 建账前应考虑什么问题
  • 无发票 入账
  • 医疗机构药库设置标准
  • fedora安装apt
  • Win10 Mobile 10572怎么更新升级? 需回滚到WP 8.1
  • xp系统本地连接启用不了
  • ubuntu photoshop
  • 双系统麻烦吗
  • win8对机械硬盘不友好
  • window8.1
  • mcclauncher.exe
  • win7系统删除文件夹怎么恢复
  • win7屏幕刷新率怎么调高
  • css hacks
  • python 数据处理 pdf
  • python语言怎么用
  • 在javascript中
  • jquery ajax后台返回list,前台用jquery遍历list的实现
  • JavaScript+html5 canvas绘制的圆弧荡秋千效果完整实例
  • Android文本框怎么变成椭圆形?
  • android的动画有哪些?
  • 建筑单位外地缴税
  • 临时占地耕地占用税纳税义务发生时间
  • 车辆购置税是国家收还是地方收
  • 该纳税人还未申报,请申报成功后
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设