JavaScript(字符串)

字符串

1.字符串可以取下标,通过下标可以获取到对应的字符

2.字符串是只读数据,不能修改原字符串

3.字符串的长度:字符串.length

字符串的比较

字符串比较:

比较规则:逐字符比较,字符大小由阿斯克码决定的

排在后面的字母更大,小写字母比大写字母更大,字母比数字更大

需要记忆的阿斯克码:

数字:0~9   48~57

大写字母:A~Z   65~90

小写字母:a~z   97~122

阿斯克码:ASCII - 美国信息交换标准代码

计算机最早产生的时候,计算只能通过输入2进制的数字来控制他,他给用户呈现的内容,也只能使用2进制的形式来显示。

对于大部分人使用计算机造成了困扰。

科学家们,通过画图程序,将希望显示的内容,显示在页面中;制造了一套由输入的字符和2进制数字对应的系统。例:输入a - 让计算机默认转成输入的是 0101010 - 当计算机读取到这个2进制数字的时候,就让计算机通过画图程序帮用户显示成字符a

最早使用这套系统的人,是外国人,语言是使用字母以及一些符号,专门做了一张对照表,可以按照对照表上的记录,来使用计算机 - 阿斯克码表

阿斯克码表中有共128个对照,其中分别有输入的图形、对应的10进制数字、对应的2进制数字

汉字的大小,由unicode码决定

最早是外国人发明了对照表,但是对照表中只有128个字符。为了方便国人使用计算机,科学家们又创造了一张更大的对照表 - unicode。其中包含了全世界大部分国家的语言文件,汉字收录了93000多个汉字。每个汉字相当于也有对应的2进制数字和10进制数字,所以汉字也是可以有大小的。

字符串方法

字符串.charCodeAt() - 根据下标获取字符串对应的阿斯克码

var str = 'abcdef';
// 获取下标为3的字符的阿斯克码
var res = str.charCodeAt(0); // 参数为指定的下标
console.log(res); // 97

String.fromCharCode() - 根据阿斯克码获取对应的字符

// 获取98对应的字符
var res = String.fromCharCode(98); // 参数为指定的阿斯克码
console.log(res); // b

字符串.indexOf() - 找字符串第一次出现的下标

var str = 'i love you';
// 找到o字符在str中第一次出现的位置
var s = str.indexOf('o'); // 参数为要查找的字符
console.log(s); // 3

var s = str.indexOf('o',4); // 参数2为开始查找的下标
console.log(s) // 8

var s = str.indexOf('a') // 查找a字符在字符串中第一次出现的下标
console.log(s) // -1 - 找不到就返回-1

字符串.lastIndexOf() - 找字符串最后一次出现的下标

var str = 'i love you';
// 找到o字符在str中最后一次出现的位置
var s = str.lastIndexOf('o');
console.log(s); // 8

var s = str.lastIndexOf('o',7) // 将下标7当做字符串末尾,查找字符o在字符串中最后一次出现的下标
console.log(s) // 3

var s = str.lastIndexOf('a')
console.log(s) // -1 - 找不到就返回-1

字符串.split()  - 将字符串分割为数组

var str = 'a-b-c-d';
var arr = str.split('-') // 参数为分隔符,使用-将字符串分割为一个数组
console.log(arr) // ['a','b','c','d']

var arr = str.split('-',3) // 参数2表示数组中要保留前几个元素
console.log(arr) // ['a','b','c']

var str = 'abcd';
var arr = str.split() // 省略了分隔符,默认就不分割,将整个字符串当做一个元素放在数组中
console.log(arr) // ['abcd']

var arr = str.split('')
console.log(arr) // ["a", "b", "c", "d"]

字符串.slice() - 截取字符串  -  截取减一

var str = 'abcdef';
// 从下标1截取到下标4
var s = str.slice(1,4) // 参数1是开始截取的下标,参数2是截取的结束下标
console.log(s) // bcd - 结果中不包含结束下标对应的字符

var s = str.slice(1) // 省略第二个参数,默认能截取到字符串末尾
console.log(s) // bcdef

var s = str.slice(-3,-1) // 下标可以使用负数表示,-3表示倒数第3个字符,-1表示倒数第1个字符
console.log(s) // def

var s = str.slice(-1,-3) // 如果开始下标比结束下标大,会截取到空
console.log(s) // ''

字符串.substr() - 截取字符串 -  截取完

var str = 'abcdef';
str = str.substr(1,3) // 参数1是开始截取的下标,参数2是截取的字符串长度
console.log(str) // bcd

str = str.substr(1) // 省略参数2默认截取到字符串末尾
console.log(str) // bcdef

str = str.substr(-4,2) // 开始截取的下标可以用负数表示
console.log(str) // 'cd'

str = str.substr(1,20) // 长度超出最大下标,就相当于省略了参数2
console.log(str) // cdef

字符串.substring() - 截取字符串   -  截取减一

var str = 'abcdef'
str = str.substring(1,4) // 参数1是开始截取的下标,参数2是结束下标
console.log(str) // bcd - 结果不包含结束下标对应的字符

str = str.substring(1) // 省略参数2,默认截取到末尾
console.log(str) // bcdef

str = str.substring(1,1) // 开始下标和结束下标相等就截取到空字符串
console.log(str) // ''

str = str.substring(4,1) // 开始下标大于结束下标,就先交换两个参数位置,然后再截取
console.log(str) // 'bcd'

str = str.substring(-5,4) // 开始下标或结束下标是负数,就先替换为0,然后开始截取
console.log(str) // abcd

字符串.replace() - 替换字符串

var str = '你的头发还好吗?';
str = str.replace('头发','眉毛') // 参数1是被替换的字符串中的部分,参数2是新内容
console.log(str) // '你的眉毛还好吗?'

str = str.replace('','哈哈') // 参数1为空,就会将新内容添加到原字符串的最前面
console.log(str) // '哈哈你的眉毛还好吗?'

字符串.toUpperCase() - 转大写

var str = 'i love you';
str = str.toUpperCase()
console.log(str) // 'I LOVE YOU'

字符串.toLowerCase() - 转小写

var str = 'I LOVE YOU';
str = str.toLowerCase()
console.log(str) // 'i love you'

字符串.trim() - 去除两端空白

字符串.trimLeft() - 去除左边空白

字符串.trimRight() - 去除右边空白

var str = '    aaa          ';
str = str.trim()
console.log(str) // 'aaa' - 左右两端的空白被去掉了

str = str.trimLeft() // 去除左边的空白
console.log(str) // 'aaa          '

str = str.trimRight() // 去除右边的空白
console.log(str) // '    aaa'

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值