七、JS字符串"string"
ES5/String
字符串的常用方法
我们操作字符串,也有一堆的方法来帮助我们操作
字符串和数组有一个一样的地方,也是按照索引来排列的
charAt
、charCodeAt
、indexOf
、lastIndexOf
、substring
、substr
、split
、replace
、toLowewrCase
、toUpperCase
charAt()
是找到字符串中指定索引位置把内容返回,如果没有对应的索引,那么就会返回 空字符串1
2
3var str = 'HJ'
var res1 = str.charAt(1) // J
var res2 = str.charAt(3) // ''charCodeAt()
就是返回对应索引位置的unicode
编码1
2
3var str = 'HJ'
var res = str.charCodeAt(1) // 74
// 因为 `J` 在 `unicode` 对照表里面存储的是 74,所以就会返回 74indexOf()
就是按照字符找到对应的索引,找不到返回 -11
2
3var str = 'HJ'
var index = str.indexOf('J') // 1
var index = str.indexOf('K') // -1substring
是用来截取字符串使用的- 语法:
substring(从哪个索引开始,到哪个索引截止)
,包含开始索引,不包含结束索引
1
2
3
4var str = 'javascript'
var res1 = str.substring(0) // 'javascript'
var res2 = str.substring(4) // 'script'
var res2 = str.substring(0, 4) // 'java'- 语法:
substr
也是用来截取字符串的- 语法:
substr(从哪个索引开始,截取多少个)
1
2
3var str = 'javascript'
var res = str.substr(0) // "javascript"
var res = str.substr(0, 4) // "java"- 语法:
split
将字符串分割成数组1
2
3var name = "娄豪杰"
var res1 = name.split() // ['娄豪杰']
var res2 = name.split('') // ['娄', '豪', '杰']replace
字符串替换1
2var str = '666555666'
var res = str.replace('666', '444') // "444555666"toLowewrCase
字符串转成小写字母1
2var str = "LOUHAOJIE"
let res = str.toLowewrCase() // "louhaojie"toUpperCase
字符串转成大写字母1
2var str = "louhaojie"
let res = str.toUpperCase() // "LOUHAOJIE"
严格模式(了解)
- 我们都知道
js
是一个相对不很严谨的语言 - 而且开发的时候,一些代码也不是很严格要求
- 而严格模式就是对开发的时候写的一些内容做了要求
开启严格模式
想开启严格模式,直接在代码最开始的位置写上字符串
use strict
1
2
3
4<script>
"use strtic";
// 下面代码书写就要按照严格模式来书写
</script>
严格模式的规则
声明变量必须有
var
关键字1
2
3
4"use strtic";
num = 200; // 这个就会报错
var num = 200; // 正确写发放- 之前了解过,在声明变量的时候,如果没有
var
关键字,那么按照作用域的规则会自动定义成全局变量 - 严格模式下不可以,会报错
- 之前了解过,在声明变量的时候,如果没有
函数的行参不可以重复
1
2
3"use strtic";
function fn(p1, p1) {} // 直接就会报错- 在非严格模式下,函数两个行参一样,是不会报错的,只不过就是相当于在函数内部只有一个变量了
- 但是在严格模式下会报错
声明式函数调用的时候函数内部没有 this
1
2
3
4
5
6"use strtic";
function fn() {
console.log(this); // undefined
}
fn();- 本身,全局声明式函数在调用的时候,函数内部的
this
是指向window
的 - 在严格模式下,是没有
this
的
- 本身,全局声明式函数在调用的时候,函数内部的
ASCII 字符集(了解)
- 我们都知道,计算机只能存储
0101010
这样的二进制数字 - 那么我们的
a ~ z
/A ~ Z
/$
/@
/… 之类的内容也有由二进制数字组成的 - 我们可以简单的理解为,
a ~ z
/A ~ Z
/$
/@
/… 之类的内容都有一个自己的编号,然后在计算机存储的时候,是存储的这些编号,我们看的时候,也是通过这些编号在解析成我们要看到的内容给我们看到
unicode 编码
- 我们看到了,
ASCII
只有这128
个字符的编码结构 - 但是因为
ASCII
出现的比较早,而且是美国发明的,早先时候这些内容就够用了 - 因为存储一些英文的内容,传递一些英文的文章什么的都够用了
- 那么对于这个世界来说肯定是不够用的
- 因为我们的汉字没有办法存储,包括一些其他国家的语言也没有办法存储
- 所以就出现了
unicode
编码,也叫(万国码,统一码) unicode
对照表就是一个和ASCII
一样的对照表,只不过变得很大很大,因为存储的内容特别的多- 而且包含了世界上大部分国家的文字,所以我们的文字和字符现在在存储的时候,都是按照
unicode
编码转换成数字进行存储 - 我们的
UTF-8
就是一种8 位的 unicode
字符集
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 HJ BLOG!