我有一个同学最近在自学JavaScript,偶尔遇到问题了会让我帮忙解决,虽然我也是一个JavaScript菜鸟,但是我还是很乐意帮忙,这样不仅可以帮到别人,也可以让自己在解决问题的过程中学到更多知识。先来看看他的代码吧!

  HTML代码:

<input type='text' id='txt1' />
<select id='select'>
<option value='+'>+</option>
<option value="-">-</option>
<option value="*">*</option>
<option value="/">/</option>
</select>
<input type='text' id='txt2' />
<input type='button' value=' = ' onclick="count()" /> <!--通过 = 按钮来调用创建的函数,得到结果-->
<input type='text' id='fruit' />

  JavaScript代码:

function count(){
//获取第一个输入框的值
var num1 = document.getElementById("txt1");
//获取第二个输入框的值
var num2 = document.getElementById("txt2");
//获取选择框的值
var fuhao = document.getElementById("select").value;
function yunsuan(){
  var num;
  if (fuhao == "+") {
   num = num1 + num2;
   }else if(fuhao == "-"){
   num = num1 - num2;
  }else if(fuhao == "*"){
   num = num1 * num2;
   }else if(fuhao == "/"){
   num = num1 / num2;
   }
}
document.getElementById("fruit").value = num;
}

  看完代码后,我发现了三个问题,分别为:

  • num1和num2获取的是元素节点,而不是文本框的值,所以应该这样写:var num1 = document.getElementById("txt1").value; num2同num1
  • num是一个局部变量,document.getElementById("fruit").value无法得到num的值
  • 在JavaScript中+可以用来连接字符串,因此这里需要进行转换

  修改后的JavaScript代码如下:

function count(){
var num;
//获取第一个输入框的值
var num1 = parseInt(document.getElementById("txt1").value);
//获取第二个输入框的值
var num2 = parseInt(document.getElementById("txt2").value);
//获取选择框的值
var fuhao = document.getElementById("select").value;
function yunsuan(){
  if (fuhao == "+") {
   num = num1 + num2;
   }else if(fuhao == "-"){
   num = num1 - num2;
  }else if(fuhao == "*"){
   num = num1 * num2;
   }else if(fuhao == "/"){
   num = num1 / num2;
   }
}
document.getElementById("fruit").value = num;
}

  但是,经过测试我发现得到的答案永远是undefined。所以我将JavaScript代码进一步修改为:

function count(){
var num;
//获取第一个输入框的值
var num1 = parseInt(document.getElementById("txt1").value);
//获取第二个输入框的值
var num2 = parseInt(document.getElementById("txt2").value);
//获取选择框的值
var fuhao = document.getElementById("select").value;
switch(fuhao){
case "+":
num = num1 + num2;
break;
case "-":
num = num1 - num2;
break;
case "*":
num = num1 * num2;
break;
case "/":
num = num1 / num2;
}
document.getElementById("fruit").value = num;
}

  这次可以得到正确答案了,但是无法进行小数运算,所以我用Number()方法替换parseInt()方法,但是Number无法将字符串中的非数字字符过滤掉,所以我用parseFloat()来代替。这下可以很好地解决问题了。

  知识链接:

  parseInt():parseInt()函数可以解析一个字符串,并返回一个整数。它可接受两个参数,第一个参数是要解析的字符串,第二个参数是要解析的数字的基数,范围为2~36。如果省略该参数或其值为0,则以十进制来解析;如果该参数小于2或者大于36,则parseInt()将返回NaN。该方法可以将非数字字符(非首个字符)过滤掉,例如:parseInt("40d"),返回40,而parseInt("d40")则返回NaN。

  parseFloat():parseFloat())函数可以解析一个字符串,并返回一个浮点数。该函数在解析过程中遇到了正负号、数字、小数点或者科学计数法中的指数(e 或 E)以外的字符,则它会忽略该字符以及之后的所有字符,返回当前已经解析到的浮点数。同时参数字符串首尾的空白符会被忽略。

  Number():Number()函数把对象的值转换为数字。如果参数是Date对象,Number()返回1970年1月1日至今的毫秒数。如果对象的值无法转换为数字,那么Number()函数返回NaN。

  刚开始一直没弄明白为什么使用if...else总是得到undefined,经过反复的测试,终于得到了我想要的结果,代码如下:

function count(){
var num;
//获取第一个输入框的值
var num1 = parseFloat(document.getElementById("txt1").value);
//获取第二个输入框的值
var num2 = parseFloat(document.getElementById("txt2").value);
//获取选择框的值
var fuhao = document.getElementById("select").value;
if (fuhao == "+") {
num = num1 + num2;
}else if(fuhao == "-"){
num = num1 - num2;
}else if(fuhao == "*"){
num = num1 * num2
}else{
num = num1 / num2;
}
document.getElementById("fruit").value = num;
}

parseInt()、parseFloat()与Number()的比较的更多相关文章

  1. parseInt parseFloat isNaN Number 区别和具体的转换规则及用法

    原文链接:https://blog.csdn.net/wulove52/article/details/84953998 在javascript 我经常用到,parseInt.parseFloat.N ...

  2. parseint和parsefloat总结number。隐形转换

    parseint:会认识一些字符+.-.空格,其他的就会截止譬如23hudhchauch结果为:23,对于boollen类型不能转换为1或是0. number:是对整体的转换.对true的转换为1. ...

  3. Number,parseInt,parseFloat函数

    Number,parseInt,parseFloat函数 console.group('Number'); console.log(Number( console.log(Number( consol ...

  4. Number(),parseInt(),parseFloat(),Math.round(),Math.floor(),Math.ceil()对比横评

    首先,这些处理方法可分为三类. 1,只用来处理数字取整问题的:Math.round(),Math.floor(),Math.ceil(): 2,专门用于把字符串转化成数值:parseInt(),par ...

  5. isNaN与parseInt/parseFloat

    isNaN 返回一个 Boolean 值,指明提供的值是否是保留值 NaN (不是数字). NaN 即 Not a Number isNaN(numValue) 必选项 numvalue 参数为要检查 ...

  6. js字符转换成整型 parseInt()函数规程Number()函数

    今天在做一个js加法的时候,忘记将字符转换成整型,导致将加号认为是连接符,  在运算前要先对字符井行类型转换,使用parseInt()函数   使用Number()将字符转换成int型效果更好

  7. parseFloat 和 Number isNaN 转换

    parseFloat(true) // NaN Number( parseFloat(null) // NaN Number( parseFloat('') // NaN Number('') par ...

  8. js parseInt();parseFloat;Number()

    1:  parseInt( numString [, radix ] ) [测试浏览器:chromium && firefox] ①parseInt()函数用于将字符串转换为(十进制) ...

  9. parseInt、parseFloat、Number、Boolean、valueOf总结

    parseInt(string, radix) 功能: 将字符串转换为十进制的数字 radix: string的进制,没有时根据string进行判断: 1~9开头 十进制 0x开头 16进制 0开头 ...

随机推荐

  1. 修改LiteIDE 编辑窗口的主题

    用习惯了Visual Studio 再看其他编译器总是有点别扭,当然LiteIDE 也是能够自定义主题的,再次感叹作者的用心. 依次: 查看 -> 选项 -> LiteEditor 在编辑 ...

  2. android自动打包方法(ant+proguard+签名)

    前段时间做了一个android的网游项目,现在优化减少体积和防止别人反编译,需要把编译后.class进行混淆,开始在网上看了一些关于 ProGuard的介绍,基本上都是使用ADT自带的打包方式,那个打 ...

  3. [转]Log4Net中配置文件的解释

    FROM:http://www.cnblogs.com/kissazi2/p/3392605.html 一个完整的配置文件的例子如下所示 <log4net> <!-- 错误日志类-- ...

  4. iOS开发——OC篇&协议篇/NSCoder/NSCoding/NSCoping

    协议篇/NSCoder/NSCoding/NSCoping 协议声明类需要实现的的方法,为不同的类提供公用方法,一个类可以有多个协议,但只能有一个父类,即单继承.它类似java中的接口. 正式协议(f ...

  5. 【剑指Offer学习】【面试题55:字符流中第一个不反复的字符】

    题目:请实现一个函数用来找出字符流中第一个仅仅出现一次的字符. 举例说明 比如,当从字符流中仅仅读出前两个字符"go"时.第一个仅仅出现一次的字符是'g'.当从该字符流中读出前六个 ...

  6. 特殊用途语言特性——默认参数、内联函数和constexptr函数

    1 默认实参 某些函数有这样一些参数,在函数的很多次调用中它们都被赋予一个相同的值,此时,我们把这个反复出现的值称为函数的默认实参.调用含有默认实参的函数时,可以包含该实参,也可以省略该实参. 我们可 ...

  7. C#_Queue实例

    using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Queu ...

  8. java_泛型(设置通配符下限)

    package ming; import java.util.ArrayList; import java.util.Collection; import java.util.List; /* * 返 ...

  9. 显示/去掉CONSOLE窗口

    众所周知,控制台应用程序一般都会显示一个控制台窗口(虚拟DOS窗口),但很多时候控制台程序的执行逻辑根本不需要与用户进行交互,所以显示这个难看的窗口纯属多余,那么如何将它屏蔽掉呢?下面我向大家介绍一种 ...

  10. jemalloc源码结构分析(一):内存申请处理过程

    一.5种malloc方法 1)tcache_alloc_small 2)arena_malloc_small 3)tcache_alloc_large 4)arena_malloc_large 5)h ...