天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

js 覆蓋和重載 函數

學過Java的人對函數的覆蓋和重載肯定是再熟悉不過了。
重載指兩個或多個函數的參數類型,順序和數量以及返回值不一樣。
覆蓋指兩個或多個函數的參數類型,順序和數量以及返回值完全一樣。
Javascript真的有這種特性么?
回答是JS中函數重名只會采用最后一個定義。
首先來看下下面的代碼
復制代碼 代碼如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
</HEAD>
<SCRIPT LANGUAGE="JavaScript">
<!--

    
    //展現結果
    function showResult(result) {
        var showDiv = document.getElementById('result');
        showDiv.innerHTML = '';
        showDiv.innerHTML = result;
    };
    //展現結果2
    function showResult2(result) {
        var showDiv = document.getElementById('result2');
        showDiv.innerHTML = '';
        showDiv.innerHTML = result;
    };
    //展現結果3
    function showResult3(result) {
        var showDiv = document.getElementById('result3');
        showDiv.innerHTML = '';
        showDiv.innerHTML = result;
    };
    //測試同名方法
    function testFun() {
        showResult('this is a function named /'testFun/' with no arguments.');
    };
    function testFun(arg) {
        showResult('this is a function named /'testFun/' with one argument,the argument is '+arg);
    };
    //2th測試,交換兩個函數的順序
    //測試同名方法
    function testFun2(arg) {
        showResult2('this is a function named /'testFun2/' with one argument,the argument is '+arg);
    };
    function testFun2() {
        showResult2('this is a function named /'testFun2/' with no arguments.');
    };
    //3th測試,測試覆蓋,同名同參數
    function testFun3() {
        showResult3('this is a function named /'testFun3/' first.');
    };
    function testFun3() {
        showResult3('this is a function named /'testFun3/' second.');
    };
//-->
</SCRIPT>
<BODY>
<div>
    <input type='button' onclick='testFun();' value='function with no arguments'/></br>
    <input type='button' onclick="testFun('test');" value='function with one argument test'/>
</div>
<div id="result"></div>
<hr>2th test <hr>
<div>
    <input type='button' onclick='testFun2();' value='function with no arguments'/></br>
    <input type='button' onclick="testFun2('test');" value='function with one argument test'/>
</div>
<div id="result2"></div>
<hr>3th test <hr>
<div>
    <input type='button' onclick='testFun3();' value='test function share the same name and arguments.'/></br>
</div>
<div id="result3"></div>
</BODY>
</HTML>

首先按名為 function with no arguments 的按鈕

頁面的結果為 this is a function named 'testFun' with one argument,the argument is undefined
然后按名為 function with one argument test 的按鈕
頁面的結果為 this is a function named 'testFun' with one argument,the argument is test
然后按名為 function with no arguments 的按鈕
頁面的結果為 this is a function named 'testFun2' with no arguments.
然后按名為 function with one argument test 的按鈕
頁面的結果為 this is a function named 'testFun2' with no arguments.

從以上的測試中我們發現我們只是點換了兩個函數的定義順序,結果大不相同。
從上面的測試中我們可以得出結論: 重載的話,只要函數定義在下面就會覆蓋上面的函數定義。
好了,接下來看覆蓋。
按名為 test function share the same name and arguments. 的按鈕

頁面的結果為 this is a function named 'testFun3' second.
測試結果很明顯,結論也是和上面相同的。
最終,我們得出結論:
方法重名,JS會以最后定義的函數作為函數體。當然這不包括JS中的繼承中的覆蓋。
歡迎拍磚

JavaScript技術js 覆蓋和重載 函數,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 色宅男看片午夜大片免费看 | 在线自拍综合亚洲欧美 | 麻豆久久国产亚洲精品超碰热 | 少妇性饥渴BBBBBBBBB | 在线免费中文字幕 | 韩国女人高潮嗷嗷叫视频 | 大乳牛奶女magnet | 456亚洲人成在线播放网站 | 漂亮的保姆5电影免费观看完整版中文 | 无人区乱码区1卡2卡三卡在线 | 国产AV精品一区二区三区漫画 | 日本三区四区免费高清不卡 | 亚洲成年男人的天堂网 | 男女免费观看在线爽爽爽视频 | 巨胸美乳中文在线观看 | xiao776唯美清纯 | 国产精品一区二区AV白丝在线 | 无码人妻精品一区二区蜜桃在线看 | 青青草狠狠干 | 男女作爱在线播放免费网页版观看 | 最近最新中文字幕MV高清在线 | 青青久久网 | 欧美91精品久久久久网免费 | 伊人久久精品99热超碰 | 在线欧美 精品 第1页 | 亚洲视频第二页 | 嘴巴舔着她的私处插 | 嗯啊快停下我是你老师啊H 嗯啊快拔出来我是你老师视频 | 国产 在线 亚洲 欧美 动漫 | 扒开双腿疯进出爽爽爽动态图 | 一级毛片免费下载 | 国产成人无码一区AV在线观看 | 中文字幕专区高清在线观看 | 精品国产午夜肉伦伦影院 | 久久日韩精品无码一区 | yellow片在线观看免费观看动漫 | 黄页网址大全免费观看 | 国产综合视频在线观看一区 | 消息称老熟妇乱视频一区二区 | 色多多污网站在线观看 | 男女免费观看在线爽爽爽视频 |