《Java从入门到放弃》入门篇:Struts2的基本数据传递方式

把这个和JSP的数据传递方式对比一下,你就会发现·······真的可以少写两句代码!!!

struts2中常用的两种数据传递方式如下:

  1. 属性匹配方式
  2. ModelDriven接口匹配方式(常用于自定义类型)

个人比较喜欢使用第一种,为什么呢?因为············懒~~~~~。

接下来,有请代码君登场!!!

一、属性匹配方式

    属性匹配又分为两种情况,一种是Java基本数据类型,一种是自定义类型,请Look下面的Code。

    1.1)自定义一个Singer类,包含3个属性(singerID,singerName,area),代码如下

public class Singer {
	private int singerID;		//歌手ID
	private String singerName;	//歌手姓名
	private String area;		//所属地区
	public int getSingerID() {
		return singerID;
	}
	public void setSingerID(int singerID) {
		this.singerID = singerID;
	}
	public String getSingerName() {
		return singerName;
	}
	public void setSingerName(String singerName) {
		this.singerName = singerName;
	}
	public String getArea() {
		return area;
	}
	public void setArea(String area) {
		this.area = area;
	}
}

    1.2)在前面定义的Action类中添加两个属性(msg和singer),并修改add方法

public class Hello extends ActionSupport {
	private String msg;       //基本类型
	private Singer singer;    //自定义类型

	public String getMsg() {
		return msg;
	}
	public void setMsg(String msg) {
		this.msg = msg;
	}
	public Singer getSinger() {
		return singer;
	}
	public void setSinger(Singer singer) {
		this.singer = singer;
	}

	// 默认调用
	@Override
	public String execute() throws Exception {
		System.out.println("默认调用的方法!");
		return SUCCESS;
	}
	// 添加
	public String add() {
		System.out.println("调用了添加的方法!");
		System.out.println("编号:"+singer.getSingerID());
		System.out.println("姓名:"+singer.getSingerName());
		System.out.println("地区:"+singer.getArea());
		System.out.println("留言:"+msg);

		return "add";
	}
}

    1.3)编写添加歌手的JSP页面(前面的singer_add.jsp),注意看代码中表单元素的name属性中基本类型和自定义类型的区别(singer就是上面Action中的singer属性)

    <body>
  	<!-- 提交给前面配置的通配符方式的Action -->
  	<form action="smng_add.action" method="post">
  		编号:<input type="text" name="singer.singerID" value="9527" /><br />
  		姓名:<input type="text" name="singer.singerName" value="小马哥" /><br />
  		地区:<select name="singer.area">
  			<option>大陆</option>
  			<option selected="selected">香港</option>
  			<option>台湾</option>
  			</select><br />
  		留言:<input type="text" name="msg" value="好酷啊!" /><br />
  		<input type="submit" value="提交" />
  	</form>
    </body>

1.4)因为该JSP页面放在WEB-INF下面,不能直接访问,所以再在struts.xml中配置一个访问Action

<action name="singeradd" class="">
    <result>/WEB-INF/jsp/singer_add.jsp</result>
</action>

1.5)接下来就可以访问http://localhost:8080/strDemo/singeradd.action点击提交看效果了, 是不是很简单!!!



二、ModelDriven接口方式

这种方式与属性方式最大的区别就是自定义类型不用封装,而是通过实现该接口来进行自动赋值,请看下面代码。(主要是Action类不一样,另外JSP页面的name属性也不需要加对象名了)

2.1)修改Action类

public class Hello extends ActionSupport implements ModelDriven<Singer> {

	private String msg;

	//不用封装get和set,但必须实例化,否则报空指针异常
	private Singer singer = new Singer();	

	public String getMsg() {
		return msg;
	}

	public void setMsg(String msg) {
		this.msg = msg;
	}

	// 默认调用
	@Override
	public String execute() throws Exception {
		System.out.println("默认调用的方法!");
		return SUCCESS;
	}
	// 添加
	public String add() {
		System.out.println("调用了添加的方法!");
		System.out.println("编号:"+singer.getSingerID());
		System.out.println("姓名:"+singer.getSingerName());
		System.out.println("地区:"+singer.getArea());
		System.out.println("留言:"+msg);

		return "add";
	}
	//下面是实现接口后的新增代码
	@Override
	public Singer getModel() {
		// TODO Auto-generated method stub
		return singer;
	}
	public void setModel(Singer singer){
		this.singer = singer;
	}

}

2.2)修改JSP页面(注意与前面的JSP页面对比表单元素的name值,这儿直接写singer对象的属性名)

    <body>
  	<!-- 提交给前面配置的通配符方式的Action -->
  	<form action="smng_add.action" method="post">
  		编号:<input type="text" name="singerID" value="9527" /><br />
  		姓名:<input type="text" name="singerName" value="小马哥" /><br />
  		地区:<select name="area">
  			<option>大陆</option>
  			<option selected="selected">香港</option>
  			<option>台湾</option>
  			</select><br />
  		留言:<input type="text" name="msg" value="好酷啊!" /><br />
  		<input type="submit" value="提交" />
  	</form>
    </body>

OK,最终的效果是一模一样,今天的内容就到这儿,感谢各位看官。

这些入门级的东西,应该还没有出现要放弃的客官吧,如果还看得过眼,请点个赞

时间: 2024-10-21 16:07:37

《Java从入门到放弃》入门篇:Struts2的基本数据传递方式的相关文章

Vue.js2.0从入门到放弃---入门实例

最近,vue.js越来越火.在这样的大浪潮下,我也开始进入vue的学习行列中,在网上也搜了很多教程,按着教程来做,也总会出现这样那样的问题(坑啊,由于网上那些教程都是Vue.js 1.x版本的,现在用Vue.js 的构建工具都已经升级到2.0版本了),经过了一段时间的摸索和看官方的教程和api,才了解到2.0版本在1.0版本的基础上做了好多调整,废弃了好多api...废话不多说了,把我踩过的坑,在这里跟大家说说,希望对初学者有所帮助.ps:高手请绕道. 既然是入门实例,那肯定从最基础的开始了,希

转-Vue.js2.0从入门到放弃---入门实例(一)

http://blog.csdn.net/u013182762/article/details/53021374 标签: Vue.jsVue.js 2.0Vue.js入门实例Vue.js 2.0教程 2016-11-03 14:40 21431人阅读 评论(9) 收藏 举报 版权声明:本文为博主原创文章,未经博主允许不得转载. 目录(?)[+] 最 近,vue.js越来越火.在这样的大浪潮下,我也开始进入vue的学习行列中,在网上也搜了很多教程,按着教程来做,也总会出现这样那样的问题(坑啊, 由

vue.js 2.0 从入门到放弃 --- 入门案例(一)

最近,vue.js越来越火.在这样的大浪潮下,我也开始进入vue的学习行列中,在网上也搜了很多教程,按着教程来做,也总会出现这样那样的问题(坑啊,由于网上那些教程都是Vue.js 1.x版本的,现在用Vue.js 的构建工具都已经升级到2.0版本了),经过了一段时间的摸索和看官方的教程和api,才了解到2.0版本在1.0版本的基础上做了好多调整,废弃了好多api...废话不多说了,把我踩过的坑,在这里跟大家说说,希望对初学者有所帮助.ps:高手请绕道. 既然是入门实例,那肯定从最基础的开始了,希

mysql从入门到放弃-入门知识介绍

数据库在互联网网站的重要性 简单地说,数据库就是一个存放数据的仓库,这个仓库是按照一定的数据结构来组织和存储的,我们可以通过数据库提供的多种方法来管理数据库里的数据.由于数据库不易扩展,所以,在一个互联网网站里,它的瓶颈必然是数据库. 数据库的种类 在当今的互联网中,最常用的数据库模型主要有两种:1)关系型数据库:2)非关系型数据库(NOSQL).

《Java从入门到放弃》文章目录

转眼半个月过去了,不知不觉也写了10篇博客,突然发现所有的目录都没有纯列表的展示,所以特意写一个目录篇,来记录该系列下所有的文章. 当然,因为现在还没有写完,所以先按时间顺序排列,等相关内容都写完后,再按学习顺序来整理. <Java从入门到放弃>入门篇:XMLHttpRequest的基本用法 <Java从入门到放弃>入门篇:Struts2的基本访问方 <Java从入门到放弃>入门篇:Struts2的基本访问方式(二) <Java从入门到放弃>入门篇:Stru

JavaScript从入门到放弃之补充篇

上回说到,基础之篇,看久必新,新久必看. 这回我们来说说除了基础篇之外的一些花里胡哨的东西. 数组 以字面量方式创建数组 //字面量方式创建 var colors = ['red','white','black'] console.log(colors) 输出结果如下: 使用构造函数创建 // 使用构造函数创建数组 var heroes = new Array(); heroes[0] = 'Marvelous'; heroes[1] = 'Riven'; heroes[2] = 'Lee Si

Linux从入门到放弃、零基础入门Linux(第四篇):在虚拟机vmware中安装centos7.7

如果是新手,建议安装带图形化界面的centos,这里以安装centos7.7的64位为例 一.下载系统镜像 镜像文件下载链接https://wiki.centos.org/Download 阿里云官网:https://mirrors.aliyun.com 现更新为:https://opsx.alibaba.com/mirror 清华软件镜像:https://mirrors.tuna.tsinghua.edu.cn/ 都可以, 下载centos7.7的64位版本镜像文件种子,然后用下载软件下载即可

iOS 即时通讯,从入门到 “放弃”?

原文链接:http://www.jianshu.com/p/2dbb360886a8 本文会用实例的方式,将 iOS 各种 IM 的方案都简单的实现一遍.并且提供一些选型.实现细节以及优化的建议. —— 由宇朋Look分享 前言 本文会用实例的方式,将iOS各种IM的方案都简单的实现一遍.并且提供一些选型.实现细节以及优化的建议. 注:文中的所有的代码示例,在github中都有demo:iOS即时通讯,从入门到“放弃”?(demo)可以打开项目先预览效果,对照着进行阅读. 言归正传,首先我们来总

NDK开发 从入门到放弃(七:Android Studio 2.2 CMAKE 高效NDK开发)

前言 之前,每次需要边写C++代码的时候,我的内心都是拒绝的. 1. 它没有代码提示!!!这意味着我们必须自己手动敲出所有的代码,对于一个新手来说,要一个字母都不错且大小写也要正确,甚至要记得住所有的jni函数等,真是太折磨人了-平时写java代码的时候都是写几个字母会出来一大堆提示然后选择的,这样还有一个好处就是很多时候我们不知道有那些函数,但是我们可以通过obj.,然后就可以看到它有哪些方法函数了. 2. 很多地方会显示为红色,就像是错误提示的那种,当然,如果没错的话还是能编译运行的,但是如