使用jQuery 和PHP 序列化並提交表單
問題:儘管使用jQuery 序列化表資料,但數據未到達伺服器。
HTML表單:
<code class="html"><form id="contactForm" name="contactForm" method="post"> <input type="text" name="nume" size="40" placeholder="Nume"> <input type="text" name="telefon" size="40" placeholder="Telefon"> <input type="text" name="email" size="40" placeholder="Email"> <textarea name="comentarii" cols="36" rows="5" placeholder="Message"></textarea> <input id="submitBtn" type="submit" name="submit" value="Trimite"> </form></code>
JavaScript:
<code class="javascript">$("#contactForm").submit(function(e) { e.preventDefault(); // Prevent browser submission $.post("getcontact.php", $("#contactForm").serialize()) .done(function(data) { // Process server response }); });</code>
<code class="php">$nume = $_POST["nume"]; $email = $_POST["email"]; $telefon = $_POST["telefon"]; $comentarii = $_POST["comentarii"];</code>
問題解決方案:
<code class="javascript">$.ajax({ type: "POST", url: "getcontact.php", data: $("#contactForm").serialize(), dataType: "json", success: function(data) { // Process server response }, error: function() { // Handle errors } });</code>問題是由於使用$.post() 中的傳輸方法選項(在jQuery 3.0 中已棄用)而引起的。相反,請使用帶有以下設定的$.ajax():
以上是為什麼我的 jQuery 序列化表單資料無法到達 PHP 伺服器?的詳細內容。更多資訊請關注PHP中文網其他相關文章!