jq回調函數、jq一個函數執行完畢后再執行另一個函數


jq回調函數第一版

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
    </head>
    <body>
        <div class="div" style="width: 200px;height: 200px;background: red;"></div>
        <script type="text/javascript" src="../js/jquery-1.12.4.js" ></script>
        <script>
            $(".div").on('click',function(){
                auto(a);//參數就是個回調函數
            });
            /*點擊之后調用的函數*/
            function  auto(callback){
                alert('1')
                callback&&callback();
            }
            /*回調函數*/
            function a(){
                alert('我是點擊之后的回調函數')
            }
        </script>
    </body>
</html>

 

jq回調函數第二版

<!DOCTYPE html>
<html>

    <head>
        <meta charset="UTF-8">
        <title></title>
        <style>
            .div {
                width: 100px;
                height: 100px;
                background-color: red;
            }
        </style>
    </head>

    <body>
        <div class="div"></div>
        <script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
        <script type="text/javascript">
            $(".div").on('click', function() {
                a(b);
            })

            function a(callBack) {
                $(".div").css('background', 'yellow')
                /*重點 定時器加以區分*/
                setTimeout(function() {
                    callBack && callBack();
                }, 1000);

            }

            function b() {
                $(".div").css('background', 'green')
            }
        </script>
    </body>

</html>

jq一個函數執行完畢后再執行另一個函數利用返回值

<!DOCTYPE html>
<html>

    <head>
        <meta charset="UTF-8">
        <title></title>
        <style>
            .div {
                width: 100px;
                height: 100px;
                background-color: red;
            }
        </style>
    </head>

    <body>
        <div class="div"></div>
        <script src="http://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js"></script>
        <script type="text/javascript">
            var  off=false;
            $(".div").on('click', function() {
                console.log('a函數執行之前'+off+'')
                a();
                console.log('a函數執行完畢'+off+'')
                
                if(off){
                    console.log('a函數執行完畢執行b函數'+off+'')
                    b();
                }
            })

            function a() {
                $(".div").css('background', 'yellow')
                off=true;
            }

            function b() {
                $(".div").css('background', 'green')
            }
        </script>
    </body>

</html>

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM