项目笔记:list页面展示与交互设计
1、前台页面:
因为要展示正版和非正版,所以传个Type值过去:
//正版序列号库列表
var type = $("input[name='serialNumber']:checked").val();
$("#inside_tableElement").datagrid({
striped : true,
collapsible : true,
url : "${basePath}/genuineSerialNumberManagementAction_list.do",
queryParams:{
"genuineSerialNumberManagement.type":type
},
columns : [ [
{field : 'softDisplayName',title : '软件名',align : 'center',width : (datag_width * 0.44)},
{field : 'version',title : '版本号',align : 'center',width : (datag_width * 0.44)},
{field : 'serialNumber',title : '序列号',align : 'center',width : (datag_width * 0.44)}
] ],
fitColumns : true,
rownumbers : true,
pagination:true,
pageSize: ,
pageList: [, , ],
onSelectAll : function() {
},
onUnselectAll : function() {
},
onSelect : function() {
},
onUnselect : function(rowIndex, rowData) {
}
});
后台list方法:
public void list(){
GridData<GenuineSerialNumberManagement> genuineSerialNumberManagements = null;
try {
HQLBuilderUtil builderUtil = new HQLBuilderUtil(GenuineSerialNumberManagement.class);
builderUtil.addOrderByProperty(" this.id ", true);
if(genuineSerialNumberManagement.getType() != null){
int type = genuineSerialNumberManagement.getType();
builderUtil.addWhereClause(" this.type=? ", type);//增加查询属性type
}
//当有SoftDisplayName传过来时,还要增加查询属性SoftDisplayName
if(genuineSerialNumberManagement.getSoftDisplayName() != null && !"".equals(genuineSerialNumberManagement.getSoftDisplayName())){
String softDisplayName = genuineSerialNumberManagement.getSoftDisplayName();
builderUtil.addWhereClause(" this.softDisplayName=? ", softDisplayName);
}
System.out.println(builderUtil.toQueryListHql());
genuineSerialNumberManagements = genuineSerialNumberManagementService.getPageView(builderUtil, getPageNum(), getPageSize());
} catch (Exception e) {
log.error("正版序列号管理列表获取失败!", e);
}finally{
print(ActionUtil.jsonObj(genuineSerialNumberManagements));
}
}
我们可以看下HQLBuilderUtil 工具类里面的addWhereClause:注意需要加 =? 来与参数对应
/**
* 添加过滤条件,组织WHERE语句(可变参数附条件)
* @param condition 过滤的条件
* @param params 参数列表
* @return 工具类本身
*/
public HQLBuilderUtil addWhereClause(String condition, Object... params){
//1.组织语句
if(StringUtils.isBlank(whereClause)){
whereClause = " WHERE " + condition;
}else{
whereClause += " AND " + condition;
}
//2.添加参数
if(params != null && params.length>){
for (Object param : params) {
paramList.add(param);
}
}
return this;
}
2、接着,我们看点击左右软件名字,与右侧展示数据的交互
//左边菜单栏切换
function changeMenu(obj){
$(obj).siblings().removeClass("selected");
$(obj).addClass("selected");
var softDisplayName = $(obj).text(),
type = $('input[name="serialNumber"]:checked').val();
if(type === ""){
$("#inside_tableElement").datagrid('load',{
"genuineSerialNumberManagement.type":type,
"genuineSerialNumberManagement.softDisplayName":softDisplayName
})
}else{
$("#inside_tableElement_no").datagrid('load',{
"genuineSerialNumberManagement.type":type,
"genuineSerialNumberManagement.softDisplayName":softDisplayName
})
}
}
也就是上面的list方法,传入了softDisplayName的查询属性。
3、接着,正版和非正版之间切换:注意$("#inside_tableElement_no")需要这样初始化表格之后,才能再像正版那样使用 load 传入参数重新加载
//正版与非正版之间切换
$("#genuineSerialNumber").click(function(){
$("#tableName").text("正版序列号库:");
$("#center1").css('display','block');
$("#center2").css('display','none');
var type = $("#genuineSerialNumber").val();
var softDisplayName = $("#softNameMenu .selected").text();
$("#inside_tableElement").datagrid("load",{
"genuineSerialNumberManagement.type":type,
"genuineSerialNumberManagement.softDisplayName":softDisplayName
});
});
$("#non_genuineSerialNumber").click(function(){
$("#tableName").text("非正版序列号库:");
$("#center1").css('display','none');
$("#center2").css('display','block');
var type = $("#non_genuineSerialNumber").val();
var softDisplayName = $("#softNameMenu .selected").text();
$("#inside_tableElement_no").datagrid({
striped : true,
collapsible : true,
url : "${basePath}/genuineSerialNumberManagementAction_list.do",
queryParams:{
"genuineSerialNumberManagement.type":type,
"genuineSerialNumberManagement.softDisplayName":softDisplayName
},
columns : [ [
{field : 'softDisplayName',title : '软件名',align : 'center',width : (datag_width * 0.44)},
{field : 'version',title : '版本号',align : 'center',width : (datag_width * 0.44)},
{field : 'serialNumber',title : '序列号',align : 'center',width : (datag_width * 0.44)}
] ],
fitColumns : true,
rownumbers : true,
pagination:true,
pageSize: ,
pageList: [, , ]
});
});
4、struts的s:iterator标签循环遍历:
左侧的软件名称是通过struts遍历数据的值来展示,通过下面方式。
后台需要设置list到前台来:
public String listUI(){
List<GenuineSerialNumberManagement> genuineSerialNumberManagements = genuineSerialNumberManagementService.queryAll();
List<GenuineSerialNumberManagement> genuineSerialNumberManagementList = new ArrayList<GenuineSerialNumberManagement>();
if(genuineSerialNumberManagements != null){
for(GenuineSerialNumberManagement gsnm : genuineSerialNumberManagements){
GenuineSerialNumberManagement gm = new GenuineSerialNumberManagement();
gm.setSoftDisplayName(gsnm.getSoftDisplayName());
genuineSerialNumberManagementList.add(gm);
}
}
getRequest().setAttribute("genuineSerialNumberManagementList", genuineSerialNumberManagementList);
return RETURN_LISTUI;
}
前台通过下面方式获取遍历:
<div id="softNameMenuContent">
<s:if test="#request.genuineSerialNumberManagementList != null">
<s:iterator value="#request.genuineSerialNumberManagementList">
<a class="softName" onclick="changeMenu(this);"><span><s:property value="#request.softDisplayName" /></span></a>
</s:iterator>
</s:if>
</div>
项目笔记:list页面展示与交互设计的更多相关文章
- HTML5项目笔记4:使用Audio API设计绚丽的HTML5音乐播放器
HTML5 有两个很炫的元素,就是Audio和 Video,可以用他们在页面上创建音频播放器和视频播放器,制作一些效果很不错的应用. 无论是视屏还是音频,都是一个容器文件,包含了一些音频轨道,视频轨道 ...
- HTML5项目笔记10:使用HTML5 IndexDB设计离线数据库
之前的文章(http://www.cnblogs.com/wzh2010/archive/2012/05/22/2514017.html)里面描述了HTML5 离线数据存储的Web SQL,一个基于S ...
- 项目Splash页面的开发与设计
项目Splash页面的开发与设计 首先建立一个安卓的项目,然后修改manifest.xml文件,修改应用程序的logo和显示名称,效果图如下: 对应的代码如下: 1 <?xml version= ...
- Prometheus笔记(二)监控go项目实时给grafana展示
欢迎加入go语言学习交流群 636728449 Prometheus笔记(二)监控go项目实时给grafana展示 Prometheus笔记(一)metric type 文章目录 一.promethe ...
- case设计及验证:入口+页面+展示
测试个性CB问题, 功能整体结构为:入口+页面+展示 总结: 1. 产品文档为主,其次是服务端接口返回.数据结构及字段值确认.结合实际场景检查是否有遗漏或不合理. 2. 以字段为维度,每个字段的检查点 ...
- 《About Face 3:交互设计精髓》读书笔记(一)
第一章 目标导向设计 当今数字产品的创造过程 市场营销人员对于产品设计过程的贡献,通常局限于需求列表这些需求同用户的实际需要与期望无关,主要在于追赶竞争对手,按照任务清单管理IT资源,以及基于市场调查 ...
- 【软件需求工程与建模 - 小组项目】第6周 - 成果展示3 - 软件设计规格说明书V4.1
成果展示3 - 软件设计规格说明书V4.1
- 项目那几步走:先配置setting路径文件、创建数据库、执行数据库迁移命令、配置mysql数据库信息、注册app、注释中间件、pymysql替换mysqldb-配置urls路由-继续视图函数-然后HTML页面展示-HTML里面导入css文件、models配置数据库表、
django使用mysql数据库: 首先cmd创建库 1.settings: """Django settings for day42 project. Generate ...
- SNF快速开发平台3.0之BS页面展示和九大优点-部分页面显示效果-Asp.net+MVC4.0+WebAPI+EasyUI+Knockout
一)经过多年的实践不断优化.精心维护.运行稳定.功能完善: 能经得起不同实施策略下客户的折腾,能满足各种情况下客户的复杂需求. 二)编码实现简单易懂.符合设计模式等理念: 上手快,见效快.方便维护,能 ...
随机推荐
- mvc3 RenderAction传参问题
我在viewA中调用部分视图viewB代码如下:@{Html.RenderAction("NewsList","News",new{pageSize=13, c ...
- jenkins pipelines 简介
1. 简介:A pipeline就是软件和质量保证进程中的一部分中的自动化连续操作.它可以看成是一连串的脚本. 操作组:就是把一系统的操作可以合成一个个的步骤,如果一个步骤失败,那么后续步骤便不会执行 ...
- gVim 启动时窗口自动居中
最近折腾 vim, 除了配置巨麻烦外, 另一个很蛋疼的就是窗口位置问题了, 折腾了半天无法启动时自动居中, 找遍各地也只有保存上次位置, 下次启动时恢复的方法 废话不多说, 直接上代码, 丢到 vim ...
- Wannafly挑战赛7 D - codeJan与青蛙
codeJan喜欢观察世界.有一天,codeJan发现一个非常奇怪的现象.有一些年轻的青蛙聚集在一条直线上的某些位置上,同一个位置可能有多个青蛙.这些青蛙每次只会向前跳一米,并且每只青蛙每跳一次都会发 ...
- Code forces363D Renting Bikes
Renting Bikes Time Limit:1000MS Memory Limit:262144KB 64bit IO Format:%I64d & %I64u Subm ...
- CodeForces 606C Sorting Railway Cars(最长连续上升子序列)
Description An infinitely long railway has a train consisting of n cars, numbered from 1 to n (the n ...
- 洛谷P1149 火柴棒等式
题目描述 给你n根火柴棍,你可以拼出多少个形如“A+B=C”的等式?等式中的A.B.C是用火柴棍拼出的整数(若该数非零,则最高位不能是0).用火柴棍拼数字0-9的拼法如图所示: 注意: 1.加号与等号 ...
- Tsinsen Palisection
建回文树. 正反建统计一种前缀和求出所有不相交的,用总数减去就是答案数. 在这里我们可以知道一个字符串中所有回文串的个数即为num数组之和(因为以一个节点为回文串结尾的字串都是唯一的) 也可以是cnt ...
- hdu 3081
二分答案,网络流是否满流判断合法性. #include <cstdio> #include <cstring> #include <queue> #include ...
- SHELL异常处理(转载)
写SHELL好久了,经常被异常困扰,可竟然坚持了若干年没用过,回想以前服务过的公司,阿弥陀佛,罪过罪过.废话少说,希望此篇文章可以协助大家和我彻底结束SHELL脚本就是LINUX命令集合的初级阶段. ...