3

この例では、非推奨であることはわかっている 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
});
4

1 に答える 1

1
<script>
  $('#contForm').submit(function()
  {
    var formData = $(this).serialize();            // Stores all form data in AJAX variable
    $.post('contact.php',formData, function(data)
    {
      console.log(data);
      if(data)
      {
        $('#main').html('<div>You have been added to the mailing list</div>');
      }
      else
      {
        $('#main').append('<div id="fail" style="color:red";>This email address is already subscribed to our mailing list</div>');
      }
      console.log(data);
    });
    return false;    // Stops form from loading contact.php page
  });
</script>

次に、contact.php に以下の関数を配置する必要があります。

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;
  }
}

contact.php のコードが実行されたら、dispAdd関数を呼び出して、結果をdispAddAjax リクエストに返します。

于 2013-03-16T17:37:41.563 に答える