jQuery / Javascript - “不是函数错误”但定义了函数

时间:2013-05-05 08:19:41

标签: javascript jquery ajax timer

嗨,我有这段代码:

<script type="text/javascript" src="jquery.js"></script>
    <script type="text/javascript">

    $(function(){
        $('#invite').on('click',function(){
            if(!$('#invite').hasClass('disabled') ){
                invite($("#email").val());
            }
        });
        $('#email').on('keyup',function(e){
            if(e.which == 13 && !$('#invite').hasClass('disabled') ){
                invite($("#email").val());
            }
        });


    });
    function loading(){

        window.loading = setInterval(function(){
        $(".logo img").fadeTo(500,0.1).fadeTo(550,1);
    },1600); 

    }
    function unloading(){
      $('.logo img').fadeTo(0,1);
      clearTimeout(window.loading);
    }
    function invite(_email){
        $.ajax({
            type:'POST',
            url:_config_base_url+'/invite/get_invite',
            data:{email:_email},
            dataType:'json',
            error:function(){
                unloading();
                $("#invite").removeClass('disabled');
               notify("Sorry an error occured, please try again later",2000);
                $("input").focusout();
            },
            beforeSend:function(){
                loading();
                notify_destroy();
                $("#invite").addClass('disabled');
                $("input").focusout();
            },
            success:function(json){
                unloading();
                $('body').trigger('focus');
                $("#invite").removeClass('disabled');

                if(json.error == 'yes'){

                    notify(json.error_message,false,false);
                }else{
                    $("#email").val("");
                    notify(json.confirm_message,false,'notify-info');
                }

                $("input").focusout();
            }

        });
    }
    </script>

当我第一次启动ajax请求时,每件事都很完美。

但是,当我尝试重新启动请求时,它总会返回:“错误:加载不是函数”,所涉及的代码行是这样的:

 beforeSend:function(){
                loading();

我不知道那里发生了什么:/

1 个答案:

答案 0 :(得分:2)

window.loading = setInterval(function(){

在函数loading的上一行中,loading被重新定义为setInterval返回值,因为loading在第一次调用后不再是函数。