js快速入门—string篇

string

对字符串操作的各种方法和技巧

索引
indexOf(str,[start])返回字符串中指定文本首次出现的索引位置,若未找到返回-1
search(str)返回字符串中指定文本首次出现的索引位置,若未找到返回-1
match(reg)通过正则以数组形式返回找到的字符串
includes(str)是否包含字符串,返回布尔类型
const str = 'hang love dan hang love dan'
const index1 = str.indexOf('love')  // 5
const index2 = str.lastIndexOf('love')  // 19
const index = str.search('dan') // 10

search和indexOf基本一致,以下为不同点:
1. search()无法设置第二个开始位置参数
2. indexOf()无法设置正则表达式搜索值
提取字符串
slice(start, end)提取字符串指定位置,[ 起始,结束 ),允许负数
substring(start, end)提取字符串指定位置,[ 起始,结束 ),不允许负数
substr(start, length)提取字符串指定位置,[ 起始,长度)
chatAt(position)提取字符串指定下标字符串
charCodeAt(postion)提取字符串指定下标字符串的unicode编码
const str = 'hang'
const res = str.slice(2)  // ng, 默认截取到最后
const res = str.substr(2, 1)  // n, 弃用
const str1 = '110'
const res = str1.charAt(0) // 1
const res = str1.charCodeAt(1) // 49
替换
replace(str, newStr)将字符串中某段字符串替换,只替换首个,返回新字符串
const str = 'hang Dan dan hang Dan'
const res = str.replace('dan', 'hang') // hang Dan hang hang Dan 只能替换第一个
const res = str.replace(/dan/i, 'hang')  // hang hang dan hang Dan 大小写不敏感
const res = str.replace(/dan/ig, 'hang') // 全局替换且大小写不敏感
大小写
toUpperCase()转换为大写
toLowerCase()转换为小写
接字符串
concat()连接两个或多个字符串
const str1 = 'hang'
const str2 = 'dan'
str = str1.concat(' love ', str2)  // hang love dan
清空空白符
trim()删除字符串两端空格,中间不会删除
const str1 = '     h an g       '
str = str1.trim() // h an g

存在一个缺陷,此方法不知此IE8以下版本,我们可以用replace正则替代

str = str1.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g, '')

还可以判断若没有,自定义trim方法

if(!String.prototype.trim){
    String.prototype.trim = function() {
        return this.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g, '')
    }
}
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值