Flask接口签名sign原理与实例代码浅析
411
2023-01-20
java easyUI实现自定义网格视图实例代码
前言
easyui是一种基于jquery的用户界面插件集合。
easyui为创建现代化,互动,javascript应用程序,提供必要的功能。
使用easyui你不需要写很多代码,你只需要通过编写一些简单HTML标记,就可以定义用户界面。
本文主要给大家介绍了关于java easyUI自定义网格视图的相关内容,下面话不多说了,来一起看看详细的介绍吧
方法如下:
一:前台代码如下
.textbox-label {
display: inline-block;
width: 70px;
height: 22px;
line-height: 22px;
vertical-align: middle;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
margin: 0;
paddinhttp://g-right: 5px;
}
.c-content{
overflow:hidden;
text-overflow:ellipsis;
display:-webkit-box;
-webkit-box-orient:vertical;
-webkit-line-clamp:2;
}
.highlight{
background-color: yellow;
}
em.important{
background-color: red;
}
.c-label{
display:inline-block;
width:50px;
}
.textbox-label-min {
display: inline-block;
width: 60px;
height: 22px;
line-height: 22px;
vertical-align: middle;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
margin: 0;
padding-right: 5px;
}
标题/内容:
用户名:
频道:
品牌:
分类:
帖子状态:
发布时间:
-
后台处理中。。。
var cardview = $.extend({}, $.fn.datagrid.defaults.view, {//重绘视图开始
renderRow: function(target, fields, frozen, rowIndex, rowData){
var cc = [];
cc.push('
if ( !frozen && rowData.postId){
var _isTop = rowData.isTop;
var _isAdmindel = rowData.isAdmindel;
var _isDeleted = rowData.isDelete;
var cs = "";
if(_isAdmindel ==1){
cs = cs+'管理员删除';
}
if(_isDeleted ==1){
cs = cs+'用户删除';
}
if(_isTop==1){
cs = cs+'置顶';
}
cc.push('
cc.push('
cc.push('
cc.push('
cc.push('
cc.push('
cc.push('
if(rowData.channelId==2){
if(rowData.title != null){
cc.push('
}else{
cc.push('
}
}else{
if(rowData.title != null){
cc.push('
}else{
cc.push('
}
}
if(rowData.content != null){
cc.push('
}else{
cc.push('
}
var ss ='
var attachmentList = rowData.channelPostAttach ;
for(var p in attachmentList){
if(attachmentList[p].type==10121002){
/* ss +='' */
/* ss +='' */
/* ss+='' */
/* ss+='' */
}
if(attachmentList[p].type==10121001){
ss += '';
}
}
ss +='
cc.push(ss);
cc.push('
}
cc.push('
return cc.join('');
},
onAfterRender: function(target){
var rows = $(target).datagrid('getRows');
$.each(rows, function (index, row) {
$('#title_'+row.postId).highlight($('#content').val());
$('#content_'+row.postId).highlight($('#content').val());
});
}
});//重绘视图结束
$(function(){
var dg =$('#dg').datagrid({//渲染表格
view: cardview,//更换默认视图
rowStyler: function(index,row){
if((index+1)%2 ==0){//隔行变色
return {class:'datagrid-double-color'}; // return inline style
}
},
url:'/channelPost/showChannelPost',
columns:[[
{field:'postId',title:'帖子', width:'20%',
}
]],
onDblClickRow:function(index,row){
window.open("/channelPost/getChannelPostDetail?postId="+row.postId,"channelPostDetail","scrollbars=yes,copyhistory=yes,width=1200, height=600");
},
nowrap:false,
pageSize: 10,//每页显示的记录条数,默认为15
pageList: [10,20,30],
onLoadSuccess:function(data){
if(data.errcode == -1){
showResult("更新出错");
}else if(data.errcode == 1){
}else{
showResult("更新成功");
}
}
});
});
$("#submitSearch").click(function(){
selectFunction();
});
function selectFunction(){
var content=$('#content').val();
var nickName=$('#author').val();
var dealType=$('#postStatus').val();
var isDelete=$('#isDeleted').val();
var startDate=$('#startDate').val();
var endDate=$('#endDate').val();
var forumIdArray = $('#forumIds').combobox('getValues');
var brandIdArray = $('#brandIds').combobox('getValues');
var brandIds ="";
var forumIds ="";
for(var o in brandIdArray){
brandIds +=brandIdArray[o];
if(o brandIds +=","; } } for(var o in forumIdArray){ forumIds +=forumIdArray[o]; if(o forumIds +=","; } } var str=$(".validatebox-text.validatebox-invalid:first"); if(str.val()==null){ $('#dg').datagrid('load',{ "content":content, "nickName":nickName, "dealTypes":dealType, "isDeletes":isDelete, "startDate":startDate, "endDate":endDate, "brandIds":brandIds, "channelIds":forumIds }); }else{ alert("请检查填写错误的数据!"); } } function allselectRow(tableName) { //全选 $('#' + tableName).datagrid('selectAll'); } function unselectRow(tableName) { //反选 var s_rows = $.map($('#' + tableName).datagrid('getSelections'), function(n) { return $('#' + tableName).datagrid('getRowIndex', n); }); $('#' + tableName).datagrid('selectAll'); $.each(s_rows, function(i, n) { $('#' + tableName).datagrid('unselectRow', n); }); } function doDel(column,value,msg) { //返回选中多行 var selRow = $('#dg').datagrid('getSelections') //判断是否选中行 if (selRow.length==0) { $.messager.alert("提示", "请选择"+msg+"行!", "info"); return; }else{ var temID=""; //批量获取选中行的id for (i = 0; i < selRow.length;i++) { if(selRow[i].isAdmindel==1){ $.messager.alert("提示", "已经有选中行的状态是'管理员删除',请去掉此行重试", "info"); return; } /* if(selRow[i].isTop==1){ $.messager.confirm('提示', '你选中要删除的里面包含置顶帖,是否继续?', function (r) { if (!r) { return; } }); } */ if (temID =="") { temID = selRow[i].postId }else{ temID = selRow[i].postId + "," + temID; } } $.messager.confirm('提示', '是否'+msg+'选中数据?', function (r) { if (!r) { return; }else{ $.ajax({ type : "POST", //提交方式 async: false, url : "/channelPost/updateChannel",//路径 data : {item:column,value:value,strPostIds:temID}, success:function(data) { if(data=='ok'){ $.messager.alert("提示", "ok", "info"); selectFunction(); }else{ $.messager.alert("提示", "error", "info"); } } }); } }); } }; function doTop(column,value,msg) { //返回选中多行 var selRow = $('#dg').datagrid('getSelections') //http://判断是否选中行 if (selRow.length==0) { $.messager.alert("提示", "请选择"+msg+"行!", "info"); return; }else{ var temID=""; //批量获取选中行的id for (i = 0; i < selRow.length;i++) { if(selRow[i].isTop==1){ $.messager.alert("提示", "已经有选中行的状态是'置顶',请去掉此行重试", "info"); return; } if(selRow[i].isAdmindel==1){ $.messager.alert("提示", "选中行的状态有'管理员删除',请去掉此行重试", "info"); return; } if(selRow[i].isDelete==1){ $.messager.alert("提示", "选中行的状态有'用户删除',请去掉此行重试", "info"); return; } if (temID =="") { temID = selRow[i].postId }else{ temID = selRow[i].postId + "," + temID; } } $.messager.confirm('提示', '是否'+msg+'选中数据?', function (r) { if (!r) { return; } $.ajax({ type : "POST", //提交方式 url : "/channelPost/updateChannel",//路径 data : {item:column,value:value,strPostIds:temID}, success:function(data) { if(data=='ok'){ $.messager.alert("提示", "ok", "info"); selectFunction(); }else{ $.messager.alert("提示", "error", "info"); } } }); }); } }; function doOffTop(column,value,msg) { //返回选中多行 var selRow = $('#dg').datagrid('getSelections') //判断是否选中行 if (selRow.length==0) { $.messager.alert("提示", "请选择"+msg+"行!", "info"); return; }else{ var temID=""; //批量获取选中行的id for (i = 0; i < selRow.length;i++) { if(selRow[i].isTop!=1){ $.messager.alert("提示", "只有'置顶'的才能取消置顶,检查选中项", "info"); return; }else{ if (temID =="") { temID = selRow[i].postId }else{ temID = selRow[i].postId + "," + temID; } } } $.messager.confirm('提示', '是否'+msg+'选中数据?', function (r) { if (!r) { return; } $.ajax({ type : "POST", //提交方式 url : "/channelPost/updateChannel",//路径 data : {item:column,value:value,strPostIds:temID}, success:function(data) { if(data=='ok'){ $.messager.alert("提示", "ok", "info"); selectFunction(); }else{ $.messager.alert("提示", "error", "info"); } } }); }); } }; 二:后台返回的数据格式 后台返回的数据格式和经典的easyui的数据格式是一样的 数据格式: {"total":67,"errmsg":"查询成功","errcode":1,"rows":[{"postId":77,"dealType":0,"title":"理解","partNo":null,"content":"理解[图片]","location":null,"tradeType":0,"brandId":0,"quantity":0,"contacts":"SakuraAoi","contactNumber":null,"color":null,"channelId":1,"createDate":"2018-10-16 10:12:19","updateDate":null,"status":0,"isDelete":0,"isAdmindel":0,"isTop":0,"replyNumber":0,"readNumber":0,"thumbNumber":0,"authorId":0,"isOem":0,"type":0,"amount":0.0,"channelPostAttach":[{"attachId":99,"postId":77,"uploadDate":1539655939000,"attachName":"record-attach/sell/371-20181016101221.png","type":10121001,"typeName":null,"attachNameUrl":""}],"nickName":"SakuraAoi","avatar":"","channelName":"新车交易","brandName":"长安铃木","startDate":null,"endDate":null,"brandIds":null,"channelIds":null,"strBrandIds":null,"strChannelIds":null,"begin":0,"end":0,"dealTypes":null,"isDeletes":null,"item":null,"value":0,"userId":0,"actId":0,"dealTypeName":null,"tradeTypeName":null,"isTopName":null,"createDate2":null}]} 三:视图效果 四:后台数据的获取 后台数据的获取为一对多,因为一个帖子会包含多个图片附件。 帖子实体类: public class BsChannelPost { private int postId; private int dealType; private String title; private String partNo; private String content; private String location; private int tradeType; private int brandId; private int quantity; private String contacts; private String contactNumber; private String color; private int channelId; @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss",timezone = "GMT+8") private Date createDate; @JsonFormat(pattern="yyyy-MM-dd HH:mm:ss",timezone = "GMT+8") private Date updateDate; private int status; private int isDelete; private int isAdmindel; private int isTop; private int replyNumber; private int readNumber; private int thumbNumber; private int authorId; private int isOem; private int type; private double amount; private List private String nickName; private String avatar; private String channelName; private String brandName; private String startDate; private String endDate; private List private List private String strBrandIds; private String strChannelIds; private int begin; private int end; private String dealTypes; private String isDeletes; private String item; private int value; private int userId; private int actId; private String dealTypeName; private String tradeTypeName; private String isTopName; private String createDate2; } 附件实体类: import lombok.Data; @Data//lombok 免写get set public class BsChannelPostAttach { private int attachId; private int postId; private Date uploadDate; private String attachName; private int type; private String typeName; private String attachNameUrl; } dao: select attach_id attachId,post_id postId,upload_date uploadDate,attach_name attachName,type from bs_channel_post_attach where post_id = #{postId} order by attach_id select p.post_id postId,u.nickname nickName,c.channel_name channelName,b.brand_name brandName,p.create_date createDate,p.title title,p.content content,p.part_no partNo,p.contacts contacts,u.avatar avatar,p.is_top isTop, is_delete isDelete,p.is_admindel isAdmindel,p.channel_id channelId from bs_channel_post p left join bs_channel c on p.channel_id=c.channel_id left join bs_brand b on p.brand_id=b.brand_id left join bs_user u on p.author_id=u.user_id where 1=1 and (p.content like '%${content}%' or p.title like '%${content}%' ) and u.nickname like '%${nickName}%' and p.deal_type=#{dealType} and (is_delete=0 and is_admindel=0) and (is_delete=1 or is_admindel=1) and is_top=1 and p.brand_id in #{id} and p.channel_id in #{id} and p.create_date>#{beginDate} and p.create_date <#{endDate} and p.create_date between #{beginDate} and #{endDate} order by p.create_date desc limit #{begin},#{end} 总结 以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对我们的支持。
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~