この例では、非推奨であることはわかっている MySQL を使用していますが、これは単なる学習目的です。私はPDOの使い方も学んでいますが、今はPDOの経験が浅いために台無しにしたくないので、現在mysqlを使用しています。
わかりましたので、フォーム データを PHP 関数ページに送信する jQuery AJAX 関数があります。次に、PHP ページはデータベースと通信し、結果を返します。これまでのところ、これはすべて機能します。
ユーザーが自分の電子メール アドレスを提供するフォームに入力します。電子メールは PHP ページに渡され、DB に入力されます。ユーザーが存在する場合は、既に購読していることを知らせるメッセージが表示されます。存在しない場合は追加され、正常に追加されたことを示すメッセージが表示されます。良いニュースは、このすべてがうまく機能することです!
今、私が問題を抱えているのは、同じコールバック関数「dispAdd」の間に、自動化されたウェルカム メールをユーザーに生成したいということです。メール呼び出しをどのようにコーディングしようとしても、関数でエラーが発生するようです。私は今持っているものをあなたにあげるつもりですが、誰かがそれを助けることができれば、非常に感謝しています.
他のすべての部分は今のところ問題なく動作するため、これが私のコールバック関数です。
function dispAdd() // Serves as callback function to jQuery/AJAX in contact.html
{
$sql= "SELECT * FROM mailList WHERE email = '$email'";
$result= mysql_query($sql) or die(mysql_error());
$to = "rmailloux11@mail.bristol.mass.edu";
$who = "ME";
$message = "WOW";
$subject = "TESTING";
$message = $who . ', ' . $message;
$headers = "From: rmailloux11@mail.bristol.mass.edu" . "\r\n";
if(mysql_num_rows($result) > 0) // Checks to see if query returns any info for the calling function
{
mail($to,$subject,$message,$headers);
while ( $row = mysql_fetch_assoc($result))
return;
}
}
元のコール:
$('#contForm').submit(function() {
var formData = $(this).serialize(); // Stores all form data in AJAX variable
$.post('contact.php',formData,dispAdd);
function dispAdd(result) { // Callback function requests result of RESULT
if (!result) {
$('#main').html('<div>Your have been added to the mailing list</div>');
} else {
if ($('#fail').length==0) {
$('#main').append('<div id="fail" style="color:red";>This email address is already subscribed to our mailing list</div>');
}
}
}
return false; // Stops form from loading contact.php page
});