1

$.post()witchがifステートメントを実行するために正しいデータjsonデータを最初に返すときに実行しますが、次に使用$.post()すると誤って返され、ifステートメントが意図したとおりに機能しなくなります。

私の現在のJqueryコード:

$.post('functions/write_settings.php', { dbname: $('#dbname').val(), dbhost: $('#dbhost').val(), dbpassword: $('#dbpassword').val(), dbusername: $('#dbusername').val(), dbprefix: $('#dbprefix').val() }, function(data){
    alert("here");
    try{var returndata = $.parseJSON(data);}catch(e){/*cont*/}
    alert("here1");
      if($(returndata).size() >= 1){
          for(var i = 0; i < $(returndata).size(); i++){
              $("#" + returndata[i]).css('background', 'url(style/install/database/imgs/textbox_error.png)');
          }
          ResetButton();
          alert("here2");
    }else{
        $.post('functions/check_settings.php', function(data){
            alert(data);
            var postdata = data;
            $.trim(postdata);
            if(postdata == 'error'){
                alert("test2");
                $('#pdbe').show();
                $('#pdbe').effect("pulsate", { times:10 }, 10000);
                ResetButton();
            }else if(data == '0'){
                alert('connected!');
            }
        });
    }
});

これはcheck_settings.phpです

$cwd = getcwd();
$file = $cwd.'/dbconfig.php';
//check dbconfig created
if(file_exists($file)){
    include('./dbconfig.php');
}else{
    echo("error2");
    die();
}

//grab required vars
$host = $config['db']['host'];
$dbname = $config['db']['dbname'];

//test basic connection
try{
   $dbh = new PDO("mysql:host=$host;dbname=$dbname", $config['db']['username'], $config['db']['password']);
   $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
}catch(PDOException $e){
   echo("error");
   die();
}
echo("0");

私が言ったように、最初$.post()は正しいデータを返しますが、2回目はそれを使用すると誤って返され、ifステートメントが正しく機能しなくなります。

この問題を修正するための提案をいただければ幸いです。

4

1 に答える 1

1

あなたの問題は余分なスペースですか?その場合、check_settings.phpで、無意識のうちにスペースまたは改行を印刷している可能性があります。たとえば、最初の行の前にスペースまたは改行がある場合があります

于 2012-12-07T21:29:04.473 に答える