CSDN话题挑战赛第2期
参赛话题:学习笔记
🖥️ NodeJS专栏:Node.js从入门到精通
🖥️ 博主的前端之路:前端之行,任重道远(来自大三学长的万字自述)
🖥️ TypeScript知识总结:TypeScript从入门到精通(十万字超详细知识点总结)
🧑💼个人简介:大三学生,一个不甘平庸的平凡人🍬
👉 你的一键三连是我更新的最大动力❤️!
🏆分享博主自用牛客网🏆:一个非常全面的面试刷题求职网站,点击跳转🍬
文章目录
- 前言
- 一、判断特定结尾的字符串
- 二、获取指定字符串
- 三、颜色字符串格式转换
- 四、将字符串转换为驼峰格式
- 五、实现简易购物车
- 结语
前言
最近博主一直在牛客网刷题巩固基础知识,牛客网不仅具有公司真题、专项练习、面试题库、在线编程等功能,还具有非常强大的AI模拟面试功能,简直是求职者的福音!
牛客网里的题库非常全面的,无论你是前端还是后端,是想要备考还是准备面试又或者是想要提高自己,你都能在牛客网上找到适合自己的题,赶快点击链接去注册登录吧:点我进入牛客网
牛客网 | 牛客网 |
---|---|
本篇文章所有示例来自于牛客网题库/在线编程/JS篇
,这些都是前端开发中常用的功能,借此记录一下刷题过程,巩固基础!
一、判断特定结尾的字符串
描述:
给定字符串 str
,检查其是否以元音字母结尾
1、元音字母包括 a
,e
,i
,o
,u
,以及对应的大写
2、包含返回 true
,否则返回 false
示例:
输入:'gorilla'
输出:true
方案一: 运用数组进行判断
function endsWithVowel(str) {
const arr=['a','e','i','o','u']
return arr.includes(str[str.length-1].toLowerCase())
}
知识点:
- includes()方法用来判断一个数组是否包含一个指定的值。
- toLowerCase() 会将调用该方法的字符串值转换为小写形式,并返回。
方案二: 使用正则
function endsWithVowel(str) {
const reg=/[aeiou]$/gi
return reg.test(str)
}
知识点:
[aeiou]
表示匹配一个字符,它可以是“a
”、“e
”、“i
”、“o
”、“u
”之一。- 正则表达式后面的
g
,i
是正则的一个修饰符,g
表示全局匹配,i
表示不区分大小写。 $
(美元符号)匹配结尾,在多行匹配中匹配行结尾。- test() 方法执行一个检索,用来查看正则表达式与指定的字符串是否匹配。返回
true
或false
。
二、获取指定字符串
描述:
给定字符串 str
,检查其是否包含 连续3个数字,请使用正则表达式实现。
1、如果包含,返回最先出现的 3 个数字的字符串
2、如果不包含,返回 false
示例:
输入:'9876543'
输出:'987'
方案:
function captureThreeNumbers(str) {
const reg=/\d{3}/g
if(reg.test(str)){
return str.match(reg)[0]
}
return false
}
知识点:
\d
就是[0-9]
,表示是一位数字。{m}
等价于{m,m}
,表示出现m
到m
次,即m
次。({m,n}
,表示出现m
到n
次。)- 正则表达式后面的
g
是正则的一个修饰符,表示全局匹配。 - test() 方法执行一个检索,用来查看正则表达式与指定的字符串是否匹配。返回
true
或false
。 - match()方法检索返回一个字符串匹配正则表达式的结果。(数组形式)
三、颜色字符串格式转换
描述:
将 rgb
颜色字符串转换为十六进制的形式,如 rgb(255, 255, 255)
转为 #ffffff
rgb
中每个 , 后面的空格数量不固定- 十六进制表达式使用六位小写字母
- 如果输入不符合
rgb
格式,返回原始输入
示例:
输入:'rgb(255, 255, 255)'
输出:#ffffff
方案一:
function rgb2hex(sRGB) {
const reg = /^rgb\((\d+),\s*(\d+),\s*(\d+)\)$/;
const ret = sRGB.match(reg);
if (!ret) {
return sRGB;
} else {
var str = "#";
for (var i = 1; i <= 3; i++) {
var m = parseInt(ret[i]);
if (m >= 0 && m <= 255) {
str += m < 16 ? "0" + m.toString(16) : m.toString(16);
} else {
return sRGB;
}
}
return str;
}
}
知识点:
-
正则里
^
表示开头;\
代表转义(如不能直接输入(
,需要输入\(
对(
进行转义);\d
就是[0-9]
,表示是一位数字;+
等价于{1,}
,表示出现至少一次;\s
是[ \t\v\n\r\f]
,表示空白符,包括空格、水平制表符、垂直制表符、换行符、回车符、换页符;*
等价于{0,},表示出现任意次,有可能不出现。$
代表结尾
-
parseInt(string,radix) 解析一个字符串并返回指定基数(
radix
)的十进制整数,radix
是2-36之间的整数,假如radix
指定 0 或未指定,基数将会根据字符串的值进行推算。 -
rgb(a, b, c)
中的a
、b
、c
都在0~255之间。 -
match() 方法检索返回一个字符串匹配正则表达式的结果(数组形式),如果正则表达式没有设置全局标志 (
g
),数组的0元素包含整个匹配,而第 1 到 n 元素包含了匹配中曾出现过的任一个子匹配。这相当于没有设置全局标志的exec
方法。如果设置了全局标志(g
),元素0到n
中包含所有匹配。var regexp = /rgb\((\d+),\s*(\d+),\s*(\d+)\)/g; // 加g全局匹配 var ret = "rgb(255, 250, 255)".match(regexp); console.log("全局匹配结果:", ret); // 全局匹配结果: [ 'rgb(255, 250, 255)' ]
var regexp = /rgb\((\d+),\s*(\d+),\s*(\d+)\)/; // 不加g var ret = "rgb(255, 250, 255)".match(regexp); console.log("匹配结果:", ret); // 匹配结果: [ // 'rgb(255, 250, 255)', // '255', // '250', // '255', // index: 0, // input: 'rgb(255, 250, 255)', // groups: undefined // ]
思路:
先使用正则判断输入的内容是否符合rgb
格式,是的话就for
循环遍历到rgb
中的三个数值字符串,通过parseInt
将其转换成数值,再进一步判断其是否在0~255之间,是的话就继续操作,通过toString(16)
转换成16进制字符串(需要注意的是,如果原数小于16,转换成16进制后就只有一位,这时就需要在它前面补0,因为案例要求的是十六进制表达式使用六位小写字母,每两位表示一个rgb
中的一个数值)
方案二: 优雅永不过时!
function rgb2hex(sRGB) {
try {
return eval(sRGB);
} catch (err) {
// 出现错误了就直接返回sRGB
return sRGB;
}
}
// 定义一个rgb方法(因为sRGB字符串是rgb(a,b,c)格式的,当作JS代码执行时相当于是调用rgb函数)
function rgb(r, g, b) {
// 有一个数值不在0~255范围内就抛出错误
if (!num(r) || !num(g) || !num(b)) {
throw Error;
}
let rH = r.toString(16);
let gH = g.toString(16);
let bH = b.toString(16);
// 是一位时在前面补零补成两位
rH = rH.length == 1 ? "0" + rH : rH;
gH = gH.length == 1 ? "0" + gH : gH;
bH = bH.length == 1 ? "0" + bH : bH;
return "#" + rH + gH + bH;
}
// 判断数值范围是否在0~255之间
function num(num) {
return parseInt(num) >= 0 && parseInt(num) <= 255;
}
知识点:
- eval() 函数会将传入的字符串当做
JavaScript
代码进行执行。
这种方法比较巧妙,也比较简单直观。
四、将字符串转换为驼峰格式
描述:
css
中经常有类似 background-image
这种通过 -
连接的字符,通过 javascript
设置样式的时候需要将这种样式转换成 backgroundImage
驼峰格式,请完成此转换功能
- 以
-
为分隔符,将第二个起的非空单词首字母转为大写 -webkit-border-image
转换后的结果为webkitBorderImage
示例:
输入:'font-size'
输出:fontSize
方案:
function cssStyle2DomStyle(sName) {
let str = "";
// 通过-分割字符串,获得分割后的数组
const arr = sName.split("-");
// 如果数组第一位为空,则将其删除
if (arr[0] === "") {
arr.shift();
}
for (let i = 0; i < arr.length; i++) {
if (i === 0) {
str += arr[i];
} else {
str += arr[i][0].toUpperCase() + arr[i].slice(1);
}
}
return str;
}
知识点:
-
split() 方法使用指定的分隔符字符串将一个
String
对象分割成子字符串数组,以一个指定的分割字串来决定每个拆分的位置。const arr = "a-b-c".split("-"); console.log(arr); // [ 'a', 'b', 'c' ]
-
shift() 方法会删除数组的第一个元素并返回删除的这个元素,该方法会改变原数组。
-
toUpperCase() 方法将字符串转换成大写形式并返回。
-
slice(a,b) 方法截取字符串,从下标a截取到下标b(包括下标为a的元素不包括下标b的元素),如果不指定a代表从索引 0 开始,不指定b则代表截取到最后(包含最后一个元素)。a为负值时则表示从原数组中的倒数第几个元素开始提取。
五、实现简易购物车
描述:
HTML
模块为一个简化版的购物车,tbody
为商品列表,tfoot
为统计信息,系统会随机在列表中生成一些初始商品信息
1、请完成add
函数,在列表后面显示items
商品信息。参数items
为{name: String, price: Number}
组成的数组
2、请完成bind
函数,点击每一行的删除按钮(包括通过add
增加的行),从列表中删除对应行
3、请注意同步更新统计信息,价格保留小数点后两位
4、列表和统计信息格式请与HTML
示例保持一致
5、不要直接手动修改HTML
中的代码
6、不要使用第三方库
方案:
HTML:
<table id="jsTrolley">
<thead><tr><th>名称</th><th>价格</th><th>操作</th></tr></thead>
<tbody>
<tr><td>产品1</td><td>10.00</td><td><a href="javascript:void(0);">删除</a></td></tr>
<tr><td>产品2</td><td>30.20</td><td><a href="javascript:void(0);">删除</a></td></tr>
<tr><td>产品3</td><td>20.50</td><td><a href="javascript:void(0);">删除</a></td></tr>
</tbody>
<tfoot><tr><th>总计</th><td colspan="2">60.70(3件商品)</td></tr></tfoot>
</table>
<!-- 测试 -->
<button onclick="add([{name: 'Ailjx', price: 3}])">增加</button>
CSS:
body,
html {
padding: 0;
margin: 0;
font-size: 14px;
color: #000000;
}
table {
border-collapse: collapse;
width: 100%;
table-layout: fixed;
}
thead {
background: #3d444c;
color: #ffffff;
}
td,
th {
border: 1px solid #e1e1e1;
padding: 0;
height: 30px;
line-height: 30px;
text-align: center;
}
JavaScript:
function add(items) {
let tbody = document.getElementsByTagName('tbody')[0];
items.forEach((item) => {
// 创建tr节点
let tr = document.createElement('tr');
tr.innerHTML = `<td>${item.name}</td><td>${item.price.toFixed(2)}</td><td><a href="javascript:void(0);">删除</a></td>`;
// 将创建的tr添加到tbody中
tbody.appendChild(tr);
})
// 调用更改统计价格和数量的函数
changePrice();
}
function bind() {
let tbody = document.getElementsByTagName('tbody')[0];
// 给tbody添加点击事件
tbody.onclick = function (e) {
let target = e.target
// 如果点击的是删除按钮
if (target.innerText == "删除") {
// Element.remove() 方法,把对象从它所属的 DOM 树中删除。
target.parentNode.parentNode.remove();
// 调用更改统计价格和数量的函数
changePrice();
}
}
}
// 更改统计价格和数量的函数
function changePrice() {
let tbody = document.getElementsByTagName('tbody')[0];
let tftext = document.getElementsByTagName('tfoot')[0].children[0].children[1];
let total = 0;
// 统计总价
for (let i = 0; i < tbody.children.length; i++) {
// parseFloat() 函数解析一个参数(必要时先转换为字符串)并返回一个浮点数。
total += parseFloat(tbody.children[i].children[1].innerText);
};
// toFixed(digits) 方法使用定点表示法来格式化一个数值。参数digits表示小数点后数字的个数
// Element.childElementCount 只读属性返回一个无符号长整型数字,表示给定元素的子元素数。
tftext.innerText = `${total.toFixed(2)}(${tbody.childElementCount}件商品)`;
}
效果演示:
结语
这篇文章的所有内容都出自于牛客网的JS篇题库:
牛客网的JS
题库非常贴合实际的,在写的过程中自己查漏补缺,收获了很多,强烈将牛客网推荐给大家!
如果本篇文章对你有所帮助,还请客官一件四连!❤️
基础不牢,地动山摇! 快来和博主一起来牛客网刷题巩固基础知识吧!