Javascript字符串转数字的三种方法

2025-07-07 00:38:57

以前给大家讲过 Ja箪滹埘麽vascript中如何将字符串转换成对象的方法 ,今天我们就一起来看Javascript字符串转数字的三种方法:转掊测汹权换函数、强制类型转换、利用js变量弱类型转换。

  1. 1. 转换函数:

    js提供了parseInt()和parseFloat()两个转换函数。前者把值转换成整数,后者把值转换成浮点数。只有对String类型调用这些方法,这两个函数才能正确运行;对其他类型返回的都是NaN(Not a Number)。

    一些示例如下:

    代码如下:

    parseInt(\"1234blue\"); //returns 1234 parseInt(\"0xA\"); //returns 10 parseInt(\"22.5\"); //returns 22 parseInt(\"blue\"); //returns NaN

    parseInt()方法还有基模式,可以把二进制、八进制、十六进制或其他任何进制的字符串转换成整数。基是由parseInt()方法的第二个参数指定的,示例如下:

    代码如下:

    parseInt(\"AF\", 16); //returns 175 parseInt(\"10\", 2); //returns 2 parseInt(\"10\", 8); //returns 8 parseInt(\"10\", 10); //returns 10

    如果十进制数包含前导0,那么最好采用基数10,这样才不会意外地得到八进制的值。例如:

    代码如下:

    parseInt(\"010\"); //returns 8 parseInt(\"010\", 8); //returns 8 parseInt(\"010\", 10); //returns 10

    parseFloat()方法与parseInt()方法的处理方式相似。使用parseFloat()方法的另一不同之处在于,字符串必须以十进制形式表示浮点数,parseFloat()没有基模式。

    下面是使用parseFloat()方法的示例:

    代码如下:

    parseFloat(\"1234blue\"); //returns 1234.0 parseFloat(\"0xA\"); //returns NaN parseFloat(\"22.5\"); //returns 22.5 parseFloat(\"22.34.5\"); //returns 22.34 parseFloat(\"0908\"); //returns 908 parseFloat(\"blue\"); //returns NaN

  2. 2. 强制类型转换

    还可使用强制类型转换(type casting)处理转换值的类型。使用强制类型转换可以访问特定的值,即使它是另一种类型的。ECMAScript中可用的3种强制类型转换如下:Boolean(value)――把给定的值转换成Boolean型;Number(value)――把给定的值转换成数字(可以是整数或浮点数);String(value)――把给定的值转换成字符串。用这三个函数之一转换值,将创建一个新值,存放由原始值直接转换成的值。这会造成意想不到的后果。当要转换的值是至少有一个字符的字符串、非0数字或对象(下一节将讨论这一点)时,Boolean()函数将返回true。如果该值是空字符串、数字0、undefined或null,它将返回false。

    可以用下面的代码段测试Boolean型的强制类型转换。

    代码如下:

    Boolean(\"\"); //false

  3. 3. 利用js变量弱类型转换

    举个小例子,一看,就会明白了。 <script> var str= '012.345 '; var x = str-0; x = x*1; </script>

声明:本网站引用、摘录或转载内容仅供网站访问者交流或参考,不代表本站立场,如存在版权或非法内容,请联系站长删除,联系邮箱:site.kefu@qq.com。
猜你喜欢