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

  • 路由器拔掉电源再插上就连不上网怎么办(路由器拔掉电源再插上需要重新设置吗)

    路由器拔掉电源再插上就连不上网怎么办(路由器拔掉电源再插上需要重新设置吗)

  • 微博被限流怎么解除(微博被限流怎么办 如何解决微博限流_游戏狗手机版)

    微博被限流怎么解除(微博被限流怎么办 如何解决微博限流_游戏狗手机版)

  • 三种常见的视频格式(三种常见的视频文件格式)

    三种常见的视频格式(三种常见的视频文件格式)

  • ctrl+home是什么快捷键(ctrl和home)

    ctrl+home是什么快捷键(ctrl和home)

  • 红米k20pro充电突然变慢(红米k20pro充电一闪一闪的是什么原因)

    红米k20pro充电突然变慢(红米k20pro充电一闪一闪的是什么原因)

  • 内存频率重要吗(内存频率重要吗知乎)

    内存频率重要吗(内存频率重要吗知乎)

  • 苹果6能不能用快充头(苹果6能不能用5G卡)

    苹果6能不能用快充头(苹果6能不能用5G卡)

  • bilibili怎么关闭循环播放(哔哩哔哩怎么关闭会员续费)

    bilibili怎么关闭循环播放(哔哩哔哩怎么关闭会员续费)

  • 抖音无法下载视频怎么办(抖音无法下载视频,只可以复制链接)

    抖音无法下载视频怎么办(抖音无法下载视频,只可以复制链接)

  • 美团订单极速付款是什么(美团的极速付款)

    美团订单极速付款是什么(美团的极速付款)

  • 小米夜光屏是什么意思(小米夜光屏亮度有什么用)

    小米夜光屏是什么意思(小米夜光屏亮度有什么用)

  • 淘宝人生胡子怎么去除(淘宝人生 胡子)

    淘宝人生胡子怎么去除(淘宝人生 胡子)

  • wps文字怎么做表格(wps文字做表格)

    wps文字怎么做表格(wps文字做表格)

  • iphone11可以分屏吗(iphone 11能否分屏)

    iphone11可以分屏吗(iphone 11能否分屏)

  • 微信禁止砍价活动了吗(微信不能砍价了)

    微信禁止砍价活动了吗(微信不能砍价了)

  • xsmax原装是无线耳机吗(xsmax用什么无线充电器好)

    xsmax原装是无线耳机吗(xsmax用什么无线充电器好)

  • 剪映怎样剪音乐(剪映怎样剪音乐的声音)

    剪映怎样剪音乐(剪映怎样剪音乐的声音)

  • 快手降权什么标志(快手降权了怎么能恢复)

    快手降权什么标志(快手降权了怎么能恢复)

  • 陀螺仪灵敏度是什么(陀螺仪灵敏度是不是越高越好)

    陀螺仪灵敏度是什么(陀螺仪灵敏度是不是越高越好)

  • 微信评论区怎么显示全文(微信评论区怎么发表情包图片)

    微信评论区怎么显示全文(微信评论区怎么发表情包图片)

  • iphone8短信拦截设置(苹果手机短息拦截)

    iphone8短信拦截设置(苹果手机短息拦截)

  • 小米m1810f6le是什么型号(小米m1810f6le是什么型号手机)

    小米m1810f6le是什么型号(小米m1810f6le是什么型号手机)

  • U盘UEFI硬装WIN10 64位系统安装不求人(三星951+GTX950)(uefi启动u盘安装win10系统的详细流程)

    U盘UEFI硬装WIN10 64位系统安装不求人(三星951+GTX950)(uefi启动u盘安装win10系统的详细流程)

  • Win11怎么安装打印机? Windows11安装打印设备的技巧(win11自带一键重装系统)

    Win11怎么安装打印机? Windows11安装打印设备的技巧(win11自带一键重装系统)

  • 进项税转出的金额含税吗
  • 收到货款发货了没开发票怎么入账
  • 企业缴纳季度所得税
  • 疫情期间餐饮发票税点
  • 货品调拨的意义
  • 银行存款支付运费会计科目
  • 资产负债表的累计折旧期末数怎么填
  • 申报美元出口以欧元收汇
  • 小规模企业发生了增值税,如何计提附加税
  • 注销实收资本账务处理
  • 两金占流动资产比重
  • 外资企业享受什么优惠政策
  • 红字发票科目入进项税额还是进项税额转出
  • 在建工程转什么
  • 固定资产盘亏造成的损失计入什么科目
  • 一般纳税人公司卖车怎么做账
  • 基本户开户费多少钱
  • 利润表所得税费用计算公式
  • 增值税一般纳税人与小规模纳税人的区别
  • 应付短期租入固定资产的租金计入什么科目
  • 商业承兑汇票如何查询
  • win11正式版好用吗
  • cmos电池耗尽
  • 水利基金返还分录怎么写
  • 加计扣除的会计要素
  • sentstrt.exe - sentstrt进程是什么文件 有什么用
  • 天猫魔合
  • 佣金手续费开什么发票
  • phpget方法
  • 稳岗补贴支付范围
  • 提取现金 备发工资
  • 挂在树上的小鸟怎么画
  • 前端 组件化
  • node.js的安装和配置
  • is-l命令
  • 2019年新会计制度改革
  • 旅行社代订酒店如何入账
  • 生产成本有什么
  • 房地产企业的开发成本和开发费用有什么区
  • 应付账款转入营业外收入的证明
  • 融资租赁有免租金吗
  • mongodb导入数据三种方式
  • mysql复制数据到另一张表
  • 小规模纳税人申报增值税的操作流程
  • 差旅费住宿费专票
  • 生产企业电费怎么做账
  • 预付账款摊销会计分录
  • 运费开什么发票
  • 审计 调整分录
  • 营业外支出罚没支出包括
  • 小规模开具的1%专票 一般纳税人抵扣
  • 未计提坏账准备的应收账款
  • 企业组织结构的本质是
  • 存货与总账对账
  • linux怎么修改
  • 笔记本上安装软件怎么弄
  • wncloud.exe是什么程序
  • win7系统压缩包
  • centos中用户的基本属性
  • KunlunPlatform.exe是什么进程?KunlunPlatform.exe是安全的程序吗?
  • win8截屏在哪个文件夹
  • 苹果电脑dashboard什么意思
  • 富泽园假日酒店
  • 有没有软件恢复
  • win8.1如何更改密码
  • win8系统开机启动项怎么设置
  • redhat本地yum配置的基本步骤
  • jQuery ajax读取本地json文件的实例
  • [置顶] 纯享版奥义,手机迅雷搜:阿天动漫
  • cocos2d-x windows开发环境配置
  • jquery实现图片懒加载
  • 电脑启动项清理
  • javascript总结
  • javascriptz
  • unity dllimport
  • 请问在javascript程序中
  • Nodejs之http的表单提交
  • 深入理解新发展理念
  • 江苏税务开发票
  • 税控发票开票软件提示非征期不得抄报税?是什么意思?
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设