$.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ステートメントが正しく機能しなくなります。
この問題を修正するための提案をいただければ幸いです。