簡體   English   中英

如何更新按鈕上已更改的數據?

[英]How can I update changed data on button?

我想通過在文本框中輸入新值(例如他的名字)來編輯用戶的數據,並在個人資料中顯示這些更改。 我嘗試使用Ajax,但我不明白該在其中輸入url。 那是我的帶有編輯表單和Ajax腳本的jsp文件:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib  uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<script type="text/javascript">
    $("edit").click(function() {
        var firstName = $(request.getParameter("firstname")).val();
        $.ajax({
            url: '',
            type: 'POST',
            data: {
                firstName: firstName
            }
        });
    });
</script>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>${title}</title>
</head>
<body>
<h4>To edit your information fill the fields, please.</h4>
    <form name='f' action="${pageContext.request.contextPath}/j_spring_security_check" method='POST'>
      <table>
         <tr>
            <td>First Name:</td>
            <td><input type='text' name='firstname' id='firstname' value='${firstname}'></td>
         </tr>
         <tr>
            <td><input name="edit" type="submit" value="Submit" /></td>
         </tr>      
      </table>
    </form> 

我有一個類的名字的更新和獲取方法:

public class UserInfoDAOImpl extends JdbcDaoSupport implements UserInfoDAO {    
    @Autowired
    public UserInfoDAOImpl(DataSource dataSource) {
        this.setDataSource(dataSource);
    }    
//.....other methods

@Override
public void editFirstName(String userName, String fName){
    String sql = "update Users set FirstName = ? where Username = ?";
    Object[] params = new Object[] {fName, userName};
    this.getJdbcTemplate().update(sql, params);
}

@Override
    public String getFirstName(String userName) {
        // TODO Auto-generated method stub      
        String sql = "select u.FirstName from Users u where u.Username = ? "; 
        Object[] params = new Object[] { userName };         
        String firstName = (String)getJdbcTemplate().queryForObject(sql, params, String.class);
        return firstName;
    }
}

因此,我實際上並沒有使用這些已編寫的方法來更新數據並在用戶配置文件中進行這些更改。 我是Ajax的新手,因此很高興獲得任何幫助。

您在JSP上輸入的錯誤, j_spring_security_check是Spring URL的默認URL。

為了更新名字,您必須在處理Ajax請求的Controller上執行@RequestMapping @ResponseBody

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM