Struts2中表单数据怎样实例化 <input name=user.name>struts实现拿值方法

本文介绍了Struts2框架中的三种数据绑定方式:使用领域对象接收用户输入、使用ModelDriven接口以及直接使用Action属性接收输入。通过示例展示了如何在JSP页面中实现这些绑定方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、使用领域对象来接收用户输入
er对象中包含两个字段:username和password,在Action中有一个User对象user,则在jsp中:

Jsp代码
<input type="text" name="user.username">  
<input type="text" name="user.password"> 

<input type="text" name="user.username">
<input type="text" name="user.password"> 来进行数据绑定。

当Struts2尝试设置user对象的username属性时,将依次调用以下的方法:

Java代码
action.getUser();  
action.setUser(new User());  
action.getUser().setUserName(); 

action.getUser();
action.setUser(new User());
action.getUser().setUserName();Struts2首先尝试获得User对象的引用,当它发现User对象为null时,它将使用User类的默认构造方法创建一个User实例,并调用action的setUser()方法设置这个实例。这样,Struts2就可以设置Usser对象的username字段了。



在Struts2中,自动实例化对象的特性对于任意层次的对象包含关系都是适用的。



例如, user.address.street这样的表达式会调用:

Java代码
getUser().getAdderss().setStreet(...); 

getUser().getAdderss().setStreet(...); Struts2会先创建User对象,接着创建Address对象,然后设置Address对象的street属性。



2、使用ModelDriver action
Java代码
public class LoginAction implements Action, ModelDriven<User> {  
      
    private User user = new User();  
 
    @Override 
    public User getModel() {  
         return user;  
    }  
 


public class LoginAction implements Action, ModelDriven<User> {
   
    private User user = new User();

    @Override
    public User getModel() {
         return user;
    }

} 在jsp页面中:

Jsp代码
<input type="text" name="user.username">  
<input type="text" name="user.password"> 

<input type="text" name="user.username">
<input type="text" name="user.password">

3、使用action的属性接收用户输入
Java代码
public class LoginAction implements Action, ModelDriven<User> {  
 
      private String username;  
      ...  
    

public class LoginAction implements Action, ModelDriven<User> {

      private String username;
      ...
  
<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>健康咨询智能问答</title> <!-- 外部引入Bootstrap框架 --> <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.0-alpha1/dist/css/bootstrap.min.css" rel="stylesheet"> <style> body { background-color: #f9fafb; font-family: 'Arial', sans-serif; } header { background-color: #4CAF50; color: white; padding: 1rem; text-align: center; } form { max-width: 600px; margin: 2rem auto; padding: 1.5rem; border-radius: 8px; box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); background-color: #ffffff; } label { display: block; margin-bottom: 0.5rem; font-weight: bold; } input[type="text"] { width: 100%; padding: 0.75rem; margin-bottom: 1rem; border: 1px solid #ced4da; border-radius: 4px; } button { width: 100%; padding: 0.75rem; background-color: #4CAF50; color: white; border: none; border-radius: 4px; cursor: pointer; transition: background-color 0.3s ease; } button:hover { background-color: #45a049; } h2 { text-align: center; margin-top: 1.5rem; } p { line-height: 1.6; text-align: justify; } </style> </head> <body> <header> <h1>健康咨询智能问答</h1> </header> <main> <form action="/ask" method="post"> <label for="user_input">请输入您的问题:</label> <input type="text" id="user_input" name="user_input" placeholder="例如:如何预防感冒?" required> <button type="submit">提交问题</button> </form> {% if user_input %} <section class="mt-4"> <h2>您提出的问题:</h2> <p>{{ user_input }}</p> {% if answer %} <h2>模型的回答如下:</h2> <p>{{ answer }}</p> {% endif %} </section> {% endif %} </main> </body> </html>基于这个代码 创建一个点击提交按钮后的子窗口
最新发布
05-12
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值