请帮忙! - 不推荐使用event.returnValue。请改用标准的event.preventDefault()

时间:2014-03-18 19:10:44

标签: javascript php jquery ajax google-chrome

当我在Google Chrome上使用ajax时,我收到此消息 event.returnValue已弃用。请使用标准的event.preventDefault()代替 我安装了新的G.Chrome和新的jquery库,但它没有生效。 我的代码在Mozilla Firefox中运行良好。 我有jquery代码文件 - edit.php 和动作文件editting.php 编辑代码.php:

 $('#submit').click(function(){  
      //if( this.value == "apl" )  
       var id = $("#inf_id").val();
       var text = $("#text").val();
       var title = $("#title").val();
      $("#imgLoad").show(); // Показываем прелоадер

      //setTimeout('$("#imgLoad").show()', 1000);
         $.ajax({  
                url: "editting.php",  
                type: "POST",
                data: {"inf_id": id,"title": title,"text":text},
                cache: false,  
               success: function(response){ 
               //////////////////////////// 
    alert(response);               
               //////////////////////////////
            if(response == 0){ // Смотрим ответ от сервера и выполняем соответствующее действие
                //alert("Больше нет записей");  
                $("#imgLoad").hide();
                $("#success_div").show();
                $("#alert_div").hide(); 
                $("#empty_infs_div").hide();                    
                setTimeout('$("#success_div").hide();', 2000);  

                $("#empty_text").hide();
                $("#empty_title").hide();                                   
            }else if(response == 1){
                $("#imgLoad").hide();
                $("#success_div").hide();
                $("#alert_div").show(); 
                $("#empty_infs_div").hide();
                setTimeout('$("#alert_div").hide();', 2000);    

                $("#empty_text").hide();
                $("#empty_title").hide();
            } /*else if(response == 2){
                $("#imgLoad").hide();
                $("#success_div").hide();
                $("#empty_infs_div").show();
                $("#alert_div").hide();                         
                setTimeout('$("#empty_infs_div").hide();', 2000);
            }*/

            else if(response == 2 || response == '2'){
                $("#empty_text").hide();
                $("#empty_title").show();

                $("#imgLoad").hide();
                $("#success_div").hide();
                $("#empty_infs_div").hide();
                $("#alert_div").hide(); 
                setTimeout('$("#empty_title").hide();', 2000);
                }
            else if(response == 3){ //if(response == 4)     
                $("#empty_text").show();
                $("#empty_title").hide();

                $("#imgLoad").hide();
                $("#success_div").hide();
                $("#empty_infs_div").hide();
                $("#alert_div").hide(); 
                setTimeout('$("#empty_text").hide();', 2000);
                }

            }//success  
            }); 

        });  

和editting.php:

                <?
            include("site_blocks/bd.php");
            if (isset($_REQUEST['inf_id'])) {$id = $_REQUEST['inf_id']; 
            if ($id == '') {unset($id);}}

            if (isset($_REQUEST['title'])){$title = $_REQUEST['title']; 
            if ($title == '') {unset($title);}}

            if (isset($_REQUEST['text']))  {$text = $_REQUEST['text']; 
            if ($text == '' || $text == '<br>' ) {unset($text);}}

            if (isset($title) && isset($text))
            {
                mysql_query('SET NAMES utf8');ob_clean();
                $update_infs = mysql_query ("UPDATE data SET title='$title',text='$text' WHERE id='$id'");      

                if($update_infs==1) {sleep(1); echo 0;}
                else {sleep(1); echo 1; }
            }

            else 
            {sleep(1);
            if (!isset($title)) {echo 2;}
            else if(!isset($text)) {echo 3;}
            }

            ?>

警报有效,显示结果0,1,2,3。但浏览器Chrome并未对此数字作出反应。 Mozilla的反应和我预期的一样。 有人可以帮帮我吗?非常感谢))

1 个答案:

答案 0 :(得分:1)

  

不推荐使用event.returnValue。请使用标准的event.preventDefault()

只是一个警告(请参阅here),它应该适用于chrome和firefox! 如果它不在chrome中工作,你应该检查你的代码: 例如:

setTimeout('$("#success_div").hide();', 2000); 

应改为

setTimeout($("#success_div").hide(), 2000); 

setTimeout()的第一个参数应该是一个函数(参见here),而不是一个字符串

[edit]纠正了分号剩余

我用jslint检查你的js-code并且有2个主要错误,上面的一个用setTimeout&#34;隐含的eval是邪恶的。传递函数而不是字符串。&#34;和你的条件有一个错误

Expected '===' and instead saw '=='.
line 32 character 33:    } else if (response == 1) {

但是这个不应该使代码不起作用