求解!为什么没有加parseInt()函数时,计算相加时,第一个框的数字会被放大10倍呢,从而使结果不正确,但是相减,相乘,相除又是正确的。

来源:6-11 编程练习

天涯蝶舞

2016-07-09 12:30

<!DOCTYPE html>

<html>

 <head>

  <title> 事件</title>  

  <script type="text/javascript">

   function count(){

    var num1,num2,num3,fruit;  

    //获取第一个输入框的值

    num1 = document.getElementById("txt1").value;

//获取第二个输入框的值

    num2 = document.getElementById("txt2").value;

//获取选择框的值

    num3 = document.getElementById("select").value;

//获取通过下拉框来选择的值来改变加减乘除的运算法则

    //设置结果输入框的值 

    switch(num3){

        case "+":fruit=num1+num2;break;

        case "-":fruit=num1-num2;break;

        case "*":fruit=num1*num2;break;

        case "/":fruit=num1/num2;break;

    }

    document.getElementById("fruit").value=fruit;

   }

  </script> 

 </head> 

 <body>

   <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' />   

 </body>

</html>


写回答 关注

3回答

  • 天涯蝶舞
    2016-07-09 18:32:09

    document.getElementById("fruit").value返回值是字符串,若要进行运算,需要使用parseInt()或parseFloat()函数将其进行解析为数值。否则6+6相当于字符串“6”+“6”=“66”,类似于“lo”+"ve"="love"

  • 一剑一人
    2016-07-09 14:06:54

    怎么看出来放大了十倍?  你换上字母输入看看 ,   parseInt()能解析一个字符串,然后再返回一个整数,如果不加这个,只是单纯的把两个字符串放在一起。

    一剑一人 回复天涯蝶舞

    弱弱的问一句,你怎么知道哪个是5哪个是6的啊,也是后天被人引导的啊。。。

    2016-07-09 21:00:58

    共 3 条回复 >

  • qq_慕侠1535465
    2016-07-09 13:59:28

    parseFloat()

    天涯蝶舞

    不使用这个函数,只要保证输入的都是数字不行么?

    2016-07-09 17:57:43

    共 1 条回复 >

JavaScript进阶篇

本课程从如何插入JS代码开始,带您进入网页动态交互世界

468782 学习 · 22507 问题

查看课程

相似问题