JavaScript基础三、数据类型

news2025/1/10 16:06:12

零、文章目录

文章地址

  • 个人博客-CSDN地址:https://blog.csdn.net/liyou123456789
  • 个人博客-GiteePages:https://bluecusliyou.gitee.io/techlearn

代码仓库地址

  • Gitee:https://gitee.com/bluecusliyou/TechLearn
  • Github:https://github.com/bluecusliyou/TechLearn

JavaScript基础三、数据类型

1、概念和作用

(1)数据分类

  • 计算机世界中的万事万物都是数据。
  • 计算机程序可以处理大量的数据,为什么要给数据分类?
    • 更加充分和高效的利用内存
    • 也更加方便程序员的使用数据

(2)JS 数据分为两大类

  • 基本数据类型:又叫做简单数据类型或者值类型,在存储时变量中存储的是值本身,因此叫做值类型。string ,number,boolean,undefined,null
  • 引用数据类型:又叫做复杂数据类型,在存储时变量中存储的仅仅是地址(引用),因此叫做引用数据类型。通过 new 关键字创建的对象(系统对象、自定义对象),如 Object、Array、Date等。

image-20230226215707159

2、基本数据类型

(1)数字类型(Number)

  • 即我们数学中学习到的数字,可以是整数、小数、正数、负数。

  • JavaScript 中的正数、负数、小数等 统一称为 数字类型。

  • 注意事项

    • JS 是弱数据类型,变量到底属于那种类型,只有赋值之后,我们才能确认
    • Java是强数据类型 例如 int a = 3 必须是整数
  • 数字可以有很多操作,经常和算术运算符一起。算术运算符主要包括:

    • +:求和
    • -:求差
    • *:求积
    • /:求商
    • %:取模(取余数),开发中经常作为某个数字是否被整除
  • 同时使用多个运算符编写程序时,会按着某种顺序先后执行,我们称为优先级。JavaScript中 优先级越高越先被执行,优先级相同时从左向右执行

    • 乘、除、取余优先级相同

    • 加、减优先级相同

    • 乘、除、取余优先级大于加、减

    • 使用 () 可以提升优先级

    • 总结: 先乘除后加减,有括号先算括号里面的

  • NaN 代表一个计算错误。它是一个不正确的或者一个未定义的数学操作所得到的结果,NaN 是粘性的。任何对 NaN 的操作都会返回 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>基本数据类型-数字型</title>
</head>

<body>
    <script>
        // js 弱数据类型的语言 只有当我们赋值了,才知道是什么数据类型
        // let num = 'pink'
        // let num = 10.11
        // console.log(num)
        // java 强数据类型的语言    int num = 10
        console.log(1 + 1) // 2
        console.log(1 * 1) // 1
        console.log(1 / 1) // 1
        console.log(4 % 2) // 0
        console.log(5 % 3) // 2 
        console.log(3 % 5) // 3 

        //错误的计算返回NaN
        console.log('pink老师' - 2) //NaN
        console.log(NaN - 2) //NaN
        console.log(NaN + 2) //NaN
        console.log(NaN / 2) //NaN
        console.log(NaN === NaN) //false
    </script>
</body>

</html>

计算圆面积案例:

image-20230228131914730

<!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>计算圆的面积</title>
</head>

<body>
    <script>
        // 1. 页面弹出输入框
        let r = prompt('请输入圆的半径:')
            // 2. 计算圆的面积(内部处理)
        let re = 3.14 * r * r
            // 3. 页面输出
        document.write(re)
    </script>
</body>

</html>

(2)字符串类型(string)

  • 字符串:通过单引号(‘’) 、双引号(“”)或反引号(``) 包裹的数据都叫字符串,推荐使用单引号。

  • 字符串嵌套:单引号/双引号可以互相嵌套,但是不以自已嵌套自已(口诀:外双内单,或者外单内双)

  • 字符串转义:必要时可以使用转义符 \,输出单引号或双引号

  • 字符串拼接:+运算符可以实现字符串的拼接。(口诀:数字相加,字符相连)

  • 操作字符串:获取字符串字符可以用str[下标],下标索引从0开始,字符串是不可变的,如果对字符串的某个索引赋值,不会有任何错误,也没有任何效果。

  • 字符串转大小写:str.toUpperCase、str.toLowerCase

  • 获取字符串的索引位置:str1.indexOf(str2),找出str2在str1中的位置

  • 截取字符串:str.substring(start,end)start开始end结束,不包含end、str.substring(start)start开始到结束。

案例如下:

<!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>字符串类型</title>
</head>

<body>
    <script>
        // 字符串
        let uname = '小明' //使用单引号
        let gender = "男" //使用双引号
        let goods = `小米` //使用反引号
        let tel = '13681113456' //看上去是数字,但是引号包裹了就是字符事
        let str = '' //这种情况叫空字符串

        //字符串嵌套
        console.log('pink老师讲课非常有"基情"')
        console.log("pink老师讲课非常有'基情'")
        console.log('pink老师讲课非常有\'基情\'')

        // 字符串拼接
        // console.log(1 + 1)//2
        // console.log('pink' + '老师')//pink老师

        let age = 25
            // document.write('我今年' + 19)
            // document.write('我今年' + age)
        document.write('我今年' + age + '岁了')

        //获取字符串字符
        let s = 'Hello, world!'
        console.log(s[0]) // 'H'
        console.log(s[6]) // ' '
        console.log(s[7]) // 'w'
        console.log(s[12]) // '!'
        console.log(s[13]) // undefined 超出范围的索引不会报错,但一律返回undefined

        //字符串是不可变的,如果对字符串的某个索引赋值,不会有任何错误,但是,也没有任何效果
        let s1 = 'Test'
        s1[0] = 'X'
        console.log(s1) // s仍然为'Test'

        //把一个字符串全部变为大写
        let s2 = 'Hello'
        console.log(s2.toUpperCase()) // 返回'HELLO'

        //把一个字符串全部变为小写
        let s3 = 'Hello'
        console.log(s3.toLowerCase()) // 返回'hello'

        //搜索指定字符串出现的位置
        let s4 = 'hello, world'
        console.log(s4.indexOf('world')) // 返回7
        console.log(s4.indexOf('World')) // 没有找到指定的子串,返回-1

        let s5 = 'hello, world'
        console.log(s5.substring(0, 5)) // 从索引0开始到5(不包括5),返回'hello'
        console.log(s5.substring(7)) // 从索引7开始到结束,返回'world'
    </script>
</body>

</html>
  • 模板字符串
    • **场景:**用于拼接字符串和变量

    • **语法:**外面用`` 里面 ${变量名}

案例如下:

image-20230228133056087

<!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>模板字符串</title>
</head>

<body>
    <script>
        // let age = 20
        // 模板字符串 外面用`` 里面 ${变量名}
        // document.write(`我今年${age}岁了`)
        
        //输入
        let uname = prompt('请输入您的姓名:')
        let age = prompt('请输入您的年龄:')
        // 输出
        document.write(`大家好,我叫${uname}, 今年${age}岁了`)
    </script>
</body>

</html>

(3)布尔类型(boolean)

  • 表示肯定或否定时在计算机中对应的是布尔类型数据。
  • 它有两个固定的值 true 和 false,表示肯定的数据用 true(真),表示否定的数据用 false(假)。

(4)未定义类型(undefined)

  • 未定义是比较特殊的类型,只有一个值 undefined

  • 只声明变量,不赋值,变量的值为 undefined

  • **使用场景:**我们开发中经常声明一个变量,等待传送过来的数据。我们可以通过检测这个变量是不是undefined,就判断用户是否有数据传递过来。

(5)null(空类型)

  • JavaScript 中的 null 仅仅是一个代表“无”、“空”或“值未知”的特殊值。

  • 把 null 作为尚未创建的对象。

  • **使用场景:**将来有个变量里面存放的是一个对象,但是对象还没创建好,可以先给个null。

  • null 和 undefined 区别:

    • undefined 表示没有赋值
    • null 表示赋值了,但是内容为空

案例如下:

<!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>其他三种类型</title>
</head>

<body>
    <script>
        // 1. true  false 是布尔型字面量  
        console.log(3 > 4)
        let isCool = false
        console.log(isCool)

        // 2. 未定义类型 弱数据类型 声明一个变量未赋值就是 undefined
        let num
        console.log(num)

        // 3. null 空的
        let obj = null
        console.log(obj)

        // undefined null 计算有区别
        console.log(undefined + 1) // NaN
        console.log(null + 1) // 1
    </script>
</body>

</html>

3、引用数据类型-对象

(1)对象是什么

  • 对象(object):JavaScript里的一种数据类型
  • 可以理解为是一种无序的数据集合, 注意数组是有序的数据集合
  • 用来详细的描述某个事物,比如人信息:
    • 如果用多个变量保存则比较散,用对象比较统一
    • 静态特征 (姓名, 年龄, 身高, 性别, 爱好) => 可以使用数字, 字符串, 数组, 布尔类型等表示
    • 动态行为 (点名, 唱, 跳, rap) => 使用函数表示

(2)对象使用

  • 对象声明:实际开发中,我们多用花括号。 {} 是对象字面量

image-20230301213612725

  • 对象组成

    • 属性:信息或叫特征(名词)。 比如 手机尺寸、颜色、重量等…

    • 方法:功能或叫行为(动词)。 比如 手机打电话、发短信、玩游戏…

image-20230301213724025

  • 对象属性

    • 属性都是成 对出现的,包括属性名和值,它们之间使用英文 : 分隔

    • 多个属性方法之间使用英文 , 分隔

    • 属性就是依附在对象上的变量(外面是变量,对象内是属性)

    • 属性名可以使用 “” 或 ‘’,一般情况下省略,除非名称遇到特殊符号如空格、中横线等

    • 判断属性或者方法是否在对象中,使用in,继承的方法或者属性也算,如果要判断一个属性是否是 对象自身拥有的,而不是继承得到的,可以用 hasOwnProperty() 方法

image-20230301213934320

  • 对象本质是无序的数据集合, 操作数据无非就是 增 删 改 查 语法:
    • 属性-查:对象名.属性或者对象名[‘属性’](多词属性或 - 等属性,点操作就不能用了)
    • 属性-改:对象名.属性 = 新值
    • 属性-增:对象名.新属性 = 新值
    • 属性-删 (了解):delete 对象名.属性
    • 语法一样,判断标准就是对象有没有这个属性,没有就是新增,有就是改

image-20230301221933207

案例如下:

<!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>对象的使用</title>
</head>

<body>
    <script>
        // 1.声明对象
        let pink = {
            uname: 'pink老师',
            age: 18,
            gender: '女'
        }
        console.log(pink.uname)
        console.log(typeof pink)

        // 改
        pink.gender = '男'
        console.log(pink)

        // 增
        pink.hobby = '足球'
        console.log(pink)

        // 删 (了解)
        delete pink.age
        console.log(pink)

        // 声明对象
        let obj = {
                'goods-name': '小米10青春版',
                num: '100012816024',
                weight: '0.55kg',
                address: '中国大陆'
            }
            //多词属性或 - 等属性,点操作就不能用了
            //console.log(obj.goods - name)
            //可以用查的另外一种方式,对象名['属性名']
        console.log(obj['goods-name'])

        //要检测对象是否拥有某一属性
        let xiaoming = {
            name: '小明',
            birth: 1990,
            school: 'No.1 Middle School',
            height: 1.70,
            weight: 65,
            score: null
        }
        console.log('name' in xiaoming) // true
        console.log('grade' in xiaoming) // false

        //object继承到的方法也存在
        console.log('toString' in xiaoming) // true

        //判断是否是自身拥有的属性或者方法
        console.log(xiaoming.hasOwnProperty('name')) // true
        console.log(xiaoming.hasOwnProperty('toString')) // false
    </script>
</body>

</html>
  • 对象方法

    • 方法是由方法名和函数两部分构成,它们之间使用 : 分隔

    • 多个属性方法之间使用英文 , 分隔

    • 方法是依附在对象中的函数

    • 方法名可以使用 “” 或 ‘’,一般情况下省略,除非名称遇到特殊符号如空格、中横线等

image-20230302154758402

  • 对象方法调用:可以使用 . 调用对象中函数,我称之为方法调用。

image-20230302154948287

案例如下:

<!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>对象的方法</title>
</head>

<body>
  <script>
    let obj = {
      uname: '刘德华',
      // 方法
      song: function (x, y) {
        console.log(x + y)
      },
      dance: function () { }
    }
    // 方法调用 对象名.方法名
    obj.song(1, 2)
  </script>
</body>

</html>

(4)内置对象-Math

  • 内置对象:JavaScript内部提供的对象,包含各种属性和方法给开发者调用

  • Math对象:JavaScript提供的一个“数学”对象,提供了一系列做数学运算的方法

    • random:生成0-1之间的随机数(包含0不包括1)
    • ceil:向上取整
    • floor:向下取整
    • max:找最大数
    • min:找最小数
    • pow:幂运算
    • abs:绝对值

案例如下:

<!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>内置对象Math</title>
</head>

<body>
    <script>
        // 属性
        console.log(Math.PI)
            // 方法
            // ceil 天花板  向上取整
        console.log(Math.ceil(1.1)) // 2 
        console.log(Math.ceil(1.5)) // 2 
        console.log(Math.ceil(1.9)) // 2 
            // floor 地板  向下取整
        console.log(Math.floor(1.1)) // 1
        console.log(Math.floor(1.5)) // 1
        console.log(Math.floor(1.9)) // 1
        console.log(Math.floor('12px')) // NaN
            // 四舍五入 round
        console.log(Math.round(1.1)) // 1
        console.log(Math.round(1.49)) // 1
        console.log(Math.round(1.5)) // 2
        console.log(Math.round(1.9)) // 2
        console.log(Math.round(-1.1)) // -1 
        console.log(Math.round(-1.5)) // -1
        console.log(Math.round(-1.51)) // -2

        //最大值
        console.log(Math.max(1, 2, 3, 4, 5)) //5
            //最小值
        console.log(Math.min(1, 2, 3, 4, 5)) //1

        //绝对值
        console.log(Math.abs(-1)) //1
    </script>
</body>

</html>
  • Math.random() :随机数函数, 返回一个0 - 1之间,并且包括0不包括1的随机小数 [0, 1)
    • 生成0-10的随机数:Math.floor(Math.random() * (10 + 1))

    • 生成5-10的随机数:Math.floor(Math.random() * (5 + 1)) + 5

    • 生成N-M之间的随机数:Math.floor(Math.random() * (M - N + 1)) + N

案例如下:

<!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>随机数函数</title>
</head>

<body>
  <script>
    // 左闭右开 取到0~1中间一个随机小数[0,1)
    console.log(Math.random())

    // 0~ 10 之间的整数
    console.log(Math.floor(Math.random() * 11))
    
    //随机取数组元素
    let arr = ['red', 'green', 'blue']
    let random = Math.floor(Math.random() * arr.length)
    console.log(arr[random])
    
    // 取到 N ~ M 的随机整数
    function getRandom(N, M) {
      return Math.floor(Math.random() * (M - N + 1)) + N
    }
    console.log(getRandom(4, 8))
  </script>
</body>

</html>

随机点名:

image-20230302191526412

<!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>随机点名</title>
</head>

<body>
  <script>
    let arr = ['赵云', '黄忠', '关羽', '张飞', '马超', '刘备', '曹操']
    // 1. 得到一个随机数, 作为数组的索引号, 这个随机数 0~6
    let random = Math.floor(Math.random() * arr.length)
    // 2. 页面输出数组里面的元素 
    document.write(arr[random])
    // 3. splice(起始位置(下标), 删除几个元素)
    arr.splice(random, 1)
    console.log(arr)
  </script>
</body>

</html>

(5)内置对象-Date

  • Date 对象用来表示日期和时间。
  • 注意:当前时间是浏览器从本机操作系统获取的时间,所以不一定准确,因为用户可以把当前时间设定为任何值。
  • Date 对象表示的时间总是按浏览器所在时区显示的,不过我们既可以显示本地时间,也可以显示调整后的UTC时间。
  • 时间戳:时间戳是一个自增的整数,它表示从1970年1月1日零时整的GMT时区开始的那一刻,到现在的毫秒数。假设浏览器所在电脑的时间是准确的,那么世界上无论哪个时区的电脑,它们此刻产生的时间戳数字都是一样的,所以,时间戳可以精确地表示一个时刻,并且与时区无关。getTime()可以获取当前时间的时间戳。只要我们传递的是一个 number 类型的时间戳,我们就不用关心时区转换。任何浏览器都可以把一个时间戳正确转换为本地时间。

案例如下:

<!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>内置对象Date</title>
</head>

<body>
    <script>
        let now = new Date()
        console.log(now) // Wed Jun 24 2015 19:49:22 GMT+0800 (CST)
        console.log(now.getFullYear()) // 2023, 年份
        console.log(now.getMonth()) // 2, 3月份,注意月份范围是0~11,5表示六月
        console.log(now.getDate()) // 6, 表示6号
        console.log(now.getDay()) // 1, 表示星期一
        console.log(now.getHours()) // 13, 24小时制
        console.log(now.getMinutes()) // 31, 分钟
        console.log(now.getSeconds()) // 8, 秒
        console.log(now.getMilliseconds()) // 414, 毫秒数
        console.log(now.getTime()) // 1678080668414, 以number形式表示的时间戳

        //UTC时间,传入时间戳
        let d = new Date(1678080668414)
        console.log(d.toLocaleString()) //2023/3/6 13:31:08,显示的字符串与操作系统设定的格式有关
        console.log(d.toUTCString()) // Mon, 06 Mar 2023 05:31:08 GMT,UTC时间,与本地时间相差8小时
    </script>
</body>

</html>

(5)内置对象-JSON

  • JSON(JavaScript Object Notation, JS 对象标记) 是一种轻量级的数据交换格式,目前使用特别广泛。

  • 采用完全独立于编程语言的文本格式来存储和表示数据。

  • 简洁和清晰的层次结构,易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。

  • 在 JavaScript 语言中,一切都是对象。因此,任何JavaScript 支持的类型都可以通过 JSON 来表示,例如字符串、数字、对象、数组等。JSON 是 JavaScript 对象的字符串表示法,它使用文本表示一个 JS 对象的信息,本质是一个字符串

  • JSON和JavaScript对象互转:

    • JSON字符串转换为JavaScript 对象:JSON.parse()
    • JavaScript 对象转换为JSON字符串:JSON.stringify()

案例如下:

<!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>内置对象JSON</title>
</head>

<body>
    <script>
        //编写一个js的对象
        let user = {
            name: "张三",
            age: 17,
            sex: "男"
        };
        //将js对象转换成json字符串
        var str = JSON.stringify(user)
        console.log(str)//{"name":"张三","age":17,"sex":"男"}

        //将json字符串转换为js对象
        var user2 = JSON.parse(str)
        console.log(user2.age, user2.name, user2.sex)//17 '张三' '男'
    </script>
</body>

</html>

4、数据内存分配

(1)堆栈空间分配区别

  • 栈(操作系统):由操作系统自动分配释放存放函数的参数值、局部变量的值等。其操作方式类似于数据结构中的栈;简单数据类型存放到栈里面
  • 堆(操作系统):存储复杂类型(对象),一般由程序员分配释放,若程序员不释放,由垃圾回收机制回收。引用数据类型存放到堆里面

image-20230303094829640

(2)简单类型的内存分配

  • 值类型(简单数据类型): string ,number,boolean,undefined,null
  • 值类型变量的数据直接存放在变量(栈空间)中

image-20230303095002362

(3)复杂类型的内存分配

  • 引用类型(复杂数据类型):通过 new 关键字创建的对象(系统对象、自定义对象),如 Object、Array、Date等
  • 引用类型变量(栈空间)里存放的是地址,真正的对象实例存放在堆空间中

image-20230303095048067

(4)案例

<!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>数据类型存储</title>
</head>

<body>
  <script>
    let num1 = 10
    let num2 = num1
    num2 = 20
    console.log(num1) //10 值类型不变

    let obj1 = {
      age: 18
    }
    let obj2 = obj1
    // 修改属性
    obj2.age = 20
    console.log(obj1.age)//20 引用类型属性被修改
  </script>
</body>

</html>

5、数据类型检测

(1)控制台输出颜色

  • 控制台语句经常用于测试结果来使用。
  • 可以看出数字型和布尔型颜色为蓝色,字符串和undefined颜色为灰色

image-20230228141135151

(2) 通过 typeof关键字

  • typeof 运算符可以返回被检测的数据类型。它支持两种语法形式:

    • 作为运算符: typeof x (常用的写法)
    • 函数形式: typeof(x)
  • 换言之,有括号和没有括号,得到的结果是一样的,所以我们直接使用运算符的写法更简单。

案例如下:

<!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>检测数据类型</title>
</head>

<body>
    <script>
        let num = 10
        console.log(typeof num) //number
        let str = 'pink'
        console.log(typeof str) //string
        let str1 = '10'
        console.log(typeof str1) //string
        let flag = false
        console.log(typeof flag) //boolean
        let un
        console.log(typeof un) //undefined
        let obj = null
        console.log(typeof obj) //object
    </script>
</body>

</html>

6、数据类型转换

(1)类型转换作用

  • JavaScript是弱数据类型,JavaScript也不知道变量到底属于那种数据类型,只有赋值了才清楚。
  • 使用表单、prompt获取过来的数据默认是字符串类型的,此时就不能直接简单的进行加法运算。
  • 此时需要转换变量的数据类型,通俗来说,就是把一种数据类型的变量转换成我们需要的数据类型

(2)隐式转换

  • 某些运算符被执行时,系统内部自动将数据类型进行转换,这种转换称为隐式转换。

  • 规则:

    • + 号两边只要有一个是字符串,都会把另外一个转成字符串
    • 除了+以外的算术运算符 比如 - * / 等都会把数据转成数字类型
    • null 经过数字转换之后会变为 0
    • undefined 经过数字转换之后会变为 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>隐式转换</title>
</head>

<body>
    <script>
        console.log(11 + 11) //22
        console.log('11' + 11) //1111
        console.log(11 - 11) //0
        console.log('11' - 11) //0
        console.log(1 * 1) //1
        console.log('1' * 1) //1
        console.log(typeof '123') //string
        console.log(typeof + '123') //number
        console.log(+'11' + 11) //22
        console.log(null + 1) //1
        console.log(undefined + 1) //NaN
        console.log(NaN + 1) //NaN
    </script>
</body>

</html>

求和案例:

<!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>求和案例</title>
</head>

<body>
    <script>
        // 1. 用户输入   prompt 得到是字符串类型 隐士转换为 数字型
        let num1 = +prompt('请输入第一个数字:')
        let num2 = +prompt('请输入第二个数字:')
        // 2. 输出
        alert(`两个数相加的和是:${num1 + num2}`)
    </script>
</body>

</html>

(3)显式转换

  • 为了避免因隐式转换带来的问题,通常根逻辑需要对数据进行显示转换。

  • 转换为数字型

    • Number(数据):如果数据内容里有非数字,转换失败时结果为 NaN(Not a Number)即不是一个数字,NaN也是number类型的数据,代表非数字。

    • parseInt(数据):只保留整数。

    • parseFloat(数据):可以保留小数。

  • 转换为字符型

    • String(数据)
    • 变量.toString(进制)
  • 转换为布尔型

    • Boolean(内容)

    • ''、0、undefined、null、false、NaN 转换为布尔值后都是false, 其余则为 true

案例如下:

<!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>显示转换</title>
</head>

<body>
    <script>
        let str = '123'
        console.log(Number(str)) //123
        console.log(Number('pink')) //NaN

        console.log(parseInt('12px')) //12
        console.log(parseInt('12.34px')) //12
        console.log(parseInt('12.94px')) //12
        console.log(parseInt('abc12.94px')) //NaN

        console.log(parseFloat('12px')) //12
        console.log(parseFloat('12.34px')) //12.34
        console.log(parseFloat('12.94px')) //12.94
        console.log(parseFloat('abc12.94px')) //NaN
    </script>
</body>

</html>

转换为布尔型:

<!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>转换为布尔型</title>
</head>

<body>
    <script>
        console.log(Boolean('pink')) //true
        console.log(Boolean('')) //false
        console.log(Boolean(0)) //false
        console.log(Boolean(90)) //true
        console.log(Boolean(-1)) //true
        console.log(Boolean(undefined)) //false
        console.log(Boolean(null)) //false
        console.log(Boolean(NaN)) //false
    </script>
</body>

</html>

(4)常见错误

image-20230228150418427

分析:

  • 因为prompt 获取过来的是字符型,所以会出现字符相加的问题
  • prompt 如果出现相加记得要转为数字型,可以 利用 + 最简单

image-20230228150529349

7、综合案例

image-20230228145034168

代码如下:

<!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>综合案例</title>
    <style>
        h2 {
            text-align: center;
        }
        
        table {
            /* 合并相邻边框 */
            border-collapse: collapse;
            height: 80px;
            margin: 0 auto;
            text-align: center;
        }
        
        th {
            padding: 5px 30px;
        }
        
        table,
        th,
        td {
            border: 1px solid #000;
        }
    </style>
</head>

<body>
    <h2>订单确认</h2>
    <script>
        // 1 用户输入
        let price = +prompt('请输入商品价格:')
        let num = +prompt('请输入商品数量:')
        let address = prompt('请输入收获地址:')
        // 2.计算总额
        let total = price * num
        // 3.页面打印渲染 模板字符串
        document.write(`
      <table>
          <tr>
            <th>商品名称</th>
            <th>商品价格</th>
            <th>商品数量</th>
            <th>总价</th>
            <th>收货地址</th>
          </tr>
          <tr>
            <td>小米青春版PLUS</td>
            <td>${price}元</td>
            <td>${num}</td>
            <td>${total}元</td>
            <td>${address}</td>
          </tr>
        </table>
    `)
    </script>
</body>

</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/391489.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

nest.js学习笔记(一)

nest.js学习笔记&#xff08;一&#xff09;一、安装nest.js前置条件运行项目目录介绍二、nest.js cli 常用命令三、RESTful 风格设计1.接口url2.RESTful 版本控制四、获取前端传过来的参数1.获取Get请求参数2.获取Post请求参数3.动态路由4.获取Header信息5.自定义状态码nest.j…

Kotlin lateinit 和 lazy 之间的区别 (翻译)

Kotlin 中的属性是使用var或val关键字声明的。Late init 和 lazy 都是用来初始化以后要用到的属性。 由于这两个关键字都用于声明稍后将要使用的属性&#xff0c;因此让我们看一下它们以及它们的区别。 Late Init 在下面的示例中&#xff0c;我们有一个变量 myClass&#xff0…

【前缀和】截断数组、K倍区间、激光炸弹

Halo&#xff0c;这里是Ppeua。平时主要更新C语言&#xff0c;C&#xff0c;数据结构算法......感兴趣就关注我吧&#xff01;你定不会失望。 &#x1f308;个人主页&#xff1a;主页链接 &#x1f308;算法专栏&#xff1a;专栏链接 我会一直往里填充内容哒&#xff01; &…

小目标识别——基于K近邻的白酒杂质检测算法实现

文章目录实现思路配置opencv位置剪裁实现代码自适应中值滤波实现代码动态范围增强实现代码形态学处理实现代码图片预处理效果计算帧差连续帧帧差法原理和实现代码实现代码K近邻实现基本介绍实现过程参考实现思路 使用C进行实现&#xff0c;开发平台是clion&#xff0c;并没有使…

zencart/opencart/wordpress外贸独立站最少需要多少钱

以程序员的职位进入跨境电商行业已经有10年了&#xff0c;接触过不少大大小小的老板客户&#xff0c;我遇到最多的问题就是搭建一个站要多少钱&#xff1f;实话说这问题问的有些粗糙。如果我遇到不负责的公司他可能会直接报价1W&#xff0c;2W或更多&#xff0c;也有可能遇到兼…

【STM32MP157应用编程】3.控制PWM

目录 PWM文件 指令操作PWM 程序操作PWM 程序说明 程序代码 3_PWM_1.c 启动交叉编译工具 编译 拷贝到开发板 测试 PWM文件 在/sys/class/pwm目录下&#xff0c;存放了PWM的文件。 pwmchip0和pwmchip4目录对应了MP157 SoC的2个PWM控制器&#xff0c;pwmchip0对应的是M…

【Python】torch.norm()用法解析

【Python】torch.norm()用法解析 文章目录【Python】torch.norm()用法解析1. 介绍1.1 p-范数1.2 Frobenius 范数1.3 核范数2. API3. 示例1. 介绍 torch.norm()是对输入的tensor求对应的范数。tensor的范数有以下三种&#xff1a; 1.1 p-范数 1.2 Frobenius 范数 即&#xff…

Linux-GCC介绍+入门级Makefile使用

前言&#xff08;1&#xff09;我们都知道&#xff0c;在Linux中编译.c文件需要使用gcc -o .c文件的指令来将C文件变成可执行文件。但是我们有没有发现&#xff0c;如果我们需要编译大一点的工程&#xff0c;后面需要加上的.c文件是不是太多了&#xff1f;感觉非常的麻烦。&…

linux篇【16】:传输层协议<后序>

目录 六.滑动窗口 &#xff08;1&#xff09;发送缓冲区结构 &#xff08;2&#xff09;滑动窗口介绍 &#xff08;3&#xff09;滑动窗口不一定只会向右移动。滑动窗口可以变大也可以变小。 &#xff08;4&#xff09;那么如果出现了丢包, 如何进行重传? 这里分两种情况…

「微报告」激光雷达前装“成色”

激光雷达正处于第一波规模上车期。 高工智能汽车研究院监测数据显示&#xff0c;2022年中国市场&#xff08;不含进出口&#xff09;乘用车前装标配搭载激光雷达12.99万台&#xff0c;配套车辆11.18万辆&#xff0c;同比分别增长1544.30%和2626.82%。此外&#xff0c;提供选装的…

华为OD机试题,用 Java 解【相对开音节】问题

华为Od必看系列 华为OD机试 全流程解析+经验分享,题型分享,防作弊指南)华为od机试,独家整理 已参加机试人员的实战技巧华为od 2023 | 什么是华为od,od 薪资待遇,od机试题清单华为OD机试真题大全,用 Python 解华为机试题 | 机试宝典使用说明 参加华为od机试,一定要注意不…

基于BERT-PGN模型的中文新闻文本自动摘要生成——文本摘要生成(论文研读)

基于BERT-PGN模型的中文新闻文本自动摘要生成&#xff08;2020.07.08&#xff09; 基于BERT-PGN模型的中文新闻文本自动摘要生成&#xff08;2020.07.08&#xff09;摘要&#xff1a;0 引言相关研究2 BERT-PGN模型2. 1 基于预训练模型及多维语义特征的词向量获取阶段2. 1. 1 BE…

Python3-数据结构

Python3 数据结构 本章节我们主要结合前面所学的知识点来介绍Python数据结构。 列表 Python中列表是可变的&#xff0c;这是它区别于字符串和元组的最重要的特点&#xff0c;一句话概括即&#xff1a;列表可以修改&#xff0c;而字符串和元组不能。 以下是 Python 中列表的…

3.3 GPIO输入

按键1.1 按键介绍•按键&#xff1a;常见的输入设备&#xff0c;按下导通&#xff0c;松手断开•按键抖动&#xff1a;由于按键内部使用的是机械式弹簧片来进行通断的&#xff0c;所以在按下和松手的瞬间会伴随有一连串的抖动1.2 按键的四种接法P1是最常用的接法&#xff0c;p1…

【小程序】django学习笔记1

网页能用&#xff0c;不知道小程序能不能用。应该能吧。。。。。创建django程序文件包&#xff0c;xxx处是给该文件夹起个名django-admin startproject xxx一个project是由很多个app&#xff08;小应用&#xff09;组成的在文件夹目录下创建一个app&#xff0c;xxx处给该app起个…

脑雾到来的6个症状

在阳康后的一段时间里&#xff0c;很多人发现自己脑力不似从前&#xff0c;长时间的修养也没能彻底恢复&#xff0c;以为自己有后遗症&#xff0c;十分紧张。其实&#xff0c;脑雾不是专业的医学名词&#xff0c;它是对一类症状的统称&#xff1a;健忘、注意力不集中、思维迟钝…

第17天-整合Redis缓存改造三级分类,并解决缓存击穿、穿透、雪崩、一致性问题

1.缓存 1.1.缓存使用 为了系统性能的提升&#xff0c;一般都会将部分数据放入缓存中&#xff0c;达到快速响应的目的。而数据库承担数据落盘工作。 哪些数据适合放入缓存&#xff1f; 即时性、数据一致性要求不高的访问量大且更新频率不高的数据&#xff08;读多&#xff0c…

布隆过滤器Bloom -> Redisson系列-3

接上文&#xff1a;RBucket对象桶 -&#xff1e; Redisson系列-1&#xff08;让redis操作更优雅&#xff09;_子书少卿的博客-CSDN博客 本质上布隆过滤器是一种数据结构&#xff0c;是一种比较巧妙的概率性数据结构&#xff0c;特点是可以高效的插入和查询&#xff0c;可…

浅谈一下虚拟机栈

虚拟机栈 概述 由于跨平台性的设计&#xff0c;Java的指令都是根据栈来设计的。不同平台CPU架构不同&#xff0c;所以不能设计为基于寄存器的。 优点是跨平台&#xff0c;指令集小&#xff0c;编译器容易实现&#xff0c;缺点是性能下降&#xff0c;实现同样的功能需要更多的…

SpringBoot学习笔记(二)配置文件

1、配置文件SpringBoot使用一个全局的配置文件&#xff0c;配置文件名是固定的&#xff1b;application.propertiesapplication.yml配置文件的作用&#xff1a;修改SpringBoot自动配置的默认值&#xff1b;SpringBoot在底层都给我们自动配置好&#xff1b;YAML&#xff1a;以数…