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

请问为什么输出值为NaN

<!DOCTYPE html>

<html>

 <head>

  <title> 事件</title>  

  <script type="text/javascript">

   function count(){

    var m;

    var x = document.getElementById("txt1");  

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

    var y = document.getElementById("txt2");

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

    var z = document.getElementById("select");

//获取选择框的值

    

    switch(z){

        case "+":

            var m = parseInt(x) + parseInt(y);

            break;

        case "-":

            var m = x-y;

            break;

        case "*":

            var m = x*y;

            break;

        default:

            var m = x/y;

    }

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

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

    //设置结果输入框的值     

   }

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


正在回答

2 回答

var z = document.getElementById("select");

//获取选择框的值

获取z的值不能这样取,你打印出来看看z是什么就知道了。

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

飯糰熊 提问者

非常感谢!
2015-10-20 回复 有任何疑惑可以回复我~

根据你的代码,x、y、z都是对象,两个对象你怎么让他们相加啊!

  var x = document.getElementById("txt1").value;  
  var y = document.getElementById("txt2").value;
  var z = document.getElementById("select").value;

取了值之后再加!

0 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消
JavaScript进阶篇
  • 参与学习       468043    人
  • 解答问题       21891    个

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

进入课程

请问为什么输出值为NaN

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