前端 js 经典:字符串超全方法总结

2024-04-07 23:20

本文主要是介绍前端 js 经典:字符串超全方法总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. anchor 创建 a 标签字符串

anchor(name),name:a 标签的 name 属性

返回一个 a 标签字符串

let str = "yqcoder";// 不传值
str.anchor(); // '<a name="undefined">yqcoder</a>'// 创建 name 属性为 web 的 a 标签字符串
str.anchor("web"); // '<a name="web">yqcoder</a>'

2. at 根据下标查找字符

at(index?),index:字符串下标,默认等于 0

返回下标所在字符串,如果没找到返回 undefined

let str = "yqcoder";// 默认返回第 1 个字符
str.at(); // 'y'// 查找最后 1 个字符
str.at(-1); // 'r'// 没找到
str.at(100); // undefined

3. big 创建大号标签字符串

big(),返回大号标签字符串

let str = "yqcoder";// 创建 str 大号标签字符串
str.big(); // '<big>yqcoder</big>'

4. blink 创建闪动标签字符串

blink(),返回闪动标签字符串

let str = "yqcoder";// 创建 str 闪动标签字符串
str.big(); // '<blink>yqcoder</blink>'

5. bold 创建粗体标签字符串

bold(),返回粗体标签字符串

let str = "yqcoder";// 创建 str 粗体标签字符串
str.bold(); // '<b>yqcoder</b>'

6. charAt 查找下标对应字符

charAt(index?),index:字符下标,默认为 0

查找到返回对应字符,如果没找到返回空 ""。

let str = "yqcoder";// 默认返回第 1 位字符
str.charAt(); // y// 返回最后 1 位字符
str.charAt(str.length - 1); // r// 找不到
str.charAt(100); // ""

7. charCodeAt 查找下标对应字符的 Unicode 编码。

charCodeAt(index?),index:字符下标,默认为 0

查找到返回对应字符,如果没找到返回空 NAN。

let str = "yqcoder";// 默认返回第 1 位字符
str.charCodeAt(); // 121// 返回最后 1 位字符
str.charCodeAt(str.length - 1); // 114// 找不到
str.charCodeAt(100); // NAN

8. codePointAt 查找下标对应字符的 Unicode 编码。

codePointAt(index?),index:字符下标,默认为 0

查找到返回对应字符,如果没找到返回空 undefined。

let str = "yqcoder";// 默认返回第 1 位字符
str.codePointAt(); // 121// 返回最后 1 位字符
str.codePointAt(str.length - 1); // 114// 找不到
str.codePointAt(100); // undefined

9. concat 字符串拼接

concat(arg),arg 参数可以是字符串,数组,多层数组,多个数组。

返回拼接好的字符串

let str = "yqcoder";// 拼接普通字符串
str.concat(" is coder"); // 'yqcoder is coder'// 拼接字符串数组
str.concat([" is coder", " is a man"]); // 'yqcoder is coder, is a man'// 拼接多层字符串数组
str.concat([" is coder", [" is a man", [" is a big"]]]); // 'yqcoder is coder, is a man, is a big'// 拼接多个数组字符串
str.concat([" is coder"], [" is a man"]); // 'yqcoder is coder is a man'

10. endsWith 判断字符串是否由特定字符结尾

endsWith(str, length?),str:特定字符,length:被用来判断的字符长度,从左到右的字符长度。

判断时区分大小写,符合返回 true,不符合返回 false

let str = "yqcoder";// 判断是否coder结尾
str.endsWith("coder"); // true// 判断是否Coder结尾
str.endsWith("Coder"); // false// 判断前 6 个字符是否以 coder 结尾
str.endsWith("coder", 6); // false

11. fixed 创建<tt>标签字符串

fixed(),返回<tt>标签字符串

let str = "yqcoder";// 创建 str <tt>标签字符串
str.fixed(); // '<tt>yqcoder</tt>'

12. fontcolor 创建 color 属性的 font 标签字符串

fontcolor(color),color:颜色

返回 color 属性的 font 标签字符串

let str = "yqcoder";// 创建color为red的<font>标签字符串
str.fontcolor("red"); // '<font color="red">yqcoder</font>'

13. fontsize 创建 size 属性的 font 标签字符串

fontsize(size),size:字体大小

返回 size 属性的 font 标签字符串

let str = "yqcoder";// 创建size为red的<font>标签字符串
str.fontsize(12); // '<font size="12">yqcoder</font>'

14. includes 判断是否包含特定字符串

includes(str, start?),str:特定字符串,start:开始下标

包含返回 true,不包含返回 false

let str = "yqcoder";// 判断是否包含 'yq' 字符
str.includes("yq"); // true// 从下标 1 开始判断是否包含 'yq'
str.includes("yq", 1); // false

16. indexOf 查找字符串下标

indexOf(str, start?),str:查找字符,start:开始下标,默认从 0 开始

查找到返回下标,如果没找到返回 -1。

let str = "yqcoder-yqcoder";// 从下标 0 开始,查找 y 所在位置。
str.indexOf("y"); // 0// 从下标 2 开始,查找 y 所在位置。
str.indexOf("y", 2); // 8

17. isWellFormed 判断字符串是否包含单独代理项

isWellFormed(),返回 boolean 值。

let str = "yqcoder";
let str1 = "yqcoder\uD800";// 判断str是否包含单独代理项
str.isWellFormed(); // true// 判断str1是否包含单独代理项
str1.isWellFormed(); // false

18. italics 创建斜体标签字符串

italics(),返回斜体标签字符串

let str = "yqcoder";// 创建斜体字符串
str.italics(); // '<i>yqcoder</i>'

19. lastIndexOf 从后往前查找字符串下标

lastIndexOf(str, start?),str:查找字符,start:开始下标,默认从 0 开始

查找到返回下标,如果没找到返回 -1。

let str = "yqcoder-yqcoder";// 从最后 1 开始,查找 y 所在位置。
str.indexOf("y"); // 8// 从下标 0 开始,查找 y 所在位置。
str.indexOf("y", 0); // 0

20. link 创建 a 标签字符串

link(url),url:a 标签的 href 属性

返回一个 a 标签字符串

let str = "yqcoder";// 不传值
str.link(); // '<a href="undefined">yqcoder</a>'// 创建 href 属性为 www.baidu.com 的 a 标签字符串
str.link("www.baidu.com"); // '<a href="www.baidu.com">yqcoder</a>'

21. localeCompare 比较两个字符串大小

localeCompare(str),str:比较字符串

当大于比较字符串时返回 1,等于返回 0,小于返回 -1

let str = "a";
let str1 = "b";// 比较 str,str1 大小
str.localeCompare(str1); // -1// 自身比较
str.localeCompare(str); // 0// 比较 str1,str 大小
str.localeCompare(str); // -1

22. match 根据传入正则匹配字符串

match(reg),reg:传入正则

字符串满足正则要求返回一个数组。没找到返回 null

let str = "yqcoder";// 匹配正则 /coder/ 的字符串
str.match(/coder/); // ['coder', index: 2, input: 'yqcoder_yqcoder', groups: undefined]// 匹配正则 /coder/g 的字符串
str.match(/coder/g); // ['coder']// 不匹配正则
str.match(/\d/g); // null

23. matchall 根据传入正则匹配字符串

matchall(reg),reg:正则表达式,必须带 g

调用方法的字符串必须通过 ... 才可调用,满足条件返回分组迭代器,不满足返回 undefined

let str = "yqcoder-yqcoder";// 匹配正则 /coder/g 的字符串
console.log(...str.matchAll(/coder/g)); // ['coder', index: 2, input: 'yqcoder-yqcoder', groups: undefined] ['coder', index: 10, input: 'yqcoder-yqcoder', groups: undefined]// 不匹配正则
console.log(...str.matchAll(/\d/g)); // undefined

24. padEnd 尾部填充

padEnd(length, str?),length:填充长度,str:填充字符,默认为空

返回填充后的字符串,如果 length 小于原字符串长度,返回原字符串

let str = "yqcoder";// 默认填充字符串长度到 10
str.padEnd(10); // 'yqcoder   '// 填充 1 直到字符长度到 10
str.padEnd(10, 1); // 'yqcoder111'// 填充 123 知道字符长度到 9
str.padEnd(9, 123); // 'yqcoder12'// 填充 1 直到字符长度到 1
str.padEnd(1, 1); // 'yqcoder'

25. padStart 头部填充

padStart(length, str?),length:填充长度,str:填充字符,默认为空

返回填充后的字符串,如果 length 小于原字符串长度,返回原字符串

let str = "yqcoder";// 默认填充字符串长度到 10
str.padStart(10); // '   yqcoder'// 填充 1 直到字符长度到 10
str.padStart(10, 1); // '111yqcoder'// 填充 123 知道字符长度到 9
str.padStart(9, 123); // '12yqcoder'// 填充 1 直到字符长度到 1
str.padStart(1, 1); // 'yqcoder'

26. repeat 重复字符串

repeat(number), number:重复次数

返回重复后的字符串

let str = "yqcoder";// 重复 1 次字符串
str.repeat(1); // 'yqcoder'// 重复 2 次字符串
str.repeat(2); // 'yqcoderyqcoder'

27. replace 替换字符串

replace(oldStr, newStr),oldStr:替换前字符串,newStr:替换后字符串

返回替换后的字符串

let str = "yqcoder-yqcoder";// 将 yq 替换成 dyb
str.replace("yq", "dyb"); // 'dybcoder-yqcoder'// 将所有 yq 替换成 dyb
str.replace(/yq/g, "dyb"); // 'dybcoder-dybcoder'

28. replaceAll 替换所有满足条件字符串

replaceAll(oldStr, newStr),oldStr:替换前字符串,newStr:替换后字符串

返回替换后的字符串

let str = "yqcoder-yqcoder";// 将 yq 替换成 dyb
str.replaceAll("yq", "dyb"); // 'dybcoder-dybcoder'

29. search 查找字符串是否存在

search(str),str:目标字符串

如果查到返回目标字符串下标,如果没找到返回 -1

let str = "yqcoder";// 查找 'yq'
str.search("yq"); // 0// 查找 'dyb'
str.search("dyb"); // -1

30. slice 字符串截取

slice(start, end?),start:开始下标,end:结束下标

左闭右开,如果存在返回截取字段,不存在返回 ""

let str = "yqcoder";// 截取字符串前 2 位
str.slice(0, 2); // 'yq'// 截取字符串最后 1 位
str.slice(-1); // 'r'// 截取字符串第 11 位
str.slice(10, 11); // ''

31. small 创建 small 标签字符串

small(),返回一个 small 标签字符串

let str = "yqcoder";// 创建 small 标签字符串
str.small(); // '<small>yqcoder</small>'

32. split 字符串分割成数组

split(str?, length?),str:分割符,length:分割后数组长度

返回分割后的数组。

let str = "yqcoder-yqcoder";// 不传参,字符串直接转数组
str.split(); // ['yqcoder-yqcoder']// 将字符串以 "-" 分割成数组
str.split("-"); // ['yqcoder', 'yqcoder']// 将字符串以 "-" 分割成数组,只要数组第一项
str.split("-", 1); // ['yqcoder']

33. startsWith 判断字符串是否由特定字符开始

startsWith(str),str:特定字符

判断时区分大小写,符合返回 true,不符合返回 false

let str = "yqcoder";// 判断是否 yq 开始
str.startsWith("yq"); // true// 判断是否 Yq 开始
str.startsWith("Yq"); // false

34. strike 创建删除标签字符串

strike(),返回删除标签字符串

let str = "yqcoder";// 创建删除标签字符串
str.strike(); // '<strike>yqcoder</strike>'

35. sub 创建下标标签字符串

sub(),返回下标标签字符串

let str = "yqcoder";// 创建下标标签字符串
str.sub(); // '<sub>yqcoder</sub>

36. substr 字符串裁剪

substr(index, length?),index:开始下标,length:裁剪长度

返回裁剪后的字符串,包括 index 下标的字符。如果不传 length,默认裁剪从 index 到最后

let str = "yqcoder";// 裁剪下标 2 开始的全部字符
str.substr(2); // 'coder'// 裁剪前 2 位字符
str.substr(0, 2); // 'yq'

37. substring 字符串裁剪

substring(start, end?),start:开始下标,end:结束下标

返回裁剪后的字符串,包括 start 下标的字符。不包括 end 结束下标字符。如果不传 end,默认裁剪到最后

let str = "yqcoder";// 裁剪下标 2 开始的全部字符
str.substring(2); // 'coder'// 裁剪前 2 位字符
str.substring(0, 2); // 'yq'// 裁剪第 2 位
str.substring(1, 2); // 'q'

38. sup 创建上标标签字符串

sup(),返回上标标签字符串

let str = "yqcoder";// 创建上标标签字符串
str.sup(); // '<sup>yqcoder</sup>'

39. toLocaleLowerCase 字母转小写

toLocaleLowerCase(),将所有大写字母转小写

let str = "YqCoder";// 字母转小写
str.toLocaleLowerCase(); // 'yqcoder'

40. toLocaleUpperCase 字母转大写

toLocaleUpperCase(),将所有小写字母转大写

let str = "YqCoder";// 字母转大写
str.toLocaleUpperCase(); // 'YQCODER'

41. toLowerCase 字母转小写

toLowerCase(),将所有大写字母转小写

let str = "YqCoder";// 字母转小写
str.toLowerCase(); // 'yqcoder'

42. toUpperCase 字母转大写

toUpperCase(),将所有小写字母转大写

let str = "YqCoder";// 字母转大写
str.toUpperCase(); // 'YQCODER'

43. toString 转字符串

toString(),各个数据类型通过 toString()方法转字符串

let arr = [1, [2, 3, [4, 5, 6, [7, 8, 9]]]];
let obj = { name: "yqcoder" };
let bl = true;
let number = 123;// 数组转字符串,会将数组内数据平铺用, 拼接成字符串
arr.toString(); // '1,2,3,4,5,6,7,8,9'// 对象转字符串
obj.toString(); // '[object Object]'// 布尔值转字符串
bl.toString(); // 'true'// 数字转字符串
number.toString(); // '123'

44. toWellFormed 迭代字符串的码元

toWellFormed(),将任何单独的代理项替换为 Unicode 替换字符 U+FFFD �。

let str = "yqcoder";
let str1 = "yqcoder\uD800";// 将 str 中的单独的代理项替换成 �
str.toWellFormed(); // 'yqcoder'// 将 str1 中的单独的代理项替换成 �
str1.toWellFormed(); // 'yqcoder�'

45. trim 去字符串头和尾的空格

trim(),返回去除头尾空格后的字符串,无法去除中间的空格。

let str = "  yq coder  ";// 将 str 去除头尾空格
str.trim(); // 'yq coder'

46. trimEnd、trimRight 去字符串尾部的空格

trimEnd()、trimRight() 返回去除尾部空格后的字符串。

let str = "  yq coder  ";// 将 str 去除头尾空格
str.trimEnd(); // '  yq coder'
str.trimRight(); // '  yq coder'

47. trimStart、trimLeft 去字符串头部的空格

trimStart()、trimLeft() 返回去除头部空格后的字符串。

let str = "  yq coder  ";// 将 str 去除头尾空格
str.trimStart(); // 'yq coder  '
str.trimLeft(); // 'yq coder  '

这篇关于前端 js 经典:字符串超全方法总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/883953

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施: