字符串的创建(2种方法)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<script>
// 字符串的创建(2种方法创建)
// 1. 字面量方式创建
var str = '码小目'
console.log( str)
var str = "maxiaomu"
console.log( str)
var str = `112233`
console.log( str)
// 也叫作模板字符串
// 2. 内置构造函数创建
var str = new String('码小目')
console.log( str)
var str = new String("maxiaomu")
console.log( str)
var str = new String(`112233` )
console.log( str)
</script>
</body>
</html>
两种创建方法如上所属,其返回值如下:
方法一:字面量法
这种方法创建的是整体是一个字符串
方法二: 内置构造函数创建
这种方法创建的是一个字符串的集合,其中所有的都是单个的字符串类型
字符串的基本操作
1. length 属性( 即'读' 获取)
语法: 字符串.length
得到: 该字符串的长度, 也就是该字符串由多少个字符组成
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <script> // 字符串的创建(2种方法创建) // 1. 字面量方式创建 var str = '码小目' console.log( str.length) var str = "maxiaomu" console.log( str.length) var str = `112233` console.log(str.length) // 也叫作模板字符串 // 2. 内置构造函数创建 var str = new String('码小目') console.log(str.length) var str = new String("maxiaomu") console.log( str.length) var str = new String(`112233` ) console.log( str.length) </script> </body> </html>
注意: 在字符串内, 空格是占有长度的, 中文也是一个字符长度
2. 索引 读(获取)
+ 是一个只读的属性
+ 字符串也是按照索引排列的
=> 语法: 字符串[索引]
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <script> // 字符串的创建(2种方法创建) // 1. 字面量方式创建 var str = '码小目' console.log( str[2]) console.log( str[4]) var str = "maxiaomu" console.log( str[2]) console.log( str[12]) var str = `112233` console.log( str[4]) console.log( str[8]) // 也叫作模板字符串 // 2. 内置构造函数创建 var str = new String('码小目') console.log( str[2]) console.log( str[4]) var str = new String("maxiaomu") console.log( str[2]) console.log( str[12]) var str = new String(`112233` ) console.log( str[4]) console.log( str[8]) </script> </body> </html>
如果字符串有该索引位置, 那么就是该索引位置的字符
如果字符串没有该索引位置, 那么就是 undefined
3. 遍历
+ 因为 字符串 也是按照索引排列
+ 所以依旧使用 循环 进行遍历(一组从0开始的有规律数字)
根据此处代码以及返回值可以看出
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <script> // 字符串的创建(2种方法创建) // 1. 字面量方式创建 var str = '码小目' var re= fn( str) console.log( re) var str = "maxiaomu" var re= fn( str) console.log( re) var str = `112233` var re= fn( str) console.log( re) // 也叫作模板字符串 // 2. 内置构造函数创建 var str = new String('码小目') var re= fn( str) console.log( re) var str = new String("maxiaomu") var re= fn( str) console.log( re) var str = new String(`112233`) var re= fn( str) console.log( re) function fn() { for (var i = 0; i < str.length; i++) { // i 就是字符串内每一个字符的索引 console.log(' 我是索引'+`${i}`,str[i]) //就是字符串内的每一个字符 } return res=console.log(str[i]) } </script> </body> </html>
字符串常用方法
JS 提供的一系列操作 字符串 的方法
注意: 所有字符串常用方法均不会改变原始字符串, 都是返回值形式给出结果
1. charAt()
+ 语法: 字符串.charAt(索引)===字符串[ 索引 ]
+ 返回值:
-> 如果字符串有该索引位置, 那么就是该索引位置的字符
-> 如果字符串没有该索引位置, 那么就是 空字符串
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<script>
// 内置构造函数创建
var str = new String('码小目')
console.log( str.charAt( 2))
console.log( str[ 12])
var str = new String("maxiaomu")
console.log( str.charAt (2))
console.log( str [14])
var str = new String(`112233`)
console.log( str.charAt (2))
console.log( str [8])
</script>
</body>
</html>
2. charCodeAt()
+ 语法: 字符串.charCodeAt(索引)
+ 返回值:
-> 如果字符串有该索引位置, 那么就是该索引位置的字符的编码(UTF-8)
-> 如果字符串没有该索引位置, 那么就是 NaN
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<script>
// 内置构造函数创建
var str = new String('码小目')
console.log( str.charCodeAt( 2))
var str = new String("maxiaomu")
console.log( str.charCodeAt (2))
var str = new String(`112233`)
console.log( str.charCodeAt (2))
</script>
</body>
</html>
3. toUpperCase()
+ 语法: 字符串.toUpperCase()
+ 返回值: 转换好大写字母以后的字符串
4. toLowerCase()
+ 语法: 字符串.toLowerCase()
+ 返回值: 转换好小写字母以后的字符串
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<script>
// 大小写转换
var str = new String("MaXiAoMu")
// 转换成大写
console.log( str.toUpperCase ( ))
// 转换成小写
console.log( str.toLowerCase ( ))
</script>
</body>
</html>
大小写转换效果如上图所示:toUpperCase() toLowerCase()
5. substr()
语法: 字符串.substr(开始索引, 截取多少个)
返回值: 从原始字符串内截取出来的字符串片段
6. substring()
+ 语法: 字符串.substring(开始索引, 结束索引)
特点: 包前不包后, 包含开始索引, 不包含结束索引
返回值: 从原始字符串内截取出来的字符串片段
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<script>
var str = new String("Ma-Xi-Ao-Mu -")
// 字符串.substr(开始索引, 多少个)
console.log( str.substr (2,6))
//字符串.substring(开始索引, 结束索引) 包前不包后
console.log( str.substring (2,8))
</script>
</body>
</html>
7. slice() 和数组方法同名
+ 语法: 字符串.slice(开始索引, 结束索引)
特点1: 包前不包后/ 特点2: 可以填写负整数
8. split ( )
+ 语法: 字符串.split(切割符号)---
+ 作用: 把字符串按照符号切割成一个数组
+ 返回值: 是一个数组数据类型
如果传递一个空字符串, 表示按照一位一位的切割开 (' ')
数组内是你把原始字符串切割开的每一个部分
8. replace( ) replaceAll( 全部替换 )
+ 语法: 字符串.replace(换下字符, 换上字符)
+ 返回值: 替换好一个以后的字符串
+ 注意: 不管有多少个换下字符, 只能替换第一个
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<script>
var str = new String("Ma-Xa-ao-Ma -")
// replace 将第一个a替换成A
console.log(str.replace('a','A') )
// replaceAll 将所有a替换成A
console.log( str. replaceAll('a','A') )
</script>
</body>
</html>
10. indexOf( )
+ 语法: 字符串.indexOf(字符串片段, 开始索引)
+ 返回值: 如果原始字符串内有该字符串片段, 那么就是该字符串片段的起始索引位置
如果原始字符串内没有该字符串片段, 那么就是 -1 注意: 从左向右查找
11. lastIndexOf( )
+ 语法: 字符串.lastIndexOf(字符串片段, 开始索引)
+ 返回值 如果原始字符串内有该字符串片段, 那么就是该字符串片段的起始索引位置
如果原始字符串内没有该字符串片段, 那么就是 -1 注意: 从右向左查找
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<script>
var str = new String("MaXaaoMa")
// 从左向右 第一个a 索引1
var res=str.indexOf('a',1 )
console.log(res)
// 从左向右 第一个F 索引-1 不存在
console.log( str.indexOf('F',1) )
// 从右向左 第一个M 索引6
var res=str.lastIndexOf('M',8)
console.log(res)
</script>
</body>
</html>
12. concat() 和数组方法同名
+ 语法: 字符串.concat(字符串2, 字符串3)
+ 作用: 字符串拼接
+ 返回值: 拼接好的字符串
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<script>
var str = new String("MaXaaoMa")
console.log(str.concat(',--',1 ))
console.log(str.concat('/kk' ,'fd'))
console.log(str.concat('gg-',true ))
</script>
</body>
</html>
13. trim()
语法: 字符串.trim()
返回值: 去除了首尾空白内容以后的字符串
14. trimStart() / trimLeft()
字符串.trimStart()
字符串.trimLeft()
返回值: 去除了开头位置空白内容以后的字符串
15. trimEnd() / trimRight()
+ 语法:
字符串.trimEnd()
字符串.trimRight()
返回值: 去除了结束位置空白内容以后的字符串
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<script>
var str = new String(" MaX aao Ma ")
// 返回值: 去除了首尾空白内容以后的字符串
console.log(str.trim())
// trimStart() / trimLeft() 去除了开头位置空白内容以后的字符串
console.log(str.trimStart())
console.log(str.trimLeft())
// trimEnd() / trimRight() 去除了结束位置空白内容以后的字符串
console.log(str.trimEnd())
console.log(str.trimRight())
</script>
</body>
</html>
字符串的几种常用分类格式
普通字符串 'dsfasdfugsdfhkg'
数字字符串 '1234567890'
html字符串 '<p>文本内容</p>'
查询字符串 'key=value&key2=value2'
json字符串 '{ "name": "Jack", "age": 18 }' 交互使用 轻量级 键和值全部使用" "进行包含
json 格式字符串的操作
JS 的数据结构转换成 json 格式字符串
语法: JSON.stringify( JS 的对象或者数组 )
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<script>
// JSON.stringify( JS 的对象或者数组 )
var str=('qwe1234---')
console.log(typeof (str),str)
var str2=JSON.stringify( str)
console.log(typeof (str2),str2)
var arr={name:'jack',age:'18'}
console.log(typeof (arr),arr)
var arr2=JSON.stringify( arr)
console.log(typeof (arr2),arr2)
</script>
</body>
</html>
json 格式字符串转换成 JS 的数据结构
JSON.parse( json 格式字符串 )