在ZCMS中,如何在我们前端页面中进行查询,下面将以信息公开为例,对ZCMS怎么实现前台页面查询做一个介绍。
1.在DB目录下创建表结构(ZCInfo表),以保存数据:
data:image/s3,"s3://crabby-images/d607b/d607b103979fd8717129968c56515f999c1bdc8d" alt="图片1 图片1"
data:image/s3,"s3://crabby-images/38ec6/38ec65b16638b25635259b1b1584cb38e83ff248" alt="图片1 图片1"
在UI,Java目录下创建相应的子目录或包,UI下存放页面,Java下存放实现方法:
UI下的info.zhtml页面:
<script>
function add(){
var diag = new Dialog("新建信息","infoDialog.zhtml",500,250);
diag.onOk = function(){
save("Info.add");
};
diag.show();
}
function edit(){
var arr = DataGrid.getSelectedValue("grid");
if(!arr||arr.length==0){
Dialog.alert("请先选择一条记录");
return;
}
var diag = new Dialog("编辑信息","infoDialog.zhtml?ID="+arr[0]+"",500,250);
diag.onOk = function(){
save("Info.save");
};
diag.show();
}
function save(method){
var dc = $DW.Form.getData("form1");
if($DW.Verify.hasError()){
return;
}
Server.sendRequest(method,dc,function(response){
Dialog.alert(response.Message,function(){
if(response.Status==1){
DataGrid.loadData('grid');
$D.close();
}
},response.Status);
});
}
function del(){
var arr = DataGrid.getSelectedValue("grid");
if(!arr||arr.length==0){
Dialog.alert("请先选择一条记录");
return;
}
Dialog.confirm("确认删除?",function(){
var dc = new DataCollection();
dc.add("IDs",arr);
Server.sendRequest("Info.delete",dc,function(response){
Dialog.alert(response.Message);
DataGrid.loadData('grid');
});
});
}
function doSearch(){
DataGrid.setParam("grid","Name",$NV("Name").join());
DataGrid.setParam("grid","Code",$NV("Code").join());
DataGrid.setParam("grid","PublishTime",$NV("PublishTime").join());
DataGrid.setParam("grid",Constant.PageIndex,0);
DataGrid.loadData("grid");
}
document.onkeydown = function(event){
event = getEvent(event);
if(event.keyCode==13){
doSearch();
}
}
</script>
Java下InfoUI类中增删改查实现方法
2.在Java的plugins目录下创建插件配置文件InfoPlugin
data:image/s3,"s3://crabby-images/403f5/403f58cd4faac6f100c871f32d4e4668b1518f60" alt="图片3 图片3"
如下在插件的Menus下配置后台页面,注意找到URL对应的页面。
data:image/s3,"s3://crabby-images/d9a99/d9a99474485ee027604ad8a4c34074d92982053c" alt="图片4 图片4"
data:image/s3,"s3://crabby-images/1d480/1d48067e9418817792223967f781061e1bb180a7" alt="图片5 图片5"
效果如图:
data:image/s3,"s3://crabby-images/d3c1a/d3c1a4729a018727795f81f9968ed88a99075fa0" alt="图片6 图片6"
3.在插件中创建扩展项,从而通过Class找到相应的前台模板页面
data:image/s3,"s3://crabby-images/6552d/6552d36f8c763a1d8e05d8611638fc745c9fbfcc" alt="图片3 图片3"
如图添加Service ID :com.zving.contentcore.service.InteractiveTemplateService,并在Class选项中实现类data:image/s3,"s3://crabby-images/42fa8/42fa820414083bc9cd13afa480eb9ce342f1f3ea" alt="图片4 图片4"
4.infoList.template.html模板页面(存放于UI下自建的一个template目录,例如示例,在UI的nfo目录下创建一个template目录,用于存放模板页面,应注意所写目录与上述getDefaultTemplate()方法中所写的路径一致):
<script type="text/javascript">
function doSearch() {
var url = "open?SiteID=124&name="+$V("Name")+"&code="+$V("Code")+"&time="+$V("PublishTime");
window.location.href=encodeURI(encodeURI(url));
}
function showInfo(id){
var ele = $G("TabFrame");
window.location.href="search?SiteID=124&id="+id;
}
</script>
5.为了解析动态模板,在Java下创建模板UI类InfoTemplateUI,并添加相应的解析方法:
通过此方法,我们会找到之前编写的扩展项InfoTemplateProperty所定义的getDefaultTemplate()方法,从而找到infoList.template.html页面。6.前台页面展示效果及其实现方法
data:image/s3,"s3://crabby-images/a4818/a481801055e0dcc2de2d1827a725e2def873099d" alt="图片5 图片5"
双击实现信息详细页展现:
data:image/s3,"s3://crabby-images/784fd/784fd385df9ca8eadddf184af75bb7f52d3eb29a" alt="图片6 图片6"
搜索功能:
data:image/s3,"s3://crabby-images/6046c/6046c1798eec9f95b9f8ede9a572a6c04597899a" alt="图片7 图片7"
搜索结果:
data:image/s3,"s3://crabby-images/788e9/788e9214dd54f3197f505f6b56d63a178fe8d75f" alt="图片8 图片8"
7.详细页面实现如同上述在InfoPlugin中创建插件
data:image/s3,"s3://crabby-images/cc3e6/cc3e678f587343b5c15d7b38150272191f88c516" alt="图片9 图片9"
data:image/s3,"s3://crabby-images/7ef65/7ef653f6009e630c59bfff93b5a4b42a2cbae5a2" alt="图片10 图片10"
|
所有评论仅代表网友意见