JavaScript中String对象的方法介绍
发布时间 - 2026-01-10 22:18:20 点击率:次1.字符方法

1.1 charAt() 方法,返回字符串中指定位置的字符。
var question = "Do you like JavaScript?"; alert(question.charAt(5)); //"u"
字符串 "Do you like JavaScript?" 的长度为23,即位置从0到22。指定位置5处的字符是"u"。
1.2 charCodeAt() 方法,返回字符串中指定位置的字符编码。
var question = "Do you like JavaScript?"; alert(question.charCodeAt(5)); //"117"
位置5处的字符"u"的字符编码是"117"。
charAt() 和 charCodeAt() 都是针对单个字符进行操作的方法。
2.字符串操作方法
这个小节的字符串操作方法是关于创建新字符串的方法。这些方法包括 concat()、slice()、substring()、substr()。
concat() 是通过拼接的方式创建新的字符串,slice()、substring()、substr() 是通过提取的方式创建新的字符串。
这四种方法不会改变原始字符串。
2.1 concat() 方法,将一个或多个字符串拼接起来,返回新的字符串。不改变原始字符串。
concat() 方法可以接受一个或多个参数。
concat() 方法接受一个参数。
var love = "I love ";
var result = love.concat("you");
alert(result); //"I love you"
alert(love); //"I love "
love 调用了 concat() 方法,返回 "I love you",love 的值并没有改变。
concat() 方法接受多个参数。
var love = "I love ";
var result = love.concat("you"," very"," much","!");
alert(result); //"I love you very much!"
alert(love); //"I love "
不过,在实践中,通常用 + 号操作符将字符串拼接在一起。
2.2 slice()、substring()、substr() 方法,通过提取原始字符串的部分或全部来创建新的字符串,返回创建后的新字符串,不改变原始字符串。
slice()、substring()、substr() 方法可以接受一个或两个参数,这些参数为数字,可以是正值参数,也可以是负值参数。
2.2.1 参数为正值时
传入两个参数的情况
对于 slice() 、substring() ,第一个参数为提取的开始位置(包括开始位置的字符),第二个参数为提取的结束位置(不包括结束位置的字符)。
对于 substr(),第一个参数为提取的开始位置(包括开始位置的字符),第二个参数为提取的字符个数。
var hello = "I love JavaScript!"; alert(hello.slice(7,11)); //"Java" alert(hello.substring(7,11)); //"Java" alert(hello.substr(7,11)); //"JavaScript!"
字符串 "I love JavaScript!" 长度为18,即位置从0到17。第7位的字符是 "J",第11位的字符是 "S"。
slice()、substring() 提取的子字符串是从第7位开始(包括第7位的 "J")到第11位结束(不包括第11位的 "S"),于是用这两个方法提取的新字符串是 "Java"。而 substr() 则是从第7位 "J" 开始(包括第7位的 "J"),提取11个字符,最后提取的新字符串为 "JavaScript!"。
传入一个参数的情况
参数为正值,传入一个参数时,slice()、substring()、substr() 方法提取原理相同,即从参数的位置开始提取(包括开始位置的字符),一直提取到原始字符串的最后一个字符(包括最后一个字符)。
var hello = "I love JavaScript!"; alert(hello.slice(7)); //"JavaScript!" alert(hello.substring(7)); //"JavaScript!" alert(hello.substr(7)); //"JavaScript!"
传入了一个参数7,即从第7位开始(包括第7位的 "J"),一直提取到原始字符串的最后一位(包括最后一位的 "!")。于是,只有一个参数,且参数为正值时,slice()、substring()、substr() 方法返回的新字符串相同。
2.2.2 参数为负值时,不管是一个参数还是两个参数
slice() 方法会将传入的所有负值与字符串长度相加。
substring() 方法会将传入的所有负值都转化为0。
substr() 方法,若第一个参数是负值,则将负值与字符串长度相加;若第二个参数是负值,则将其转化为0。
var hello = "I love JavaScript!"; alert(hello.slice(-11)); //"JavaScript!" alert(hello.substring(-11)); //"I love JavaScript!" alert(hello.substr(-11)); //"JavaScript!" alert(hello.slice(-11,-9)); //"Ja" alert(hello.substring(-11,-9)); //""(空字符串) alert(hello.substr(-11,-9)); //""(空字符串)
当传入一个负值参数-1时,
slice() 将负值参数与字符串长度相加,前面提到过,字符串 "I love JavaScript!" 的长度为18,于是 slice(-11) 即相当于 slice(7),即从第7位开始提取,最后提取的子字符串为 "JavaScript!";
substring() 会将负值转化为0,substring(-11) 相当于 substring(0),即从第0位开始提取,最后提取的子字符串为 "I love JavaScript!";
substr() 将负值参数与字符串长度相加,substr(-11) 相当于 substr(7),即从第7位开始提取,最后提取的子字符串为 "JavaScript!"。
当传入参数-11,-9时,
slice() 将所有负值参数与字符串长度相加,slice(-11,-9) 相当于 slice(7,9),最后提取的子字符串为 "Ja";
substring() 会将所有负值转化为0,substring(-11,-9) 相当于 substring(0,0),即从第0位开始,第0位结束,即提取的是空字符串;
substr() 将第一个参数-11与字符串长度相加,将第二个参数-9转化为0,substr(-11,-9) 相当于 substr(7,0),即从第7位开始,提取0个字符串,即也是空字符串。
3.字符串位置方法
indexOf() 方法和 lastIndexOf() 方法,返回要检索的子字符串在原始字符串中第一次出现的位置。
indexOf() 方法从原始字符串开头向后检索子字符串,lastIndexOf() 方法从原始字符串末尾向前检索子字符串。
indexOf() 方法和 lastIndexOf() 方法接受一个必选参数。
var test = "balala balala balala";
alert(test.indexOf("a")); //"1"
alert(test.lastIndexOf("a")); //"19"
indexOf() 从开始位置向后检索子字符串 "a","a" 第一次出现的位置是1;lastIndexOf() 从末尾位置向前检索子字符串 "a","a" 第一次出现的位置是19。
如果没有找到要检索的子字符串,则这两个方法都会返回-1。
var test = "balala balala balala";
alert(test.indexOf("h")); //"-1"
alert(test.lastIndexOf("h")); //"-1"
indexOf() 方法和 lastIndexOf() 方法接受第二个可选参数,表示从原始字符串的哪个位置开始。
var test = "balala balala balala";
alert(test.indexOf("a",7)); //"8"
alert(test.lastIndexOf("a",7)); //"5"
indexOf("a",7) 从第7位向后检索子字符串 "a","a" 第一次出现的位置是8;lastIndexOf("a",7) 从第7位向前检索子字符串 "a","a" 第一次出现的位置是5。
4.字符串大小写换换方法
ECMAScript 中涉及字符串大小写转换的方法有4个:toUpperCase()、toLocaleUpperCase()、toLowerCase()、toLocaleLowerCase()。
toUpperCase() 和 toLowerCase() 是典型的方法,toLocaleUpperCase() 和 toLocaleLowerCase() 是针对当地地区的方法,以保证字符串正确的转换。
在不知道自己的代码在哪种语言环境中运行时,使用针对当地地区的方法更稳妥一些。
var test = "balala balala balala"; alert(test.toLocaleUpperCase()); //"BALALA BALALA BALALA" alert(test.toUpperCase()); //"BALALA BALALA BALALA" alert(test.toLocaleLowerCase()); //"balala balala balala" alert(test.toLowerCase()); //"balala balala balala"
5.trim()方法
trim() 方法会创建原始字符串的副本,并删除前置和后缀的所有空格,然后返回结果,不会改变原始字符串。
var test = " balala balala balala "; var test1 = test.trim(); alert(test1); //"balala balala balala" alert(test); // " balala balala balala " alert(test1.length); //"20" alert(test.length); //"28"
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
# js
# string对象的方法
# JavaScript之String常见的方法详解
# 用jQuery将JavaScript对象转换为querystring查询字符串的方法
# JavaScript基于扩展String实现替换字符串中index处字符的方法
# JavaScript中的toString()和toLocaleString()方法的区别
# javascript中数组(Array)对象和字符串(String)对象的常用方法总结
# JavaScript获取URL中参数querystring的方法详解
# 梳理总结JavaScript的23个String方法
# 第二个
# 即从
# 第一个
# 转化为
# 会将
# 多个
# 长度为
# 空字符串
# 这两个
# 不包括
# 则将
# 操作方法
# 不改变
# 自己的
# 的是
# 都是
# 是一个
# 则是
# 是从
# 如果没有
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
JS中对数组元素进行增删改移的方法总结
如何正确选择百度移动适配建站域名?
如何快速重置建站主机并恢复默认配置?
黑客如何利用漏洞与弱口令入侵网站服务器?
香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧
Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践
软银砸40亿美元收购DigitalBridge 强化AI资料中心布局
Android使用GridView实现日历的简单功能
高防服务器如何保障网站安全无虞?
简单实现Android验证码
uc浏览器二维码扫描入口_uc浏览器扫码功能使用地址
html文件怎么打开证书错误_https协议的html打开提示不安全【指南】
如何在宝塔面板中修改默认建站目录?
CSS3怎么给轮播图加过渡动画_transition加transform实现【技巧】
进行网站优化必须要坚持的四大原则
如何在万网ECS上快速搭建专属网站?
如何获取上海专业网站定制建站电话?
JS碰撞运动实现方法详解
Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】
Laravel怎么实现搜索功能_Laravel使用Eloquent实现模糊查询与多条件搜索【实例】
大同网页,大同瑞慈医院官网?
Linux网络带宽限制_tc配置实践解析【教程】
Android 常见的图片加载框架详细介绍
Laravel怎么在Controller之外的地方验证数据
湖南网站制作公司,湖南上善若水科技有限公司做什么的?
做企业网站制作流程,企业网站制作基本流程有哪些?
nginx修改上传文件大小限制的方法
如何基于云服务器快速搭建网站及云盘系统?
网站优化排名时,需要考虑哪些问题呢?
Android中AutoCompleteTextView自动提示
Laravel如何生成URL和重定向?(路由助手函数)
Laravel如何实现用户注册和登录?(Auth脚手架指南)
Laravel如何获取当前登录用户信息_Laravel Auth门面使用与Session用户读取【技巧】
Laravel如何实现URL美化Slug功能_Laravel使用eloquent-sluggable生成别名【方法】
什么是JavaScript解构赋值_解构赋值有哪些实用技巧
如何制作新型网站程序文件,新型止水鱼鳞网要拆除吗?
C++时间戳转换成日期时间的步骤和示例代码
DeepSeek是免费使用的吗 DeepSeek收费模式与Pro版本功能详解
SQL查询语句优化的实用方法总结
Microsoft Edge如何解决网页加载问题 Edge浏览器加载问题修复
如何在建站主机中优化服务器配置?
使用Dockerfile构建java web环境
Laravel如何处理CORS跨域问题_Laravel项目CORS配置与解决方案
如何用好域名打造高点击率的自主建站?
Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】
独立制作一个网站多少钱,建立网站需要花多少钱?
谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程
利用vue写todolist单页应用
Laravel怎么进行数据库回滚_Laravel Migration数据库版本控制与回滚操作
Laravel怎么进行浏览器测试_Laravel Dusk自动化浏览器测试入门

