1、收派标准添加

jQuery easyUI window使用

jQuery easyUI form表单校验

收派标准添加页面调整url params

服务端实现三层

2jQuery easyUI datagrid 使用方式

n 将静态HTML渲染为datagrid样式(html方式)

n 发送ajax请求获取动态json数据构造datagrid(html方式)

n 使用easyUI提供的API(js方式)动态创建datagrid(掌握

3、收派标准管理

n 收派标准分页查询(基于datagrid实现)

n 收派标准修改

4、快递员管理

n 快递员添加

快递员列表查询(no-Session)

-----------------------------------------------------------------------------

1.1 Validatebox表单校验

1、 给input加样式class=easyui-validatebox

2、 设置校验规则:

a) 非空规则 required:true

 

b) 其他规则:通过validType:指定规则

 

3、 在提交表单之前做表单校验:调用FORM的validate方法

1.1 通过调用easyui的API(js)创建datagrid(掌握

1、 在页面中添加table元素给出id

2、 页面加载完成调用API  datagrid将数据表格创建,通过json对象设置数据表格属性

当显示分页组件:

点击分页按钮发送请求,提交两个参数page(当前页数)   rows(每页显示记录数)

服务端响应返回符合规范数据json对象: total(总记录数)  rows(当前页的数据)

{

total: 12,

rows:[]

}

 

通过js方式创建数据表格

<table id="dg"></table>

<script type="text/javascript">

$('#dg').datagrid({

url:'../data/user.json', //发送请求   数据来源

columns:[[       //展示数据

{field:'id',title:'编号',width:100},

{field:'name',title:'姓名',width:100},

{field:'age',title:'年龄',width:100,align:'right'}

]],

pagination:true,//展示分页栏

/*

请求:提交参数

、rows(每页显示记录数)

响应:响应json数据

{

total:100,

 

rows:[]  //当前页记录

}

*/

toolbar:[{

iconCls: 'icon-edit',

text:"编辑",

handler: function(){ //点击事件

alert('edit')

}

},{

iconCls: 'icon-save',

text:"新增",

handler: function(){ //点击事件

alert('save')

}

},{

iconCls: 'icon-help',

text:'帮助',

handler: function(){alert('help')}

}] ,

rownumbers:true,

singleSelect:true,

striped:true,

  pageSize:3,

 

  pageList:[3,10]

});

</script>

收派标准分页

@Action("standardAction_pageQuery")

public String pageQuery() throws Exception {

//dao中方法  Page<T> findAll(Pageable pageable);

//pageable:封装当前页 每页展示记录数

Pageable pageable = new  PageRequest(page-1, rows);

//返回Page对象中:包含当前页记录 总记录数等

Page<Standard> page =  standardService.pageQuery(pageable);

System.out.println("查询到总记录数:"+page.getTotalElements());

System.out.println("查询当前页记录:"+page.getContent());

Map<String, Object> map = new HashMap<>();

map.put("total", page.getTotalElements());

map.put("rows", page.getContent());

//转json gson;jsonlib,fastjson,jackson

//Jsonlib转json

//转对象,map 使用JSONObject

//转集合,数组说那个JSONArray

//将对象转为json

String json = JSONObject.fromObject(map).toString();

System.out.println(json);

ServletActionContext.getResponse().setContentType("text/json;charset=utf-8");

ServletActionContext.getResponse().getWriter().write(json);

return NONE;

实现收派标准修改功能

1.1 页面调整

查询easyui API:

Datagrid的方法:获取选中的记录

 

form表单方法:回显数

1、 给修改按钮设置点击事件:1判断2、获取选中记录3在表单中回显数据 4打开窗口

 

 

1.1 使用combobox展示收派标准数据

1、 页面:pages/base/courier.jsp

2、 修改combobox的url

1、 在收派标准action中添加查询所有收派标准,返回json数组形式

1.1 No session(理解)

初始化快递员对象中 定区集合

Web层转Courier对象为json串时候,对象中有fixedareas集合属性,jpa集合属性加载策略延迟加载。在action中转fixedareas集合为json串,通过代理对象查询数据库,action层中session已经关闭。

1、 解决方案:

1、 解决方案:方式一:使用过滤器延迟session生命周期:在web层(页面渲染完毕)关闭session

仅解决解决noSession问题

在web.xml中配置过滤器,当页面渲染完毕后关闭session

<!-- 必须放在struts2核心过滤器之前作用,延迟session生命周期 -->

<filter>

<filter-name>openEntityManagerInViewFilter</filter-name>

<filter-class>org.springframework.orm.jpa.support.OpenEntityManagerInViewFilter</filter-class>

</filter>

<filter-mapping>

<filter-name>openEntityManagerInViewFilter</filter-name>

<url-pattern>/*</url-pattern>

</filter-mapping>

a) 方式二:将集合属性改为立即加载(效率低不用)

b) 方式三:

1、 方式二:将实体中不需要转json的属性排除掉

1、 页面中展示数据:

项目一:第三天 收派标准添加 收派标准分页查询(基于datagrid实现) 收派标准修改快递员添加 快递员列表查询的更多相关文章

  1. 直接拿来用!最火的iOS开源项目(一~三)

    结束了GitHub平台上“最受欢迎的Android开源项目”系列盘点之后,我们正式迎来了“GitHub上最受欢迎的iOS开源项目”系列盘点.今天,我们将介绍20个在GitHub上非常受开发者欢迎的iO ...

  2. Hadoop学习笔记—20.网站日志分析项目案例(三)统计分析

    网站日志分析项目案例(一)项目介绍:http://www.cnblogs.com/edisonchou/p/4449082.html 网站日志分析项目案例(二)数据清洗:http://www.cnbl ...

  3. 学习Coding-iOS开源项目日志(三)

    继续前两篇,接着本第三篇<学习Coding-iOS开源项目日志(三)>讲解Coding-iOS开源项目. 前 言:作为初级程序员,想要提高自己的水平,其中一个有效的学习方法就是学习别人好的 ...

  4. Selenium Web 自动化 - 项目实战(三)

    Selenium Web 自动化 - 项目实战(三) 2016-08-10 目录 1 关键字驱动概述2 框架更改总览3 框架更改详解  3.1 解析新增页面目录  3.2 解析新增测试用例目录  3. ...

  5. Vue2+VueRouter2+webpack 构建项目实战(三):配置路由,运行页面

    制作.vue模板文件 通过前面的两篇博文的学习,我们已经建立好了一个项目.问题是,我们还没有开始制作页面.下面,我们要来做页面了. 我们还是利用 http://cnodejs.org/api 这里公开 ...

  6. SuperDiamond在JAVA项目中的三种应用方法实践总结

    SuperDiamond在JAVA项目中的三种应用方法实践总结 1.直接读取如下: @Test public static void test_simple(){ PropertiesConfigur ...

  7. Cocos2d-x v3.1项目创建(三)

    Cocos2d-x v3.1项目创建(三) Cocos2d-x官方为我们提供了用于创建.编译.运行和部署的一套命令行的工具集,也就是上篇文章中我们所提到的Cocos2d-Console,它位于我们的引 ...

  8. (转载)Android项目实战(三十二):圆角对话框Dialog

    Android项目实战(三十二):圆角对话框Dialog   前言: 项目中多处用到对话框,用系统对话框太难看,就自己写一个自定义对话框. 对话框包括:1.圆角 2.app图标 , 提示文本,关闭对话 ...

  9. Android 项目优化(三):MultiDex 优化

    在整理MultiDex优化之前,先了解一下Apk的编译流程,这样有助于后面针对MultiDex优化. 一.Apk 编译流程 Android Studio 按下编译按钮后发生了什么? 1. 打包资源文件 ...

随机推荐

  1. Python map,reduce,filter,apply

    map(function, iterable, ...) map()函数接收两个参数,一个是函数,一个是可迭代的对象,map将传入的函数依次作用到序列的每个元素,并把结果作为新的list返回. 基本等 ...

  2. iOS项目中获取验证码倒计时及闪烁问题解决方案

    -(void)startTime{ __block int timeout= 59; //倒计时时间 dispatch_queue_t queue = dispatch_get_global_queu ...

  3. 在Delphi2007下安装ReportMachine6.5

    如何在Delphi2007下安装ReportMachine6.5: 一.在安装ReportMachine6.5之前要安装如下组件: (1).llPdfLib3.6,用于导出PDF文件: (2).Ehl ...

  4. F1 score,micro F1score,macro F1score 的定义

    F1 score,micro F1score,macro F1score 的定义 2018年09月28日 19:30:08 wanglei_1996 阅读数 976   本篇博客可能会继续更新 最近在 ...

  5. 大话设计模式--组合模式 Composite -- C++实现实例

    1. 组合模式: 将对象组合成树形结构以表示"部分--整体"的层次结构,组合模式使用户对单个对象和组合对象的使用具有一致性. 需求中是体现部分与整体层次的结构时,希望用户可以忽略组 ...

  6. python第八篇:十分钟学会Flask

    什么是Flask Flask是一个基于Python并且依赖于Jinja2模板引擎和Werkzeug WSGI服务的一个微型框架 Flask中包含一个轻量级的web 服务器主要用于在开发阶段测试使用 F ...

  7. 各数据库连接配置与maven依赖安装

    maven用的比较多,所以自己去捣鼓了一下:以下是关于数据库配置的一块,把相关的内容张贴出来,以备不时之需 //MySql 配置文件(maven):pom.xml <dependency> ...

  8. php函数decbin

    decbin()将十进制转换为二进制.必须有一个十进制参数.

  9. hdu-5651 xiaoxin juju needs help(数学+gcd约分求阶乘)

    题目链接: xiaoxin juju needs help Time Limit: 2000/1000 MS (Java/Others)     Memory Limit: 65536/65536 K ...

  10. Java IO 简记

    1.File 类: l  java.io.File类:文件和目录路径名的抽象表示形式,与平台无关 l  File 能新建.删除.重命名文件和目录,但 File 不能访问文件内容本身.如果需要访问文件内 ...