如,登陆表单login.jsp:
<form action="login" method="post" name="form1">
用户名:<s:textfield name="username"/><br/>
密 码:<s:password name="password"/><br/>
<s:submit value="提交"/>
</form>
1.在Action类中定义表单属性,两者属性名称必须一致。提供setter,getter方法。即可接收到表单传过来的参数.
这种接收参数的方法,方便简单,但是结构性不是很好,且当表单传递来的参数很多的时候,整个Action类中充斥着setter,getter方法,程序结构不是很美观。
2.把表单传递过来的参数封装成一个类,然后调用其中的属性. 如,把login.jsp页面要传来的参数进行封装
Private String username
private String password
public String
getUsername() { return username}
public void setUsername(Stringusername) { this.username = username}
public String getPassword(){ return password}
public void setPassword(String password) {this.password = password}
然后再Action方法中,定义该类的对象就可以了,
如 public class loginAction extends ActionSupport{
private Users users
Public Users getUsers(){ return users}
public void setUsers(Users users){ this.users=users} }
通过这种方法传值,还必须在jsp页面做一下处理,login.jsp中from1的属性名应该改成这样: 登陆表单login.jsp:
<form action="login" method="post" name="form1">
用户名:<s:textfield name="users.username"/><br/>
密 码:<s:password name="users.password"/><br/>
<s:submit value="提交"/>
</form>
这种方法,在struts开发中是很常用的一种方法!
3.通过实现ModelDriven接口接收表单数据(还没有用过,可以尝试。)
首先Action类必须实现ModelDriven接口,同样把表单传来的数据封装起来,Action类中必须实例化该对象,并且要重写getModel()方法
public class loginAction extends ActionSupport implements
ModelDriven<Users>{
private Users users =new Users()
public Users getModel(){ return users}
}
点击之后处理?
添加方法即可啊
<!DOCTYPE html><html>
<head>
<meta charset="UTF-8">
<script src="https://cdn.bootcss.com/jquery/2.0.0/jquery.js"></script>
<title></title>
</head>
<body>
<form id="submitForm" action="#">
<input value="123" type="text" class="val" id="val1" /><br />
<input value="234" type="text" class="val" id="val2" /><br />
<input value="345" type="text" class="val" id="val3" /><br />
<input value="456" type="text" class="val" id="val4" /><br />
</form>
<button onclick="submitMethod()">提交</button>
</body>
<script>
function submitMethod(){
//封装数组
$(".val").val("1")
//提交表单
$("#submitForm").submit()
}
</script>
</html>
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)