慕粉2359159961
2017-01-11 01:47
<!DOCTYPE html>
<html>
<head>
<title> 事件</title>
<script type="text/javascript">
function count(){
var result;
// document.write("输出"+one+" "+two+" "+three//+" "+result)
var one=document.getElementById("txt1").value;
//获取第一个输入框的值
var two=document.getElementById("txt2").value; //获取第二个输入框的值
//获取选择框的值
var three=document.getElementById("select").value;
//获取通过下拉框来选择的值来改变加减乘除的运算法则
switch(three){
case '+':result=one+two;
break;
case "-":
result=one-two;
break;
case "*":
result=one*two;
break;
case "/":
result=one/two;
break;
}
//设置结果输入框的值
document.getElementById("fruit")=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>
你可以看下基本类型,现在的one,two是字符串(string),不是数字(number),无法正常进行符号的基本运算,你可以通过parseInt(one)+parseInt(two),来吧字符串one和two转化才数字,以此类推,下面的都需要此类操作
document.getElementById("fruit")=result;应该写成document.getElementById("fruit").value=result;
另外就是楼上说的
var one,two 需要用parseInt()转成整形后才能运算
JavaScript进阶篇
468191 学习 · 21891 问题
相似问题