主頁 > 知識庫 > ajax跨頁面提交表單

ajax跨頁面提交表單

熱門標(biāo)簽:個人怎樣在百度地圖標(biāo)注地名 地圖標(biāo)注項(xiàng)目怎么樣 硅語電話機(jī)器人公司 越南河內(nèi)地圖標(biāo)注 ai機(jī)器人電銷資源 超級大富翁地圖標(biāo)注 云呼外撥網(wǎng)絡(luò)電話系統(tǒng) 機(jī)器人電銷騙局揭秘 騰訊地圖標(biāo)注位置能用多久

前面提到過重復(fù)提交表單問題,處理token口令校驗(yàn)、重定向之外,還有一種經(jīng)常使用到的方法就是新頁面處理表單提交,完成后關(guān)閉當(dāng)前頁面,并刷新之前發(fā)送請求的頁面。
這里使用了artDialog.js

1、文件結(jié)構(gòu)

2、user.jsp

%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> 
%@ taglib uri="/struts-tags" prefix="s"%> 
%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> 
!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> 
html> 
 head> 
 title>user列表/title> 
  
 meta http-equiv="pragma" content="no-cache"> 
 meta http-equiv="cache-control" content="no-cache"> 
 meta http-equiv="expires" content="0"> 
 script type="text/javascript" src="/MySSH2/jquery-1.7.js">/script> 
 script type="text/javascript" src="/MySSH2/artDialog.js?skin=default">/script> 
 script type="text/javascript"> 
 function openA(){ 
 window.open("/MySSH2/user/manage_addUI"); 
 } 
 /script> 
 /head> 
 body> 
 br/> 
 a href="s:url action="manage_addUI" namespace="/user"/>">添加用戶/a> 
 a href="javascript:void(0)" onclick="openA()">添加用戶/a> 
  br/> 
  用戶列表:br/> 
 s:iterator value="#request.users"> 
 id:s:property value="id"/>br/> 
 name:s:property value="name"/>br/> 
 /s:iterator> 
  
 
 /body> 
/html> 

3、userAdd.jsp

%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> 
%@ taglib uri="/struts-tags" prefix="s"%> 
%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%> 
!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> 
html> 
 head> 
 title>用戶添加/title> 
  
 meta http-equiv="pragma" content="no-cache"> 
 meta http-equiv="cache-control" content="no-cache"> 
 meta http-equiv="expires" content="0"> 
 script type="text/javascript" src="/MySSH2/jquery-1.7.js">/script> 
 script type="text/javascript"> 
 function AddUser(){ 
 var submitData = $('#userForm').serialize(); 
 console.log(submitData); 
 $.ajax({ 
    type : "post", 
    url : "/MySSH2/user/manage_add", 
    cache : false, 
    data: submitData, 
    dataType : 'json', 
    success : function(result) { 
    span style="white-space:pre">  /span>if(result.success){ 
       window.opener.art.dialog({time:2,content:'保存成功'}); 
       setTimeout(function(){window.opener.location.reload();},3); 
      } 
      else{ 
      span style="white-space:pre"> /span> window.opener.art.dialog({time:2,content:'保存失敗'}); 
        setTimeout(function(){window.opener.location.reload();},3); 
       } 
       window.close(); 
      }, 
    error : function(XMLHttpRequest, textStatus, 
      errorThrown) { 
        alert("error"); 
      } 
    }); 
 } 
 /script> 
 /head> 
 
 body> 
 s:form id="userForm" action="manage_add" namespace="/user" method="post"> 
  用戶名:s:textfield name="user.name"/>br/>s:token>/s:token> 
  input type="button" value="保存" onclick="AddUser()"/> 
 /s:form> 
 /body> 
/html> 

4、UserManageAction.java

package com.myssh2.action; 
 
import java.io.IOException; 
import java.io.PrintWriter; 
 
import javax.annotation.Resource; 
import javax.servlet.ServletException; 
 
import org.apache.struts2.ServletActionContext; 
import org.springframework.context.annotation.Scope; 
import org.springframework.stereotype.Controller; 
 
import com.myssh2.bean.User; 
import com.myssh2.service.UserService; 
import com.opensymphony.xwork2.ActionContext; 
import com.opensymphony.xwork2.ActionSupport; 
 
 
@Controller @Scope("prototype") 
public class UserManageAction extends ActionSupport{ 
 @Resource UserService userService; 
 private User user; 
  
 public User getUser() { 
  return user; 
 } 
 
 public void setUser(User user) { 
  this.user = user; 
 } 
 
 public String addUI(){ 
  return "add"; 
 } 
  
 public void add() throws ServletException, IOException{ 
  
  ServletActionContext.getResponse().setContentType("text/html;charset=utf-8");  
  PrintWriter out = ServletActionContext.getResponse().getWriter(); 
  try { 
   userService.addUser(user); 
   ActionContext.getContext().put("message", "保存成功"); 
   out.write("{\"success\":true}"); 
  } catch (Exception e) { 
    e.printStackTrace(); 
    out.write("{\"success\":false,\"msg\":\"error\"}"); 
  } 
 } 
} 

頁面效果

提交表單時使用$('#userForm').serialize();序列化表單數(shù)據(jù)
 window.opener.art.dialog({time:2,content:'保存成功'});則是返回使用window.open的頁面(或者理解為父頁面),并調(diào)用artDialog插件的定時關(guān)閉dialog
setTimeout(function(){window.opener.location.reload();},3);使用定時器刷新使用window.open的頁面(或者理解為父頁面),dialog和reload的時間設(shè)置問題需重新調(diào)整。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • Ajax提交表單時驗(yàn)證碼自動驗(yàn)證 php后端驗(yàn)證碼檢測
  • JS實(shí)現(xiàn)支持Ajax驗(yàn)證的表單插件
  • jquery ajax提交表單數(shù)據(jù)的兩種方式
  • jquery實(shí)現(xiàn)ajax提交form表單的方法總結(jié)
  • jQuery使用ajaxSubmit()提交表單示例
  • JQuery通過Ajax提交表單并返回結(jié)果
  • JQuery打造PHP的AJAX表單提交實(shí)例
  • jquery的ajaxSubmit()異步上傳圖片并保存表單數(shù)據(jù)演示代碼
  • jQuery ajax中使用serialize()方法提交表單數(shù)據(jù)示例
  • jquery序列化form表單使用ajax提交后處理返回的json數(shù)據(jù)

標(biāo)簽:洛陽 內(nèi)蒙古 遼源 舟山 鄭州 海南 林芝 邢臺

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ajax跨頁面提交表單》,本文關(guān)鍵詞  ajax,跨,頁面,提交,表單,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《ajax跨頁面提交表單》相關(guān)的同類信息!
  • 本頁收集關(guān)于ajax跨頁面提交表單的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章