一.JS基础 013-014 字符串and数字 (P55-P62)

113 阅读7分钟

13 字符串

13-1 创建字符串

  • 我们创建字符串也分为两种方法 字面量构造函数

  • 字面量:

    var str = 'hello'
    
  • 构造函数创建

    var str = new String('hello')
    
  • 基本操作

        var str1 = "hello"

        console.log(str1+" world")

        var str2 = new String("hello")
        console.log(str2+ " world")

        //length 只读
        str1.length = 0
        console.log(str1)

        //索引/下标 只读
        console.log(str1[1])
        str1[1] = "a"
        console.log(str1)

        // 遍历

        for(var i=0;i<str1.length;i++){
            console.log(i,str1[i])
        }

        var str = str1
        str1 = "aaaa"
        console.log(str,str1)
  • 案例————统计字符出现次数
        var str = "abcabcab"

        /*a是3个,b是3个,c是2
          [a,3,b,3,c,2]
          {a:3,b:3,c:2}
        */
        var obj = {}
        for(var i=0;i<str.length;i++){
            console.log(str[i])
            var key = str[i]

            
            // if(obj[key] === undefined){
            //     obj[key] = 1  //undefined null 0都是假
            // }else{
            //     obj[key]++
            // }
            if(obj[key]){
                obj[key]++
            }else{
                obj[key] = 1
            }
        }

        console.log(obj)

13-2 字符集

ASCII 字符集

  • 我们都知道,计算机只能存储 0101010 这样的二进制数字
  • 那么我们的 a ~ z / A ~ Z / $ / @ /… 之类的内容也有由二进制数字组成的
  • 我们可以简单的理解为, a ~ z / A ~ Z / $ / @ /… 之类的内容都有一个自己的编号,然后在计算机存储的时候,是存储的这些编号,我们看的时候,也是通过这些编号在解析成我们要看到的内容给我们看到
  • ASCII显示字符.png
  • ASCII控制字符.png
  • 上面的就是 ASCII 对照表,我们只需要知道他是这么存储的就好

unicode 编码

  • 我们看到了,ASCII 只有这 128 个字符的编码结构
  • 但是因为 ASCII 出现的比较早,而且是美国发明的,早先时候这些内容就够用了
  • 因为存储一些英文的内容,传递一些英文的文章什么的都够用了
  • 那么对于这个世界来说肯定是不够用的
  • 因为我们的汉字没有办法存储,包括一些其他国家的语言也没有办法存储
  • 所以就出现了 unicode 编码,也叫(万国码,统一码)
  • unicode 对照表就是一个和 ASCII 一样的对照表,只不过变得很大很大,因为存储的内容特别的多
  • 而且包含了世界上大部分国家的文字,所以我们的文字和字符现在在存储的时候,都是按照 unicode 编码转换成数字进行存储
  • 我们的 UTF-8 就是一种 8 位的 unicode 字符集

13-3 字符串的常用方法

  • 我们操作字符串,也有一堆的方法来帮助我们操作
  • 字符串和数组有一个一样的地方,也是按照索引来排列的

charAt

  • charAt(索引) 是找到字符串中指定索引位置的内容返回

    var str = 'Jack'
    
    // 使用 charAt 找到字符串中的某一个内容
    var index = str.charAt(2)
    
    console.log(index) // c
    
    • 因为字符串也是按照索引进行排列的,也是同样从 0 开始
    • 所以索引 2 的位置就是 c
  • 如果没有对应的索引,那么就会返回 空字符串

    var str = 'Jack'
    
    // 使用 charAt 找到字符串中的某一个内容
    var index = str.charAt(10)
    
    console.log(index) // ''
    
    • 这个字符串根本没有索引 10 的位置
    • 所以就会返回一个空字符串 ''

charCodeAt

  • charCodeAt(索引) 就是返回对应索引位置的 unicode 编码

    var str = 'Jack'
    
    // 使用 charAt 找到字符串中的某一个内容
    var index = str.charCodeAt(0)
    
    console.log(index) // 74
    
    • 因为 Junicode 对照表里面存储的是 74,所以就会返回 74

indexOf

  • indexOf 就是按照字符找到对应的索引

    var str = 'Jack'
    
    // 使用 indexOf 找到对应的索引
    var index = str.indexOf('J')
    
    console.log(index) // 0
    
    • 因为字符 J 在字符串 Jack 中的索引位置是 0
    • 所以会返回 0

substring

  • substring 是用来截取字符串使用的

  • 语法: substring(从哪个索引开始,到哪个索引截止),包含开始索引,不包含结束索引

    var str = 'hello'
    //         01234
    
    // 使用 substring 截取字符串
    var newStr = str.substring(1, 3)
    
    console.log(newStr) // el
    
    • 从索引 1 开始,到索引 3 截止,包含前面的索引不包含后面的索引
    • 所以返回的是 el

substr

  • substr 也是用来截取字符串的

  • 语法:substr(从哪个索引开始,截取多少个)

    var str = 'hello'
    //         01234
    
    // 使用 substr 截取字符串
    var newStr = str.substr(1, 3)
    
    console.log(newStr) // ell
    
    • 这个方法和 substring 不一样的是,第二个参数是截取多少个
    • 从索引 1 开始,截取 3 个,所以得到的是 ell

toLowerCase 和 toUpperCase

  • 这两个方法分别使用用来给字符串转成 小写字母大写字母

    var str = hello
    
    // 使用 toUpperCase 转换成大写
    var upper = str.toUpperCase()
    
    console.log(upper) // HELLO
    
    // 使用 toLowerCase 转换成小写
    var lower = upper.toLowerCase()
    
    console.log(lower) // hello
    

replace 替换,只能替换第一个

        //replace 替换 - 正则表达式
        var str ="abdwadwa"
        var str1 = str.replace("a","*")
        console.log(str1)

split 分割,join

            //split 分割  join
            var str = "a|b|c|d"

            console.log(str.split("|"))

            indexOf lastIndexOf

            var str = "abcda"
            console.log(str.indexOf("a",1))
            console.log(str.lastIndexOf("a",3))

indexOf lastIndexOf

            //indexOf lastIndexOf

            var str = "abcda"
            console.log(str.indexOf("a",1))
            console.log(str.lastIndexOf("a",3))

concat 同"+"一样

             //concat 连接字符串 +

            var str = "abcd"
            // var str1 = str.concat("ef")
            var str1 = str+"ef"
            console.log(str1)  // abcdef

trim 去掉首尾空格

            // trim 去掉首尾空格
            trimStart() trimLeft()去掉首空格
            trimEnd() trimRight()去掉尾空格
            
            // 中间空格不去
            var str = "  hello   world  "

            console.log("|"+str+"|")
            console.log("|"+str.trimRight()+"|")

案例————模糊查询

        var arr= ["aaa","abc","bcc","bcd","ddd","ccd"]

        // 数组的filter 字符的indexOf
        var input = prompt("请输入查询的内容")
        var res = arr.filter(function(item){
            return item.indexOf(input)>-1
        })

        console.log(res)

13-4 json字符串

       // split

        // json字符串==》对象
        // {"key":110,"key":"123"} // 格式严格

        var str = '{"name":"kerwin","age":100}'

        console.log(str)

        var obj = JSON.parse(str)
        console.log(obj)


        //前=》后
        var obj1 = {name:"tiechui"}

        var str1 = JSON.stringify(obj1)
        console.log(obj1,str1)

模板字符串

        //es6 - ``

        // var myhtml = '<li>11111</li>\
        // <li>2222</li>\
        // <li>3333</li>'
        var myhtml = `<li>11111</li>
        <li>2222</li>
        <li>3333</li>`

        var myname = "kerwin"
        var str = `my name is ${myname} ${10+20} ${10>20?'aaa':'bbb'}`
        // $ 不加引号"" 都可以支持了
        document.write(str)


         var arr =["xiaoming","kerwin","tiechui"]
        var arr2 = arr.map(function(item){
            return `<li>${item}</li>`
        })
        console.log(arr2)

        document.write(arr2.join(""))

14 数字处理————Math

  • Math 是 js 的一个内置对象,提供了一堆的方法帮助我们操作 数字

  • Number中toFixed的使用

    • sum.toFixed() 是将一个小数 四舍五入 保留几个小数位
  // Number toFixed() 返回是字符串

        var price = 123.45678   // 123.46
        // var price = 123.4    // 123.40

        var sum = price.toFixed(2)-0+100  
        //toFixed返回类型是字符串,要先减0变成数字
        console.log(sum.toFixed(2)) // 2是保留2位小数位的意思
  • 数学方法Math
14-1 random
  • Math.random() 这个方法是用来生成一个 0 ~ 1 之间的随机数

  • 每次执行生成的数字都不一样,但是一定是 0 ~ 1 之间的

  • 生成的数字包含 0 ,但是不包含 1

    var num = Math.random()
    console.log(num) // 得到一个随机数
    
14-2 round
  • Math.round() 是将一个小数 四舍五入 变成一个整数

    var num = 10.1
    console.log(Math.round(num)) // 10
    
    var num2 = 10.6
    console.log(Math.round(num2)) // 11
    
14-3 abs
  • Math.abs() 是返回一个数字的 绝对值

    var num = -10
    console.log(math.abs(num)) // 10
    
14-4 ceil
  • Math.ceil() 是将一个小数 向上取整 得到的整数

    var num = 10.1
    console.log(Math.ceil(num)) // 11
    
    var num2 = 10.9
    console.log(Math.ceil(num2)) // 11
    
14-5 floor
  • Math.floor() 是将一个小数 向下取整 的到的整数

    var num = 10.1
    console.log(Math.floor(num)) // 10
    
    var num2 = 10.9
    console.log(Math.floor(num2)) // 10
    
14-6 max
  • Math.max() 得到的是你传入的几个数字之中 最大 的那个数字

    console.log(Math.max(1, 2, 3, 4, 5)) // 5
    
14-7 min
  • Math.min() 得到的是你传入的几个数字之中 最小 的那个数字

    console.log(Math.min(1, 2, 3, 4, 5)) // 1
    
14-8 sqrt 平方根
  • sqrt是算术平方根,参数为负,输出NaN
       //sqrt 平方根 9

       console.log(Math.sqrt(8))
14-9 pow 底数,指数
       //pow(底数,指数)

       console.log(Math.pow(3,3)) //27 3的3次方

14-10 PI
  • Math.PI 得到的是 π 的值,也就是 3.1415936...

    console.log(Math.PI) // 3.141592653589793
    
    • 因为计算机的计算精度问题,只能得到小数点后 15 位
    • 使用 Math.PI 的时候,是不需要加 () 的
// Number toFixed() 返回是字符串

        var price = 123.45678
        // var price = 123.4

        var sum = price.toFixed(2)-0+100
        console.log(sum.toFixed(2))


        //Math对象

        //random //0-1- 随机整数
        console.log(Math.random())

        //round四舍五入取整
        console.log(Math.round(4.46))

        // ceil向上 floor向下

        console.log(Math.floor(4.96))


        //abs绝对值
        console.log(Math.abs(-10.2))


        //sqrt 平方根 9

        console.log(Math.sqrt(8))

        //pow(底数,指数)

        console.log(Math.pow(3,3))


        //max (多个参数)

        console.log(Math.max(10,50,20,34)) // 50

        //min (多个参数)
        console.log(Math.min(10,50,20,34)) // 10


        //PI
        console.log(Math.PI)

案例:随机整数

        // 0-10 不包含10
        var res = Math.floor(Math.random()*10)
        console.log(res)
        // 0-10 包含10
        var res = Math.floor(Math.random()*(10+1))
        console.log(res)
        // 10-20 不包含20
        var res = Math.floor(Math.random()*10)+10
        console.log(res)

        // 10-20 包含20
        var res = Math.floor(Math.random()*(10+1))+10
        console.log(res)


        //函数 --min-max 不包含

        function getRnd1(min,max) {
            if(min>max) {
                console.error("参数有误")
                return 
            }
            return Math.floor(Math.random()*(max-min))+min
        }        

        console.log(getRnd1(200,300))

         //函数 --min-max 包含

         function getRnd2(min,max) {
            if(min>max) {
                console.error("参数有误")
                return 
            }
            return Math.floor(Math.random()*(max-min+1))+min
        }  
        
        console.log(getRnd2(10,12))