减乘除都没问题,为什么加法有问题?1+1=11????对了还有乱码

来源:6-11 编程练习

稽小寞

2018-06-05 11:38

<!DOCTYPE html>

<html>

 <head>

  <title> 事件</title>  

  <script type="text/javascript">

   function count(){

    var a =document.getElementById("txt1").value;

    var b =document.getElementById("txt2").value;

    var c =document.getElementById("select").value;

    if(c=="+"){

    d=a+b;

    }else if(c=="-"){

    d=a-b;

    }else if(c=="*"){

    d=a*b;

    }else{

    d=a/b;

    }

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

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

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

//获取选择框的值

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

    //设置结果输入框的值 

https://img1.mukewang.com/5b1605a600018d5110400183.jpg   }

  </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回答

  • Viola_wl
    2018-06-05 11:55:56
    已采纳

    取得的值是字符串,所以按照字符串的运算是字符串相连。可以使用parseInt()将字符串转换成数值。

        var a =parseInt(document.getElementById("txt1").value);

        var b =parseInt(document.getElementById("txt2").value);


    稽小寞

    非常感谢!

    2018-06-05 12:59:16

    共 1 条回复 >

  • imooc客服
    2018-06-13 17:03:33

    你在input中输入的内容属于字符串类型。你可以这样来测试,在你原来的JS代码中加入console.log(typeof a)就能得到你写入的内容属性是string。既然是string, 那么+号就把它们连接起来,而不是相加取和。

    稽小寞

    非常感谢!

    2018-06-15 10:19:06

    共 1 条回复 >

  • 慕粉2122502617
    2018-06-09 15:30:48

    不行啊

JavaScript进阶篇

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

468061 学习 · 21891 问题

查看课程

相似问题