• 16 JavaScript学习: 类型转换


    JavaScript 类型转换

    Number() 转换为数字, String() 转换为字符串, Boolean() 转换为布尔值。

    JavaScript 数据类型

    在 JavaScript 中有 6 种不同的数据类型:

    • string
    • number
    • boolean
    • object
    • function
    • symbol

    3 种对象类型:

    • Object
    • Date
    • Array

    2 个不包含任何值的数据类型:

    • null
    • undefined

    typeof 操作符

    typeof 操作符是 JavaScript 中的一种操作符,用于确定给定变量的数据类型。它返回一个表示该变量数据类型的字符串。这个操作符的语法是 typeof operand,其中 operand 是要检查类型的操作数。

    举个例子:

    typeof 42; // 返回 "number"
    typeof "hello"; // 返回 "string"
    typeof true; // 返回 "boolean"
    typeof { key: "value" }; // 返回 "object"
    typeof [1, 2, 3]; // 返回 "object"(数组也是对象)
    typeof undefined; // 返回 "undefined"
    typeof null; // 返回 "object"(这是 JavaScript 的一个历史遗留问题)
    typeof function() {}; // 返回 "function"
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    需要注意的是,typeof null 返回 “object” 是 JavaScript 中的一个历史遗留问题,并非一个准确的类型判断。

    将数字转换为字符串

    将数字转换为字符串可以使用 toString() 方法或者字符串模板。下面是示例代码:

    使用 toString() 方法:

    let number = 123;
    let str = number.toString();
    console.log(str); // 输出 "123"
    
    • 1
    • 2
    • 3

    使用字符串模板:

    let number = 456;
    let str = `${number}`;
    console.log(str); // 输出 "456"
    
    • 1
    • 2
    • 3

    这两种方法都可以将数字转换为字符串。

    将布尔值转换为字符串

    将布尔值转换为字符串可以使用 toString() 方法或者字符串模板。下面是示例代码:

    使用 toString() 方法:

    let bool = true;
    let str = bool.toString();
    console.log(str); // 输出 "true"
    
    • 1
    • 2
    • 3

    使用字符串模板:

    let bool = false;
    let str = `${bool}`;
    console.log(str); // 输出 "false"
    
    • 1
    • 2
    • 3

    这两种方法都可以将布尔值转换为字符串。

    将日期转换为字符串

    let date = new Date();
    let str = date.toString();
    console.log(str); // 输出当前日期和时间的字符串表示形式
    
    • 1
    • 2
    • 3

    将字符串转换为数字

    在JavaScript中,可以使用parseInt()或者parseFloat()函数将字符串转换为数字。

    1. 使用parseInt()函数将字符串转换为整数:
    let str = "42";
    let num = parseInt(str);
    console.log(num); // 输出 42
    
    • 1
    • 2
    • 3
    1. 使用parseFloat()函数将字符串转换为浮点数:
    let str = "3.14";
    let num = parseFloat(str);
    console.log(num); // 输出 3.14
    
    • 1
    • 2
    • 3

    另外,使用Number()函数也可以将字符串转换为数字:

    let str = "123";
    let num = Number(str);
    console.log(num); // 输出 123
    
    • 1
    • 2
    • 3

    需要注意的是,如果字符串无法完全转换为有效的数字,则结果将会是NaN(Not a Number)。

    一元运算符 +

    一元运算符 + 用于将操作数转换为数字。如果操作数是一个字符串,一元运算符 + 将尝试将该字符串转换为数字。如果操作数是一个数字,那么一元运算符 + 不会对数字做任何改变,仍然是原来的数字。下面是一些示例:

    let str = "42";
    let numFromStr = +str;
    console.log(numFromStr); // 输出 42,字符串 "42" 被转换成了数字 42
    
    let num = 123;
    let numFromNum = +num;
    console.log(numFromNum); // 输出 123,数字 123 保持不变
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    请注意,一元运算符 + 可能会导致类型转换,因此在使用时要谨慎考虑。

    将布尔值转换为数字

    将日期转换为字符串,你可以使用 JavaScript 中的 Date 对象的 toString() 方法。这会返回当前日期和时间的字符串表示形式,包括星期几、月份、日期、时间和时区。以下是示例代码:

    let date = new Date();
    let str = date.toString();
    console.log(str); // 输出当前日期和时间的字符串表示形式
    
    • 1
    • 2
    • 3

    要将字符串转换为数字,你可以使用 parseInt()parseFloat() 或者 Number() 函数。这些函数可以将字符串转换为对应的数字类型,其中 parseInt() 将字符串转换为整数,parseFloat() 将字符串转换为浮点数,而 Number() 则会根据字符串内容自动转换为整数或浮点数。以下是示例代码:

    使用 parseInt() 函数将字符串转换为整数:

    let str = "42";
    let num = parseInt(str);
    console.log(num); // 输出 42
    
    • 1
    • 2
    • 3

    使用 parseFloat() 函数将字符串转换为浮点数:

    let str = "3.14";
    let num = parseFloat(str);
    console.log(num); // 输出 3.14
    
    • 1
    • 2
    • 3

    使用 Number() 函数将字符串转换为数字:

    let str = "123";
    let num = Number(str);
    console.log(num); // 输出 123
    
    • 1
    • 2
    • 3

    要注意的是,如果字符串无法完全转换为有效的数字,则结果将会是 NaN(Not a Number)。

    在 JavaScript 中,一元运算符 + 也可以用于将字符串转换为数字。它会尝试将操作数转换为数字类型,如果操作数是一个字符串,则会尝试将其转换为数字。以下是示例代码:

    let str = "42";
    let numFromStr = +str;
    console.log(numFromStr); // 输出 42,字符串 "42" 被转换成了数字 42
    
    let num = 123;
    let numFromNum = +num;
    console.log(numFromNum); // 输出 123,数字 123 保持不变
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    最后,要将布尔值转换为数字,可以使用一元加号运算符 +。在 JavaScript 中,true 会被转换为 1,而 false 会被转换为 0。以下是示例代码:

    let bool = true;
    let numFromBool = +bool;
    console.log(numFromBool); // 输出 1
    
    bool = false;
    numFromBool = +bool;
    console.log(numFromBool); // 输出 0
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    通过使用一元加号运算符,可以简单快速地将布尔值转换为对应的数字。

    将日期转换为数字

    在JavaScript中,你可以使用内置的Date对象来获取当前日期时间,并将其转换为包含年月日、时分秒的字符串。以下是一个示例代码:

    let now = new Date();
    let year = now.getFullYear();
    let month = String(now.getMonth() + 1).padStart(2, '0');
    let day = String(now.getDate()).padStart(2, '0');
    let hour = String(now.getHours()).padStart(2, '0');
    let minute = String(now.getMinutes()).padStart(2, '0');
    let second = String(now.getSeconds()).padStart(2, '0');
    
    let dateString = `${year}-${month}-${day} ${hour}:${minute}:${second}`;
    console.log(dateString);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    这段代码会获取当前日期时间并将其格式化为 “年-月-日 时:分:秒” 的字符串。JavaScript中的月份是从0开始计数的,所以需要注意将月份加1。

    在这里插入图片描述
    在这里插入图片描述

    关注我,不迷路,共学习,同进步

    关注我,不迷路,共学习,同进步

    在这里插入图片描述

  • 相关阅读:
    使用 pubsub-js 进行消息发布订阅
    内网渗透-内置工具横向移动
    nginx 配置|禁止访问规则
    ubuntu-hadoop伪分布
    删除链表中重复元素的问题
    2022-09-14 C++并发编程(二十二)
    java经典面试题并发篇(持续更新)
    10 个 效果不错的值得收藏的 css 代码片段
    【智能优化算法】基于阴阳对优化算法求解单目标优化问题附matlab代码 Yin Yang Pair Optimization
    可重入函数
  • 原文地址:https://blog.csdn.net/sixpp/article/details/138214184