为了账号安全,请及时绑定邮箱和手机立即绑定

为什么相加结果不对

<!DOCTYPE html>
<html>
 <head>
  <title> 事件</title>  
  <script type="text/javascript">
   function count(){
       
    //获取第一个输入框的值
    var txt1 = document.getElementById("txt1").value;
	//获取第二个输入框的值
    var txt2 = document.getElementById("txt2").value;
	//获取选择框的值
    var select = document.getElementById("select").value;
	//获取通过下拉框来选择的值来改变加减乘除的运算法则
    var result = '';
    switch(select){
        case "+":
           result = txt1 + txt2;
           break;
        case "-":
            result = txt1 - txt2;
            break;
        case "*":
            result = txt1 * txt2;
            break;
        case "/":
            result = txt1 / txt2;
            break;
        default :
            break;
    }
    //设置结果输入框的值 
    document.getElementById("fruit").value = result;
   }
  </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>


正在回答

1 回答

因为:“+”符号被优先当做字符串连接符了,所以效果就是1字符串连接上了2字符串“12”;

修正:加parseInt()方法强制转为整数。如:var txt1 = parseInt(document.getElementById("txt1").value);

1 回复 有任何疑惑可以回复我~
#1

VoyageCN 提问者

原来如此 ,感谢帮助
2016-07-09 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消

为什么相加结果不对

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信