热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

了解JavaScript中的数据类型转换

在JavaScript中,数据类型用于对一种特定类型的数据进行分类,确定可以分配给该类型的值以及可以对其执行的操作。

在Javascript中,数据类型用于对一种特定类型的数据进行分类,确定可以分配给该类型的值以及可以对其执行的操作。

虽然由于类型强制,Javascript会自动转换许多值,但为了达到预期的结果,通常最好在类型之间手动转换值。

本教程将指导您转换Javascript的基本数据类型,包括数字、字符串和布尔值。

隐式转换

作为一种编程语言,Javascript对意外值的容忍度很高。因此,Javascript将尝试转换意外值,而不是直接拒绝它们。这种隐式转换称为类型强制。

有些方法会自动转换值以便使用它们。alert()方法接受一个字符串作为参数,但它将自动将其他类型转换为字符串。因此,我们可以传递一个数值给方法:

alert(8.5);

如果我们运行上面的代码行,浏览器将返回一个弹出的警告对话框,其中显示8.5值,但是它将被转换为一个字符串。

当使用可以通过数学运算符计算为数字的字符串时,您将发现Javascript能够通过隐式地将字符串转换为数字来处理这些值,如下面的示例所示。

// Subtraction
"15" - "10";

输出:5

// Modulo
"15" % "10";

输出:5

然而,并不是每个运算符都能像预期的那样工作。+运算符有明显的问题,因为它可以表示加法或字符串连接。

// When working with strings, + stands for concatenation
"2" + "3";

输出:"23"

由于+运算符是多用途的,因此尽管是数字字符串,但字符串值2和3连接为字符串值23,而不是加在一起成为数字5。

由于模糊性可能存在,有时会导致意外的结果,所以通常最好在代码中显式地转换尽可能多的数据类型。这将有助于管理来自用户的输入和处理错误。

将值转换为字符串

可以通过调用String()或N.ToString()将值显式转换为字符串。

使用String()函数,让我们通过将值true传递给String()的参数,将布尔值转换为字符串。

String(true);

当我们这样做时,字符串文字“true”将返回。

输出:"true"

或者,我们可以向函数传递一个数字。

String(49);

将返回该数字的字符串文字。

输出:"49"

让我们将String()函数与变量一起使用。 我们将为变量odyssey分配一个数字值,然后使用typeof运算符来检查类型。

let odyssey = 2001;
console.log(typeof odyssey);

输出:number

此时,变量odyssey被赋予2001的数值,我们已经确认它是一个数字。

现在,让我们将odyssey重新分配到它的字符串等效值,然后使用typeof来确认我们已经成功地将变量的值从一个数字转换为一个字符串。

odyssey = String(odyssey); // "2001"
console.log(typeof odyssey);

输出:string

在上面的例子中,我们已经确认,在数据类型转换之后,将odyssey重新赋值为一个字符串值。

我们可以以类似的方式使用n.toString()。我们可以用变量替换n:

let blows = 400;
blows.toString();

变量blow将作为字符串返回。

输出:"400"

或者,我们可以把值放在圆括号内,而不是用n.toString()变量:

(1776).toString(); // returns "1776"
(false).toString(); // returns "false"
(100 + 200).toString(); // returns "300"

通过使用String()或n.toString(),我们能够显式地将布尔值或数字数据类型的值转换为String值,以确保代码的行为符合我们的预期。

将值转换为数字

在将值转换为数字数据类型时,我们将使用number()方法。首先,我们将把数字文本字符串转换为数字,但我们也可以转换布尔值。

我们可以将一个数字串传递给number()方法:

Number("1984");

字符串将被转换为一个数字,不再用引号括起来。

输出:1984

我们还可以将一个字符串赋值给一个变量,然后对其进行转换。

let dalmatians = "101";
Number(dalmatians);

输出:101

字符串文字“101”通过其变量被转换为数字101。

空白字符串或空字符串将转换为0。

Number(" "); // returns 0
Number(""); // returns 0

注意,非数字字符串将转换为NaN, NaN表示非数字。这包括用空格分隔的数字。

Number("twelve"); // returns NaN
Number("20,000"); // returns NaN
Number("2 3"); // returns NaN
Number("11-11-11"); // returns NaN

对于布尔数据类型,false的值为0,true的值为1。

Number(false); // returns 0
Number(true); // returns 1

方法的作用是:将非数字数据类型转换为数字。

将值转换为布尔值

要将数字或字符串转换为布尔值,可以使用Boolean()方法。例如,这对于确定用户是否将数据输入文本字段非常有用。

任何被解释为空的值,如数字0、空字符串或未定义的值、NaN或null,都被转换为false。

Boolean(0); // returns false
Boolean(""); // returns false
Boolean(undefined); // returns false
Boolean(NaN); // returns false
Boolean(null); // returns false

其他值将被转换为true,包括由空格组成的字符串文字。

Boolean(2000); // returns true
Boolean(" "); // returns true
Boolean("Maniacs"); // returns true

注意,“0”作为字符串文字将转换为真,因为它是一个非空字符串值:

Boolean("0");   // returns true

将数字和字符串转换为布尔值可以允许我们在二进制术语中计算数据,并且可以用于程序中的控制流。

相关免费学习推荐:js视频教程

以上就是了解Javascript中的数据类型转换的详细内容,更多请关注 第一PHP社区 其它相关文章!


推荐阅读
  • Monkey《大话移动——Android与iOS应用测试指南》的预购信息发布啦!
    Monkey《大话移动——Android与iOS应用测试指南》的预购信息已经发布,可以在京东和当当网进行预购。感谢几位大牛给出的书评,并呼吁大家的支持。明天京东的链接也将发布。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • GetWindowLong函数
    今天在看一个代码里头写了GetWindowLong(hwnd,0),我当时就有点费解,靠,上网搜索函数原型说明,死活找不到第 ... [详细]
  • 本文介绍了在Python3中如何使用选择文件对话框的格式打开和保存图片的方法。通过使用tkinter库中的filedialog模块的asksaveasfilename和askopenfilename函数,可以方便地选择要打开或保存的图片文件,并进行相关操作。具体的代码示例和操作步骤也被提供。 ... [详细]
  • 本文描述了作者第一次参加比赛的经历和感受。作者是小学六年级时参加比赛的唯一选手,感到有些紧张。在比赛期间,作者与学长学姐一起用餐,在比赛题目中遇到了一些困难,但最终成功解决。作者还尝试了一款游戏,在回程的路上感到晕车。最终,作者以110分的成绩取得了省一会的资格,并坚定了继续学习的决心。 ... [详细]
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的详细步骤
    本文详细介绍了搭建Windows Server 2012 R2 IIS8.5+PHP(FastCGI)+MySQL环境的步骤,包括环境说明、相关软件下载的地址以及所需的插件下载地址。 ... [详细]
  • PHP图片截取方法及应用实例
    本文介绍了使用PHP动态切割JPEG图片的方法,并提供了应用实例,包括截取视频图、提取文章内容中的图片地址、裁切图片等问题。详细介绍了相关的PHP函数和参数的使用,以及图片切割的具体步骤。同时,还提供了一些注意事项和优化建议。通过本文的学习,读者可以掌握PHP图片截取的技巧,实现自己的需求。 ... [详细]
  • 关羽败走麦城时路过马超封地 马超为何没有出手救人
    对当年关羽败走麦城,恰好路过马超的封地,为啥马超不救他?很感兴趣的小伙伴们,趣历史小编带来详细的文章供大家参考。说到英雄好汉,便要提到一本名著了,没错,那就是《三国演义》。书中虽 ... [详细]
  • 本文分享了一个关于在C#中使用异步代码的问题,作者在控制台中运行时代码正常工作,但在Windows窗体中却无法正常工作。作者尝试搜索局域网上的主机,但在窗体中计数器没有减少。文章提供了相关的代码和解决思路。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • PHP设置MySQL字符集的方法及使用mysqli_set_charset函数
    本文介绍了PHP设置MySQL字符集的方法,详细介绍了使用mysqli_set_charset函数来规定与数据库服务器进行数据传送时要使用的字符集。通过示例代码演示了如何设置默认客户端字符集。 ... [详细]
author-avatar
mobiledu2502918541
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有