本文涵盖了ES6中的新的和改进的数字方法(ecmascript 6)。
>这是有关ES6的新功能的系列的一部分,在其中我们还讨论了可用于字符串和数组数据类型的新方法,但也讨论了新类型的数据类型,例如MAP和FEAMMAP。>我将向您介绍添加到数字数据类型中的新方法和常数。正如我们将看到的那样,其中一些数字方法并不是什么新鲜事物,但是它们已得到改进和/或在正确的对象下移动(例如,isnan())。与往常一样,我们还将通过一些示例将新知识付诸实践。因此,事不宜迟,让我们开始。
>钥匙要点
ES6
介绍了几种新数字方法,包括number.isinteger(),number.isnan(),number.Siffinite(),number.issafeInteger(),number.parseint()和number.parsefloat()。 >- number.isinteger()检查传递的值是否为整数,number.isnan()测试是否值等于nan,而number.Siffinite()测试是否传递的值是有限的数字。
- number.issafeinteger()测试是否传递的值是一个安全整数,定义为一个可以完全表示为IEEE-754双重精度编号的整数。
- number.parseint()和number.parsefloat()并不是新事物,但它们已在数字对象下移动,以实现全球模块化。他们分析字符串参数并分别返回整数和浮点数。 ES6还引入了两个相关的常数值:number.max_safe_integer和number.min_safe_integer,代表JavaScript中的最大和最小安全整数。
- 我要涵盖的第一个方法是number.isinteger()。这是JavaScript的新补充,这是您过去自己定义和使用的东西。它确定传递给函数的值是否为整数。如果传递值是整数,则此方法将返回true,否则为false。这种方法的实现非常容易,但是本地进行本地化仍然很好。重新创建此功能的可能解决方案之一是:
这两个功能都很好且有用,但它们不尊重Ecmascript 6的规格。因此,如果您想对此方法进行多填充,则需要一些更复杂的东西,正如我们很快会看到的那样。目前,让我们从发现number.isinteger()的语法开始:
数字参数代表您要测试的值。
<span>Number.isInteger = Number.isInteger || function (number) { </span> <span>return typeof number === 'number' && number % 1 === 0; </span><span>}; </span>
使用此方法使用的一些示例如下:
<span>Number.isInteger = Number.isInteger || function (number) { </span> <span>return typeof number === 'number' && Math.floor(number) === number; </span><span>}; </span>>以下代码的实时演示如下所示,也可以在JSBIN上找到。
>除了Internet Explorer,该方法在节点和所有现代浏览器中都支持该方法。如果您需要支持较旧的浏览器,则可以使用一个多填充,例如方法页面上的Mozilla开发人员网络上可用的浏览器。为了方便起见,下面还复制了这一点:
<span>Number.isInteger = Number.isInteger || function (number) { </span> <span>return typeof number === 'number' && number % 1 === 0; </span><span>}; </span>> number.isnan()
>过去您编写了任何JavaScript代码,此方法对您来说不应该是新的。一段时间以来,JavaScript有了一种称为isnan()的方法,它通过窗口对象暴露。此方法测试值是否等于NAN,在这种情况下,它返回true或其他错误。 window.isnan()的问题是,它存在一个问题,因为它也返回true,因为
>转换为数字的值将为nan。为了让您对此问题有具体的想法,以下所有陈述返回true:
<span>Number.isInteger = Number.isInteger || function (number) { </span> <span>return typeof number === 'number' && Math.floor(number) === number; </span><span>}; </span>
>在这里,值是您要测试的值。该方法的一些示例用途如下:
><span>Number.isInteger(number) </span>如您所见,测试相同的值我们获得不同的结果。
>以下片段的实时演示如下所示,也可以在JSBIN上找到。
除了Internet Explorer,该方法在节点和所有现代浏览器中都支持该方法。如果您想支持其他浏览器,那么此方法的非常简单的多填充如下:<span>// prints 'true' </span><span>console.log(Number.isInteger(19)); </span> <span>// prints 'false' </span><span>console.log(Number.isInteger(3.5)); </span> <span>// prints 'false' </span><span>console.log(Number.isInteger([1, 2, 3])); </span>>
这项工作的原因是因为NAN是JavaScript中唯一的非反射值,这意味着它是唯一不等于自身的值。
>
number.Isfinite()此方法与上一个方法共享相同的故事。在JavaScript中,有一种称为window.isfinite()的方法,该方法测试是否传递的值是有限的数字。不幸的是,对于
<span>if (!Number.isInteger) { </span> <span>Number.isInteger = function isInteger (nVal) { </span> <span>return typeof nVal === 'number' && </span> <span>isFinite(nVal) && </span> nVal <span>> -9007199254740992 && </span> nVal <span> <span>Math.floor(nVal) === nVal; </span> <span>}; </span><span>} </span></span>>转换为一个数字的值,它也将返回true。此问题的示例如下:
出于这个原因,在ecmascript 6中,有一种属于数字的方法称为isfinite()。它的语法如下:
>在这里,值是您要测试的值。如果您从上一个片段中测试相同的值,则可以看到结果是不同的:>
<span>// prints 'true' </span><span>console.log(window.isNaN(0/0)); </span> <span>// prints 'true' </span><span>console.log(window.isNaN('test')); </span> <span>// prints 'true' </span><span>console.log(window.isNaN(undefined)); </span> <span>// prints 'true' </span><span>console.log(window.isNaN({prop: 'value'})); </span>>以下片段的实时演示如下所示,也可以在JSBIN上找到。
除了Internet Explorer,该方法在节点和所有现代浏览器中都支持该方法。您可以在MDN的方法页面上找到一个多填充。
>number.issafeInteger()
number.issafeinteger()方法是ES6的全新添加。它测试传递的值是否是一个安全整数的数字,在这种情况下,它返回了TRUE。安全整数定义为满足以下两个条件的整数:
- 该数字可以完全表示为IEEE-754双精度编号
-
该数字的IEEE-754代表不可能是将任何其他整数符合IEEE-754表示的结果。
> - >基于此定义,安全整数是 - (2
- 1)包含在2 53> 53 > 1的整数中。这些价值观很重要,我们将在本节的末尾进行更多讨论。>。
该方法的语法为:
>在这里,值是您要测试的值。该方法的一些示例用途如下:
><span>Number.isInteger = Number.isInteger || function (number) { </span> <span>return typeof number === 'number' && number % 1 === 0; </span><span>}; </span>
>该代码的实时演示如下所示,也可在JSBIN上找到。
除了Internet Explorer外,
<span>Number.isInteger = Number.isInteger || function (number) { </span> <span>return typeof number === 'number' && Math.floor(number) === number; </span><span>}; </span>请注意,此polyfill依赖于以前讨论过的number.isinteger()方法,因此您还需要对后者进行多填充。
> ecmascript 6还引入了两个相关的常数值:number.max_safe_integer和number.min_safe_integer。前者代表JavaScript中的最大安全整数 - 即2
53> 1-而后者是最小安全整数,即 - (253
1)。您可能会注意到,这些是我之前引用的相同值。<span>Number.isInteger(number) </span>
number.parseint()和number.parsefloat()
number.parseint()和number.parsefloat()方法在同一部分中介绍,因为与本文中提到的其他类似方法不同,它们已经存在于以前的Ecmascript中旧的全球版本。因此,您可以以到目前为止所做的方式使用它们,并且可以期待相同的结果。将这些方法添加到数字的目的是全球的模块化。
为了完整,我正在报告他们的语法:
>下面显示了此代码的实时演示,也可以在JSBIN上找到。
> 除了Internet Explorer,这些方法在节点和所有现代浏览器中都支持这些方法。如果您想将它们进行多填充,则可以简单地调用其相关的全局方法,如下所示:
><span>Number.isInteger = Number.isInteger || function (number) { </span> <span>return typeof number === 'number' && number % 1 === 0; </span><span>}; </span>
>浏览器支持
>以下图形描述了浏览器对ES6中内置数字对象的扩展的支持。鼠标在盒子上查看相应浏览器版本的百分比使用。
>我可以使用ES6数字吗? Caniuse.com主要浏览器中对ES6数字功能的支持数据。
ES6数字方法:总结
在本教程中,我们介绍了与数字数据类型一起使用的Ecmascript 6中添加的新方法和常数。值得注意的是,ES6还增加了我尚未提到的另一个常数。这是number.epsilon和代表一个和最小的值之间的差异大于一个数字的大于一个数字。在最后一个注释中,我们已经结束了数字数据类型的旅程。
>新的ES6数字方法是什么?它们如何工作?
ES6引入了几种新的数字方法,使与JavaScript中的数字更易于使用。其中包括number.Isfinite(),number.isinteger(),number.isnan(),number.parsefloat()和number.parseint()。这些方法中的每一个都执行特定功能。例如,number.Iffinite()检查值是否为有限数,而number.isinteger()检查值是否为整数。 number.isnan()检查值是否为nan(不是数字),number.parsefloat()和number.parseint()分别返回浮点数和整数。 epsilon方法在es6?
number.eps6中如何工作。ES6中的epsilon是一个新常数,代表两个代表数字之间的最小间隔。在比较浮点数的平等时,这特别有用。由于计算机中浮点数表示的方式,即使它们看起来也不完全相同。 number.epsilon可用于检查两个数字之间的差异是否小于最小的间隔,表明它们实际上相等。 ES6中的number.issafeinteger()方法用于确定值是否是安全整数。安全整数是一个可以完全表示为IEEE -754双精度编号的数字,这意味着它在 - (2^53 - 1)和2^53 - 1。确保在JavaScript中可以准确表示一个数字,这在某些数学操作中可能很重要。
> number.parseint()方法与global parseint()函数有何不同?数字对象的一部分。这意味着您可以将其称为数字对象上的方法,而不是作为独立函数。功能是相同的 - 它将字符串转换为指定的radix或base。 number.max_safe_integer和number.min_safe_integer常数ES6中代表JavaScript中的最大和最小安全整数值。安全整数是可以完全表示为IEEE-754双精度编号的整数。当您需要检查一个数字是否在安全整数范围内时,这些常数很有用,这在某些数学操作中可能很重要。
>>我如何在es6?
中使用number.Isfinite()方法是使用es6中的number.isfinite()方法来确定值是否为有限数字。这与全局isfinite()函数不同,该函数将其参数转换为数字,然后在测试它之前。 number.Iffinite()不执行此转换,因此仅在参数为有限数字时返回true,而如果参数是不能转换为数字的值。 eS6?
中的number.parsefloat()方法在es6中的number.parsefloat()方法在es6中的number.parsefloat()方法基本上与global parsefloat()函数相同,但它是数字对象的一部分。这意味着您可以将其称为数字对象上的方法,而不是作为独立函数。功能是相同的 - 它解析了一个字符串参数并返回浮点数。
如何在es6?
中使用number.isinteger()方法number.isinteger() ES6中的方法用于确定值是否是整数。如果该值是一个不是无穷大的,而不是NAN的数字,则此方法将返回true,并且可以在没有分数组件的情况下表示。当您需要检查一个数字是否是整数时,这很有用,这在某些数学操作中可能很重要。>
>新的ES6编号方法的实际应用是什么?
>新的ES6数字方法提供了更健壮,更精确的方法来使用JavaScript中的数字。它们可用于检查一个数字是有限的,整数,NAN还是安全的整数,并将字符串分解为数字。这些方法在需要精确控制数字的数学操作,数据验证以及其他任何地方都可能特别有用。
以上是为ecmascript做准备6:新数字方法的详细内容。更多信息请关注PHP中文网其他相关文章!

JavaScript字符串替换方法详解及常见问题解答 本文将探讨两种在JavaScript中替换字符串字符的方法:在JavaScript代码内部替换和在网页HTML内部替换。 在JavaScript代码内部替换字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 该方法仅替换第一个匹配项。要替换所有匹配项,需使用正则表达式并添加全局标志g: str = str.replace(/fi

因此,在这里,您准备好了解所有称为Ajax的东西。但是,到底是什么? AJAX一词是指用于创建动态,交互式Web内容的一系列宽松的技术。 Ajax一词,最初由Jesse J创造

10款趣味横生的jQuery游戏插件,让您的网站更具吸引力,提升用户粘性!虽然Flash仍然是开发休闲网页游戏的最佳软件,但jQuery也能创造出令人惊喜的效果,虽然无法与纯动作Flash游戏媲美,但在某些情况下,您也能在浏览器中获得意想不到的乐趣。 jQuery井字棋游戏 游戏编程的“Hello world”,现在有了jQuery版本。 源码 jQuery疯狂填词游戏 这是一个填空游戏,由于不知道单词的上下文,可能会产生一些古怪的结果。 源码 jQuery扫雷游戏

本教程演示了如何使用jQuery创建迷人的视差背景效果。 我们将构建一个带有分层图像的标题横幅,从而创造出令人惊叹的视觉深度。 更新的插件可与JQuery 1.6.4及更高版本一起使用。 下载

Matter.js是一个用JavaScript编写的2D刚体物理引擎。此库可以帮助您轻松地在浏览器中模拟2D物理。它提供了许多功能,例如创建刚体并为其分配质量、面积或密度等物理属性的能力。您还可以模拟不同类型的碰撞和力,例如重力摩擦力。 Matter.js支持所有主流浏览器。此外,它也适用于移动设备,因为它可以检测触摸并具有响应能力。所有这些功能都使其值得您投入时间学习如何使用该引擎,因为这样您就可以轻松创建基于物理的2D游戏或模拟。在本教程中,我将介绍此库的基础知识,包括其安装和用法,并提供一

本文演示了如何使用jQuery和ajax自动每5秒自动刷新DIV的内容。 该示例从RSS提要中获取并显示了最新的博客文章以及最后的刷新时间戳。 加载图像是选择

本文讨论了在浏览器中优化JavaScript性能的策略,重点是减少执行时间并最大程度地减少对页面负载速度的影响。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。