练习OGNL 与 Struts2的使用(二)
练习OGNL 与 Struts2的使用(二)
继续
使用 OGNL 与 与 Struts2 标签实现学生信息的添加
1.1 添加 stu_add.jsp 页面
在 WebRoot 下添加 stu_add.jsp 页面,修改页面的内容如下
<%@ page language="java" import="java.util.*" pageEncoding="gbk"%>
<%@ taglib uri="/struts-tags" prefix="s" %>
<%@ taglib uri="/struts-dojo-tags" prefix="sx" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title> 添加学生信息</title>
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
<%-- 下面的两名话是实现datetimepicker 的关键 --%>
<s:head theme="xhtml"/>
<sx:head parseContent="true"/>
</head>
<body>
<s:text name=" 在表单控件中输入学生信息 "></s:text>
<s:form action="stu!add">
<s:textfield label=" 学号 " name="stu.stunumber" />
<s:textfield label=" 姓名 " name="stu.stuname" />
<sx:datetimepicker label=" 生日 " toggleType="wipe"
toggleDuration="300" name="stu.birthday" />
<s:submit value=" 添加 " />
</s:form>
</body>
</html>
<span style="color:#FF0000;"><s:head theme="xhtml"/>
<sx:head parseContent="true"/></span>
为什么这两句话是关键呢?这是因为struts2.0到struts2.1有一个重要的改变就是对ajax支持的改变,struts2.0的ajax支持主要以DWR和dojo为主,并专门提供ajax主题,如:<s:head theme="ajax"/>,但是在struts2.1不在提供ajax主题,而将原来的ajax主题放入了dojo插件中,我们需要将dojo标签引入到jsp页面,加上这两句话
<s:head theme="xhtml"/>
<sd:head parseContent="true"/>
运行效果如下图所示:
1.2. 在 在 StudentAction 中添加 add 方法
在 StudentAction 中添加接收的实体类数据,与 Struts1.x 类似,Struts2 也可
以直接接收实体类数据作为属性的值,在 list 方法下面的添加 add 方法,修改后
的类代码如下
package org.sf.action;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import org.apache.struts2.ServletActionContext;
import org.sf.dao.IStudentDao;
import org.sf.dao.impl.StudentDaoImpl;
import org.sf.entity.Student;
import com.opensymphony.xwork2.ActionSupport;
/**
* 学生Action 类
*
*/
@SuppressWarnings("serial")
public class StudentAction extends ActionSupport{
private Student stu = null;
public Student getStu() {
return stu;
}
public void setStu(Student stu) {
this.stu = stu;
}
/**
* 取得学生列表的方法
* @return
*/
public String list(){
IStudentDao stuDao = new StudentDaoImpl();
List<Student> list = stuDao.getAllStudentList();
HttpServletRequest request = ServletActionContext.getRequest();
request.setAttribute("list", list);
return "stu_list";
}
/**
* 添加学生信息的方法
* @return
*/
public String add(){
IStudentDao stuDao = new StudentDaoImpl();
stuDao.addStudent(stu);
list();
return "stu_list";
}
}
1.3. 运行效果
在添加界面,填写如下数据,点击“添加”后,将看到添加结果:
使用国际化资源文件更新 学生信息添加页面
这里使用国际化资源文件更新添加页面,将原来写在程序的硬编码信息,修
改为使用配置文件完成。
2.1. 添加页面 stu_add1.jsp
以 stu_add.jsp 为模板,在 WebRoot 中复制生成 stu_add1.jsp 页面,修改新生
成的 stu_add1.jsp 页面的内容如下:
<%@ page language="java" import="java.util.*" pageEncoding="gbk"%>
<%@ taglib uri="/struts-tags" prefix="s" %>
<%@ taglib uri="/struts-dojo-tags" prefix="sx" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title> 添加学生信息</title>
<!--
<link rel="stylesheet" type="text/css" href="styles.css">
-->
<%-- 下面的两名话是实现datetimepicker 的关键 --%>
<s:head theme="xhtml"/>
<sx:head parseContent="true"/>
</head>
<body>
<s:text name="add.label"></s:text>
<s:form action="stu!add">
<s:textfield key="stunumber.label" name="stu.stunumber" />
<s:textfield key="stuname.label" name="stu.stuname" />
<sx:datetimepicker key="birthday.lable" toggleType="wipe"
toggleDuration="300" name="stu.birthday" />
<s:submit key="btnadd.value" />
</s:form>
</body>
</html>
即将原来的 name、label、value 等信息使用 key 来代替。
2.2. 添加资源文件
在 src 包下添加 messageResource.properties 文件,修改文件的内容如下:
#the text
add.label=Please input student's info
#the form
stunumber.label=stunumber
stuname.label=stuname
birthday.lable=birthday
btnadd.value=add
这里的内容即是页面上的引用内容。
1.3. 修改 struts 的配置文件 struts.xml
在配置文件中添加资源文件的引用,使用常量来进行配置,配置后的关键代
码如下
<struts>
<constant name="struts.custom.i18n.resources" value="messageResource"></constant>
<package name="mypackage" namespace="/" extends="struts-default">
<action name="stu" class="org.sf.action.StudentAction">
<result name="stu_list">/stu_list.jsp</result>
</action>
</package>
</struts>
<span style="color:#FF0000;"><constant name="struts.custom.i18n.resources" value="messageResource"></constant></span>
其中的<constant>为常量配置信息。
2.4. 运行测试
使用:http://localhost:8080/stucourse/stu_add1.jsp 打开页面,将会看到如下效
果
2.5. 添加中文资源支持
在 src 下添加 messageResource_zh_CN.properties 文件,表示支持大陆中文,
使用 MyEclipse 的属性文件编辑器来添加如下的信息, 注意:这种方式可以正常
的认识中文字符,否则会出现乱码。
此时的代码如下:
#the text
add.label=\u8BF7\u8F93\u5165\u5B66\u751F\u4FE1\u606F
#the form
stunumber.label=\u5B66\u53F7
stuname.label=\u59D3\u540D
birthday.lable=\u751F\u65E5
btnadd.value=\u6DFB\u52A0
2.6. 运行效果
此时运行页面,将会看到如下的效果:
1.7. 添加多语言支持
在src下创建一个新的属性文件, 名称为: messageResource_en_US.properties,
即支持美国英语,修改该文件的内容与默认的 messageResource.properties 相同。
即内容如下
#the text
add.label=Please input student's info
#the form
stunumber.label=stunumber
stuname.label=stuname
birthday.lable=birthday
btnadd.value=add
修改浏览器的语言支持,打开工具Internet 选项:
选择“语言” ,打开语言管理对话框,添加一种英语方言
添加完成后,将英语设置为第 1 项:
此时运行系统将会看到英文界面,将中文设置为第 1 项,刷新页面后,将会
看到中文界面。
这就是现在各大型网站能同时支持世界上多种语言, 能被多个地区同时使用
的工作原理
上一篇: 通用 Mapper
下一篇: for之于while的优势
推荐阅读
-
Linux中别名与二进制的使用教程
-
C#_Excel数据读取与写入_自定义解析封装类_支持设置标题行位置&使用excel表达式收集数据&单元格映射&标题映射&模板文件的参数数据替换(第二版-增加深度读取和更新功能)
-
Android上使用ZXing识别条形码与二维码的方法
-
Docker的使用初探(二):Docker与.NET Core的结合
-
PYTHON练习题 二. 使用random中的randint函数随机生成一个1~100之间的预设整数让用户键盘输入所猜的数。
-
C++ 实验二 NO.1_(3) 1:熟悉DEV环境,练习自己的第一个程序使用DEV集成环境来编辑,运行简单的数据输入和运算实验。(3)编写一个程序,要求:提示输入3个数;显示这3个数,求他们的平均值
-
C语言使用栈和队列实现二进制与十进制的互转(带小数)
-
nodejs二进制与Buffer的介绍与使用
-
如何使用HTML5的WebSocket实现网页与服务器的双工通信(二)
-
struts2标签与jstl标签的混合使用