為什么函數調用那里不加括號就沒有結果
<!DOCTYPE html>
<html>
?<head>
? <title> 事件</title>??
? <script type="text/javascript">
? ?function count(){
? ? ? ?
? ? //獲取第一個輸入框的值
var one=document.getElementById('txt1').value
//獲取第二個輸入框的值
var two=document.getElementById('txt2').value
//獲取選擇框的值
var sel=document.getElementById('select').value
//獲取通過下拉框來選擇的值來改變加減乘除的運算法則
var result;
switch(sel)
{
case '+':result=parseInt(one)+parseInt(two);
break;
case '-':result=parseInt(one)-parseInt(two);
break;
case '*':result=parseInt(one)*parseInt(two);
break;
case '/':result=parseInt(one)/parseInt(two);
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>
2020-03-03
例子說明:例1.
function init(){
??? 。。。。。。
}
window.onload = init;
例2:
function fun(){
??? return 5
}
var a=fun
var b=fun()
a是fun函數,b是5
那么到底在使用一個函數時需不需要加上()呢?
函數只要是要調用它進行執行的,都必須加括號。此時,函數實際上等于函數的返回值或者執行效果,當然,有些沒有返回值,但已經執行了函數體內的行為,就是說,加括號的,就代表將會執行函數體代碼。
不加括號的,都是把函數名稱作為函數的指針,一個函數的名稱就是這個函數的指針,此時不是得到函數的結果,因為不會運行函數體代碼。它只是傳遞了函數體所在的地址位置,在需要的時候好找到函數體去執行。
例如window.οnlοad=init;
init函數并不會在這行代碼時就執行,瀏覽器加載文檔時這句話會被加載,會被告知文檔加載完要執行哪個函數,但實際上沒有當時就執行,等到整個文檔加載完成之后才會通過init這個指針去執行init()。