字符串的基础

字符串的创建(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 格式字符串 )

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码小目

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值