php – 使用AJAX更新记录而无需刷新表单
我正在尝试更新数据库中的记录而不刷新表单.我有grid.php页面,用于显示和更新记录的表单.然后,我有UPDATE查询的文件update.php.第三个文件是带有 AJAX代码的js1.js.如果我通过action = update.php将grid.php映射到update.php,则更新查询效果很好.但是一旦我尝试包含js1.js文件以防止表单刷新,它就会停止工作. 代码如下: grid.php <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script> <script src="j1.js"></script> <?php //query.php require_once 'header.php'; if (!$loggedin) die(); $query = "SELECT SpringMgmt.SpringMgmtID,SpringMgmt.SpringMgmtActiveYear,SpringMgmt.PoolID,SpringMgmt.Notes,SpringMgmt.SOIEstSubmitted,SpringMgmt.EstAdditional,SpringMgmt.SOIMeetingScheduled,Pool.Pool,Pool.AreaManager,Employees.EmployeeID,Employees.FirstName FROM SpringMgmt INNER JOIN Pool ON SpringMgmt.PoolID = Pool.PoolID INNER JOIN Employees ON Employees.EmployeeID = Pool.AreaManager "; $result = mysql_query($query); echo "OK</div>"; if (!$result) die ("Database access failed0: " . mysql_error()); //TABLE AND ITS HEADING echo '<table id="header" cellpadding="0" cellspacing="0" border="0" >'; echo " <tr> <th>Pool</th> <th>Notes</th> <th>SO Sent</th> <th>Est</th> <th>Meet Date</th> </tr> "; while($record = mysql_fetch_array($result)){ echo "<form id='myForm' name='myForm' method=post>"; echo "<tr>"; echo "<td >$record[Pool]</td>"; echo "<td ><textarea size=4 name=Notes rows=3 cols=22>$record[Notes]</textarea> </td>"; echo "<td style=background-color:><input type=text size=3 name=SOIEstSubmitted value='$record[SOIEstSubmitted]' /></td>"; echo "<td ><textarea size=4 name=EstAdditional rows=3 cols=12>$record[EstAdditional]</textarea></td>"; echo "<td style=background-color:><input type=text size=3 name=SOIMeetingScheduled value='$record[SOIMeetingScheduled]' /></td>"; echo "<td> <input type=hidden name='SpringMgmtID' value=$record[SpringMgmtID] /> <input type=submit name='submit' id='submit' value='Submit' /> </div></td>"; echo "</tr>"; echo "</form>"; } echo "</table>"; ?> update4.php: <?php require_once 'header.php'; if (!$loggedin) die(); if(isset($_POST['submit'])){ $UpdateQuery = "UPDATE SpringMgmt SET Notes='$_POST[Notes]',SOIEstSubmitted='$_POST[SOIEstSubmitted]',EstAdditional='$_POST[EstAdditional]',SOIMeetingScheduled='$_POST[SOIMeetingScheduled]' WHERE SpringMgmtID='$_POST[SpringMgmtID]'"; mysql_query($UpdateQuery); }; ?> js1.js $(function () { $('form').on('submit',function (e) { e.preventDefault(); $.ajax({ type: 'post',url: 'update4.php',data: $('form').serialize(),success: function () { alert('form was submitted'); } }); }); });披露:我可能听起来令人难以置信的光顾,甚至在我的回答中,请注意,这不是我的意图.我将向您展示如何解决该问题,但首先让我添加一些关于上述代码的注释以及一些建议: >你的HTML结构不好:一个表单不应该包装每个tr,你应该考虑使用div而不是表格,或者“在一个单元格内的表格里面”(代码看起来像听起来一样丑陋) ).您可以在此处阅读有关类似案例的更多信息:Create a HTML table where each TR is a FORM >有多个具有相同ID的元素(循环创建的所有表单). 最后,解决方案.我希望你没有跳过上面的所有文字并直接跳到这里,因为它不仅会对你现在有所帮助,而且将来会有所帮助. 更改这两件事,您的代码将起作用(均在js1.js中): >将函数包装在$(document).ready中,以便在页面加载完成后执行. js1.js的最终代码如下所示: $(document).ready(function () { $('form').on('submit',function (e) { e.preventDefault(); $.ajax({ type: 'post',data: $(this).serialize(),success: function () { alert('form was submitted'); } }); }); }); (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |