位置: IT常识 - 正文

【JavaScript】五个常用功能/案例:判断特定结尾字符串 | 获取指定字符串 | 颜色字符串转换 | 字符串转驼峰格式 | 简易购物车(javascripts)

编辑:rootadmin
【JavaScript】五个常用功能/案例:判断特定结尾字符串 | 获取指定字符串 | 颜色字符串转换 | 字符串转驼峰格式 | 简易购物车

推荐整理分享【JavaScript】五个常用功能/案例:判断特定结尾字符串 | 获取指定字符串 | 颜色字符串转换 | 字符串转驼峰格式 | 简易购物车(javascripts),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascriptz,javascript !!,javascript gui,javascript!,javascriptz,javascript!,javascriptj,javascript gui,内容如对您有帮助,希望把文章链接给更多的朋友!

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 或未指定,基数将会根据字符串的值进行推算。

【JavaScript】五个常用功能/案例:判断特定结尾字符串 | 获取指定字符串 | 颜色字符串转换 | 字符串转驼峰格式 | 简易购物车(javascripts)

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+)\)/; // 不加gvar 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题库非常贴合实际的,在写的过程中自己查漏补缺,收获了很多,强烈将牛客网推荐给大家!

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

基础不牢,地动山摇! 快来和博主一起来牛客网刷题巩固基础知识吧!

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

上一篇:轻松玩转开源大语言模型bloom(一)(开源dap)

下一篇:UNet - unet网络(program status)

  • 复合计征消费税例题
  • 国税和地税的区别
  • 待摊费用和无形资产摊销
  • 辞退福利是指
  • 清包工取费标准
  • 免抵退税办法不得抵扣的进项税额包含了什么业务
  • 发票不附销货清单可以吗
  • 陈列费税率多少
  • 固定资产台账登记表明细科目写什么
  • 贴现利息可以抵扣吗
  • 月初发票认证能抵扣吗
  • 借入款项的来源包括哪三个
  • 出口收取佣金要开发票吗?
  • 抄税忘记了怎么办
  • 营改增后房地产企业增值税如何核算
  • 房地产土地增值税筹划
  • 向境外企业购买国内企业股权
  • 车间发生的购买办公用品支出应计入什么账户
  • 供应商返点抵应怎么做账
  • 个人租房给公司开票税点
  • 印花税减半征收优惠政策2023
  • 收到厂家返利怎么做账务处理
  • 什么叫经济作物和粮食作物
  • 本年利润和未分配利润怎么结转
  • 10款手机赚钱软件下载
  • PHP:mb_http_output()的用法_mbstring函数
  • 未入账发票可以作废吗
  • .exe是什么软件
  • 中拍网拍卖
  • 机器设备拆除增值税税率
  • php如何实现
  • 外币交易是什么意思
  • 短期资金都是债务类资金
  • 开具增值税专用发票的要求
  • 当月缴纳上月未缴纳社保
  • 待抵扣进项税在贷方什么意思
  • 败诉方承担诉讼费缴直接付给法院还是胜诉方
  • 不想预缴所得税能不能提前暂估费用,会计分录
  • Vue Router4 ,prams 传参失效和报错问题
  • 20221年最新
  • Windows7配置启用ca证书
  • 进项税额转出是好事还是坏事
  • 账载折旧金额填哪个数
  • 物业公司代收水费账务处理
  • 收据可以用来做账吗
  • 微信交电费怎么交
  • 怎么填红字信息表
  • 公章损坏如何更换
  • 冲销上个月成本的会计分录
  • 回扣发票能查出来么
  • 土地使用权是什么权利
  • 承租方承担的税费有哪些
  • 购买农产品普通发票怎么做账
  • 销售废旧物资账务处理
  • 企业所得税国税地税怎么分
  • 简易征收是什么意思和一般纳税人
  • mysql清空表内容
  • 强化廉洁意识 筑牢思想防线
  • ubuntu怎么用
  • linux文件切片命令
  • linux extundelete
  • win8.1笔记本
  • sointgr.exe - sointgr是什么进程 有什么用
  • sqlservr.exe - sqlservr是什么进程 有什么作用
  • win10预览版好吗
  • win7系统回收站不见了怎么办
  • windows7准备配置windows
  • win7网络连接无internet简单修复方法
  • win8如何调屏幕亮度
  • win8电脑键盘全部失灵怎么办
  • linux使用ssh远程连接服务器
  • meta 标签
  • linux中scp命令和scp命令用法大全
  • shell可以多线程吗
  • Android自定义控件高级进阶与精彩实例
  • 安卓手机命令代码
  • 简单谈谈你对中国国防建设的认识
  • 广西税务12366怎么查询发票
  • 企业房产税计算器
  • 土地增值税有哪些税收优惠
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设