当前位置: 代码迷 >> JavaScript >> Struts与Extjs的调整
  详细解决方案

Struts与Extjs的调整

热度:103   发布时间:2013-08-01 15:23:18.0
Struts与Extjs的整合

Struts与Extjs的整合

1、引入以下Jar包

  • commons-fileupload-1.2.2.jar
  • commons-io-2.0.1.jar
  • commons-lang3-3.1.jar
  • dom4j-1.6.1.jar
  • freemarker-2.3.19.jar
  • javassist-3.11.0.GA.jar
  • ognl-3.0.6.jar
  • struts2-core-2.3.12.jar
  • struts2-json-plugin-2.3.12.jar
  • xwork-core-2.3.12.jar

2、建立Person类

package com.hpu.pojo;

public class Person {
	private int id;
	private String name;
	private String number;
	
	public Person(int id , String name , String number) {
		this.id = id;
		this.name = name;
		this.number = number;
	}

	public int getId() {
		return id;
	}

	public void setId(int id) {
		this.id = id;
	}

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}

	public String getNumber() {
		return number;
	}

	public void setNumber(String number) {
		this.number = number;
	}
}

?3、配置struts.xml与web.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE struts PUBLIC 
		"-//Apache Software Foundation//DTD Struts Configuration 2.0//EN" 
		"http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
	<package name="struts2" namespace="/" extends="json-default">
		<action name="getPerson" class="com.hpu.action.PersonAction">
			<result type="json"/>
		</action>
		
		<action name="show" class="com.hpu.action.PersonAction" method="in" >
			<result>/in.jsp</result>
		</action>
	</package>
	
</struts>

?

<filter>
	<filter-name>struts2</filter-name>
	<filter-class>
	org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter
	</filter-class>
</filter>
<filter-mapping>
	<filter-name>struts2</filter-name>
	<url-pattern>/*</url-pattern>
</filter-mapping>

?

4、编写处理请求的PersonAction

package com.hpu.action;

import java.util.ArrayList;
import java.util.List;

import com.hpu.pojo.Person;
import com.opensymphony.xwork2.ActionSupport;

public class PersonAction extends ActionSupport {
	
	private List<Person> persons;

	public List<Person> getPersons() {
		return persons;
	}

	public void setPersons(List<Person> persons) {
		this.persons = persons;
	}

	@Override
	public String execute() throws Exception {
		Person person1 = new Person(1, "zhangsan", "15426897458");
		Person person2 = new Person(2, "lisi", "15236989636");
		persons = new ArrayList<Person>();
		persons.add(person1);
		persons.add(person2);
		return SUCCESS;
	}
}

?5、写请求页面

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Test.html</title>
	<link rel="stylesheet" type="text/css" href="../ext_js3/resources/css/ext-all.css"></link>
	<script type="text/javascript" src="../ext_js3/adapter/ext/ext-base.js"></script>
	<script type="text/javascript" src="../ext_js3/ext-all-debug.js"></script>
	<script type="text/javascript" src="Test.js"></script>
</head>
<body>
	<div id="show"></div>
</body>
</html>

?6、编写js文件

Ext.onReady(function() {
	Ext.BLANK_IMAGE_URL = "../ext_js3/resources/images/default/s.gif";
	
	
	var Person = new Ext.data.Record.create([
		{name:"id",mapping:"id"},
		{name:"name",mapping:"name"},
		{name:"number",mapping:"number"}
	]);

	// Json存储器
	var store = new Ext.data.Store({
	
		url:"getPerson.action",
		reader:new Ext.data.JsonReader(
			{root:"persons"},
			Person
		)
	});
	
	store.load();
	
	// 使用ColumnModel
	var columnModel = new Ext.grid.ColumnModel({
		columns:[
			{header:"id",dataIndex:"id",sortable:true},
			{header:"name",dataIndex:"name",sortable:true},
			{header:"number",dataIndex:"number",sortable:true}
		]
	});
	
	new Ext.grid.GridPanel({
		id:"myPanel",
		title:"gridPanel",
		width:400,
		height:300,
		frame:true,
		applyTo:"show",
		store:store,
		
		// 设置可排序
		cm:columnModel,
		autoExpandColumn:2
	});
})

?7、效果



?

  相关解决方案