位置: 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)

  • 长租公寓 税费
  • 综合所得税和单独计税
  • 汇算清缴需要传什么资料
  • 国外进口原材料会计处理
  • 商贸企业印花税税率
  • 应收账款平均数
  • 返聘已退休人员是否需要缴纳社保
  • 低值易耗品摊销什么意思
  • 服务业预收款项怎么确认收入
  • 房地产开发公司取名
  • 可变股权转让对价会计处理怎么做?
  • 预提返利的会计处理
  • 企业关闭股东拿回投资款需要交税吗
  • 个体户需不需要开立对公账户
  • 小规模纳税人按什么标准纳税
  • 投资款需要交印花税嘛
  • 2017小规模纳税人标准
  • 非全日制员工个税扣除标准
  • 公司采购商品支付货款未开票会计分录
  • 购买银行承兑汇票的会计分录
  • 股利分配是在当期损益吗
  • 公司哪些发票可以做成本或者费用
  • 财务软件里凭证打印如何设置不打印三级科目
  • 0x000000a5蓝屏代码是什么意思
  • 发工资扣的个人社保计入哪个科目
  • 土地补偿款会议记录范文
  • 域名停靠是病毒吗
  • mac笔记本装了双系统后打开苹果系统和原来一样吗
  • 汇兑损益和财务费用区别
  • 公司清算债权债务如何清理
  • 增值税逾期未申报怎么补申报
  • nacos安装包
  • 搬迁补偿费属于什么费
  • 销售多余材料的成本
  • java开源二次开发平台
  • 小企业原材料
  • 上年度的企业所得税汇算清缴怎么查询
  • 劳务支出和应付职工薪酬
  • 织梦自适应代码怎么做
  • 长期待摊费用的摊销方法
  • 个体工商户生产经营所得税税率表2023
  • 本月销售商品会计分录
  • 母公司处置子公司合并报表
  • 出口的进项发票认证后要确认吗
  • 帮人家开税票对自己生意有影响么
  • 在建工程如何结转到产品
  • 福利费列支范围及标准
  • 固定资产清理营业外支出可在税前扣除?
  • 子公司注销母公司长投账务处理
  • 进口关税如何记账
  • 小规模纳税人哪里可以查
  • 金蝶凭证做错了已经入账怎么更正
  • 会计凭证发票粘贴
  • WINDOWS体验指数5.1
  • windowsxp关机没反应
  • linux配置raid5方法
  • CentOS上使用Squid+Stunnel搭建代理服务器教程
  • fedora29
  • centos7脚本
  • assoc.exe
  • dsapi.exe是什么
  • linux文件系统损坏导致网络断开
  • 退出清理磁盘
  • linux wc-l
  • windows8快速关机
  • Win10系统如何使用虚拟光驱加载ISO镜像文件?
  • 程序员基本入门知识
  • opengl常用函数库
  • 一道关于医用口罩的数学题初二
  • nodejs.
  • u3d脚本语言
  • jquery 字符串
  • 命令行执行bat文件
  • Python回调函数注册类型不匹配
  • javascript简单代码
  • Python出现keyerror
  • js给input添加属性
  • 国税纳税服务有哪些项目
  • 国税发1994 关于个人所得税
  • 统一社会信用代码证
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设