為什么我加運算的時候結果不對呢?其他運算都對
<!DOCTYPE html>
<html>
?<head>
? <title> 事件</title>??
? <script type="text/javascript">
? ?function count(){
? ? //獲取第一個輸入框的值
? ? var x=document.getElementById("txt1").value;
//獲取第二個輸入框的值
var y=document.getElementById("txt2").value;
//獲取選擇框的值
var cal=document.getElementById("select").value;
//獲取通過下拉框來選擇的值來改變加減乘除的運算法則
switch(cal){
? ? case '+':
? ? ? ? var rst=x+y;break;
? ? case '-':
? ? ? ? rst=x-y;break;
? ? case '*':
? ? ? ? rst=x*y;break;
? ? default:
? ? ? ? rst=x/y;break;
}
? ? //設置結果輸入框的值?
? ? document.getElementById("fruit").value=
? ?}
? </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+5的話結果會變成35 而不是8
其他運算結果都對
我試了用parseInt函數處理x和y但還是這樣,不知道是怎么回事??
2019-05-06
這樣獲取的都是字符串類型,直接用+的話相當于拼接字符串,所以這里應該先用parseInt(x)轉換為數值類型再進行相加。至于其他的都對,應該是隱式轉換了。
2019-05-05
文本輸入框的值默認是字符串,要用parseInt轉化成數值
var x=parseInt(document.getElementById("txt1").value);
var y=parseInt(document.getElementById("txt2").value);
只有+是35其他卻正常,那是因為字符串之間連接也是用+