Кнопка многократной отправки в Struts 1.3 - PullRequest
5 голосов
/ 12 сентября 2011

У меня есть этот код в моем JSP:

<%@taglib uri="http://struts.apache.org/tags-html" prefix="html"%>
..
..
<html:form action="update" >
  ..
  ..
  <html:submit value="delete" />
  <html:submit value="edit" />
  <html:sumit value="update" />
</html:form>

И это в struts-config.xml файле:

<action path="/delete" name="currentTimeForm" input="/viewall.jsp" type="com.action.DeleteProduct">
   <forward name="success" path="/viewall.jsp" />
   <forward name="failure" path="/viewall.jsp" />
</action>

Как и у действия delete, у меня есть editи update.Он работает нормально, если я назову имя, например, <html:form action="delete">, но как заставить его динамически работать для update и edit?

Ответы [ 2 ]

19 голосов
/ 12 сентября 2011

У вас есть одна форма и несколько кнопок отправки. Проблема заключается в том, что форма может отправляться только на одно действие, независимо от того, сколько кнопок отправки у вас внутри формы.

На ум приходят три решения:

1. Есть только одно действие, в котором вы отправляете все. Оказавшись внутри класса Action, проверьте, какая кнопка использовалась для отправки формы, и выполните соответствующую обработку на основании этого.

<html:form action="modify">
  ..
  ..
  <html:submit value="delete"/>
  <html:submit value="edit" />
  <html:sumit value="update" >
</html:form>

В методе ModifyAction.execute(...) есть что-то вроде:

if (request.getParameter("delete") != null || request.getParameter("delete.x") != null) {
   //... delete stuff
} else if (request.getParameter("edit") != null || request.getParameter("edit.x") != null) {
   //...edit stuff
} else if (request.getParameter("update") != null || request.getParameter("update.x") != null) {
   //... update stuff
}

2. Перед отправкой формы измените атрибут действия формы HTML с помощью JavaScript. Сначала вы изменяете кнопки отправки на простые с прикрепленными обработчиками кликов:

<html:form action="whatever">
  ..
  ..
  <html:button value="delete" onclick="submitTheForm('delete.do')" />
  <html:button value="edit" onclick="submitTheForm('edit.do')" />
  <html:button value="update" onclick="submitTheForm('update.do')" />
</html:form>

С обработчиком:

function submitTheForm(theNewAction) {
  var theForm = ... // get your form here, normally: document.forms[0]
  theForm.action = theNewAction;
  theForm.submit();
}

3. Используйте DispatchAction (один класс действий, аналогичный пункту 1), но без необходимости проверять, какая кнопка была нажата, поскольку она обрабатывается DispatchAction ,

Вы просто предоставляете три метода исполнения с именами delete, edit и update. Вот пример, который объясняет, как вы можете это сделать .

В заключение: Для номера 1 мне не очень нравятся эти уродливые тесты ... для номера 2 мне не очень нравится тот факт, что вы должны играть с формой действия используя JavaScript, поэтому я бы лично пошел на номер 3 .

0 голосов
/ 27 мая 2013

Существует еще один более простой способ сделать это следующим образом:

В ActionForm currentTimeForm добавить свойство String (пример: buttonClicked).

В jsp в каждом html-файле: submit тэги добавляют это свойство.

Теперь в действии метод execute просто проверяет значение этого свойства, т. е.

if(currentTimeForm.getButtonClicked().equals("delete"){
}
else if((currentTimeForm.getButtonClicked().equals("edit"))

и так далее ...

...