- 浏览: 733939 次
- 性别:
- 来自: 宁波
文章分类
- 全部博客 (125)
- 软件开发 (17)
- java (32)
- js (2)
- jsp (1)
- struts2 (1)
- jquery (4)
- oracle (12)
- 程序员 (2)
- 三星i9300 联通版 root (1)
- easyui (2)
- DOM4J (2)
- 哲学 (1)
- ftp (1)
- oracle每日一学 (2)
- spring (4)
- jquery每日一学 (5)
- shiro (4)
- ITextRenderer (1)
- shiro标签 (1)
- mysql (1)
- mysql每日一学 (4)
- 分词 (1)
- vtiger crm (1)
- IkAnalyzer (1)
- jsoup (1)
- 多线程 (1)
- quartz (1)
- ubuntu (2)
- gradle学习笔记 (1)
- node.js (1)
- ajax (1)
- mybatis (1)
- cas (2)
- cxf (1)
- jqgrid (1)
- 开发工具破解 (1)
最新评论
-
氵每市蜃木娄:
使用过后,移动滚动条,非冻结的列,表头不见了。
easyui datagrid 右冻结 -
18335864773:
推荐用pageoffice组件打开文档,pageoffice ...
java word导出 -
xiaoliuf4565:
用过之后中文可以换行,但是现在编程了英文和数字不换行了脑壳痛
freemarker+ITextRenderer 生成html转pdf -
A741841403:
Error:(275, 29) java: 无法访问com.l ...
freemarker+ITextRenderer 生成html转pdf -
A741841403:
楼主你好,我想问下,如何在maven中使用你的jar包呢
freemarker+ITextRenderer 生成html转pdf
这里是struts2里的应用:1,.js导入
<link href="plug/Dtree/editTree.css" rel="stylesheet" type="text/css">
<script src="plug/Dtree/editTree.js" type="text/javascript" ></script>
<script src="plug/Dtree/jquery-1.3.2.js" language="JavaScript"></script>
<link href="plug/Dtree/saveKey.css" rel="stylesheet" type="text/css" />
2.js代码:
<script type="text/javascript">
<!--
$(document).ready(function(){
postSelectedNode(tree.getSelected());
});
// 去除字符串首尾空格
String.prototype.trim = function()
{
return this.replace(/(^\s+)|(\s+$)/g, "");
}
/**
* 点击菜单后的处理函数
* 更新菜单的访问记录
*/
function postSelectedNode(nodeId){
var selectedNode = tree.getNode(nodeId);
if(selectedNode!=null){
//var treeLevel = selectedNode.findByPropertyKey("treeLevel");
var type_Name = selectedNode.findByPropertyKey("name");
var type_describe = selectedNode.findByPropertyKey("describe");
var isSystemDefine=selectedNode.findByPropertyKey("isSystemDefine");
//alert(type_describe);
setCurrentCollectClassify(selectedNode.id,selectedNode.pid,type_Name,type_describe,isSystemDefine);
}
//否则展开菜单目录
postTreeSelect(selectedNode);
}
/**
* 执行菜单跳转
* @param {Object} selectedNode 当前选中的菜单节点对象
*/
function postTreeSelect(selectedNode){
if(selectedNode == null||selectedNode.id == 0){
return;
}
//当前节点id
var strNodeId = selectedNode.id;
var expandFlag = selectedNode.findByPropertyKey("expandFlag");
//如果当前菜单是叶子
if(selectedNode.isLeaf == true){
var vUrl = selectedNode.findByPropertyKey("url");
vUrl = vUrl.replace("#","=");
vUrl = vUrl.replace("#","=");
vUrl = vUrl.replace("#","=");
vUrl = vUrl.replace("#","=");
var vWin;
//在右边窗口打开
openSelectPointList(vUrl,selectedNode.id,selectedNode.pid);
}else{//否则展开分支
//如果还没有加载此节点的儿子节点
//node._hc 可能是hasCookie的意思,dTree会在cookie中保存了已经加载的节点
if(!selectedNode._hc){
document.frameTree.branchloadDataId.value = strNodeId;
document.frameTree.submit();
}
}
}
function setCurrentCollectClassify(nodeId,pNodeId,cpType_Name,cpType_descripe,isSystemDefine){
$('#id').val(nodeId); //子节点
$('#parentID').val(pNodeId); //父节点
//alert(cpType_Name);
//alert(cpType_descripe);
$('#name').val(cpType_Name);
$('#describe').val(cpType_descripe);
$('#isSystemDefine').val(isSystemDefine);
}
/**
设置节点ID,并在右窗口中打开
@parm actions 调用的Action;
@parm nodeId 节点名称
@parm pNodeId 父节点名称
**/
function openSelectPointList(actions,nodeId,pNodeId){
var url = actions + "?id="+nodeId+"^parentID="+pNodeId;
$('#workSpace',parent.document).attr('src',url);
}
$(document).ready(function(){
//树刷新时即刷新采集点列表
var id = $('#id').val();
var pid = $('#parentID').val();
var url = "manage/article/view.do?id=" + id+"^parentID="+pid;;
$('#workSpace',parent.document).attr('src',url);
});
/**
调用新增或者编辑类别方法
**/
/**
设置编辑框的值为当前选定的节点值
**/
function setNodeValue(){
$('#name').val($('#name').val());
$('#describe').val($('#describe').val());
}
function ifCanModify(){
var cpClassifyId = $('#id').val();
var cpParentID = $('#parentID').val();
var isSystemDefine=$('#isSystemDefine').val();
if(cpClassifyId==0){
alert("不允许编辑根节点!");
return;
}
if(isSystemDefine==1){
alert("不允许编辑系统定义的节点!");
return;
}
setNodeValue();
$('#addNewOrEdit').val(2);
$('#divQuery').slideDown('1000');
}
//-->
</script>
<script type="text/javascript">
<!--原始ajax-->
var xmlHttp;
function createXMLHttpRequest() {
if (window.ActiveXObject) {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
else if (window.XMLHttpRequest) {
xmlHttp = new XMLHttpRequest();
}
}
function validate() {
createXMLHttpRequest();
var mainid = $('#id').val();
var pid = $('#parentID').val();
if(mainid==0){
alert("不允许删除根节点!");
return;
}
var isSystemDefine=$('#isSystemDefine').val();
if(isSystemDefine==1){
alert("不允许删除系统定义的节点!");
return;
}
if(!confirm("确定删除该采集点类别?")){
return false;
}
var url ='manage/article/del.do?id=' +mainid+'&TimeID=' + Math.random();
xmlHttp.open("GET", url, true);
xmlHttp.onreadystatechange = callback;
xmlHttp.send(null);
}
function callback() {
if (xmlHttp.readyState == 4) {
if (xmlHttp.status == 200) {
try{
if(1==(xmlHttp.responseText.replace(/(^\s*)|(\s*$)/g, ""))){
alert('删除成功');
parent.document.form1.submit();
return true;
}else if((0==(xmlHttp.responseText.replace(/(^\s*)|(\s*$)/g, "")))){
alert('删除失败');
return false;
}else if((-1==(xmlHttp.responseText.replace(/(^\s*)|(\s*$)/g, "")))){
alert("该分类下存在子分类,无法删除!");
return false;
}
}catch(e){}
}
}
}
//新增
function Add() {
createXMLHttpRequest();
document.cookie = "returnUrl=" + escape(location.pathname + location.search);
var mainid = $('#id').val();
var pid = $('#parentID').val();
if(mainid==null || mainid ==""){
alert("请先选择分类!");
return;
}
var type_Name = document.getElementById('name').value; //类别名称
var type_Describe = document.getElementById('describe').value; //描述
//var type_ParentID = $("#type_ParentID").val();
if(type_Name==null || $.trim(type_Name) ==""){
alert("必须填写类别名称!");
return;
}
var url ='manage/article/save.do?type_Name=' + encodeURI($.trim(type_Name))+'&typeDescribe='+ encodeURI(type_Describe)+'&type_ParentID=' + mainid+'&pid='+pid+'&TimeID=' + Math.random();
xmlHttp.open("GET", url, true);
xmlHttp.onreadystatechange = callbackAdd;
xmlHttp.send(null);
}
function callbackAdd() {
if (xmlHttp.readyState == 4) {
if (xmlHttp.status == 200) {
try{
if(1==(xmlHttp.responseText.replace(/(^\s*)|(\s*$)/g, ""))){
alert('新建类别成功');
//document.form1.submit();
parent.document.form1.submit();
return true;
}else if((0==(xmlHttp.responseText.replace(/(^\s*)|(\s*$)/g, "")))){
alert('新建类别失败');
return false;
}else if((-1==(xmlHttp.responseText.replace(/(^\s*)|(\s*$)/g, "")))){
alert("新建类别失败,该节点下已存在该分类名称!");
return false;
}
}catch(e){}
}
}
}
function checkField(){
document.form2.submit();
}
//修改方法
//新增
function validateUpdate() {
var cpClassifyId = $('#id').val();
var isSystemDefine=$('#isSystemDefine').val();
createXMLHttpRequest();
document.cookie = "returnUrl=" + escape(location.pathname + location.search);
var mainid = $('#id').val();
if(mainid==null || mainid ==""){
alert("请先选择分类!");
return;
}
if(cpClassifyId==0){
alert("不允许编辑根节点!");
return;
}
if(isSystemDefine==1){
alert("不允许编辑系统定义的节点!");
return;
}
var type_Name = document.getElementById('name').value;
var type_Describe= document.getElementById('describe').value;
//var type_ParentID = $("#type_ParentID").val();
if(type_Name==null || $.trim(type_Name) ==""){
alert("必须填写类别名称!");
return;
}
// if(mainid==0){
// alert("不允许编辑根目录!");
// return;
// }
var url ='manage/article/update.do'+'?id='+mainid+'&type_Name=' + encodeURI($.trim(type_Name))+'&typeDescribe='+ encodeURI(type_Describe)+'&TimeID=' + Math.random();
xmlHttp.open("GET", url, true);
xmlHttp.onreadystatechange = callbackupdate;
xmlHttp.send(null);
}
function callbackupdate() {
if (xmlHttp.readyState == 4) {
if (xmlHttp.status == 200) {
try{
if(1==(xmlHttp.responseText.replace(/(^\s*)|(\s*$)/g, ""))){
alert('编辑类别成功');
parent.document.form1.submit();
return true;
}else if((0==(xmlHttp.responseText.replace(/(^\s*)|(\s*$)/g, "")))){
alert('编辑类别失败');
return false;
}else if((-1==(xmlHttp.responseText.replace(/(^\s*)|(\s*$)/g, "")))){
alert("编辑类别失败,该节点下已存在该分类名称!");
return false;
}
}catch(e){}
}
}
}
/**
调用新增或者编辑类别方法
**/
function saveNewTreeNode(){
var flag = $('#addNewOrEdit').val();
var type_Name = document.getElementById('name').value;
var type_Describe = document.getElementById('describe').value;
if(type_Name.length>6){
alert("中文名称字数不能大于6个!");
return;
}
if(type_Describe.length>85){
alert("英文名称字数不能大于85个!");
return;
}
if(flag==1){
Add();
}else{
validateUpdate();
}
}
//iframe网页高度自适应
function iframeAutoFit()
{
try
{
if(window!=parent)
{
var a = parent.document.getElementsByTagName("IFRAME");
for(var i=0; i<a.length; i++) //author:meizz
{
if(a[i].contentWindow==window)
{
var h1=0, h2=0, d=document, dd=d.documentElement;
a[i].parentNode.style.height = a[i].offsetHeight +"px";
a[i].style.height = "10px";
if(dd && dd.scrollHeight) h1=dd.scrollHeight;
if(d.body) h2=d.body.scrollHeight;
var h=Math.max(h1, h2);
if(document.all){h += 4;}
if(window.opera){h += 1;}
a[i].style.height = a[i].parentNode.style.height = h +"px";
}
}
}
}
catch (ex){}
}
if(window.attachEvent)
{
window.attachEvent("onload", iframeAutoFit);
}
else if(window.addEventListener)
{
window.addEventListener('load', iframeAutoFit, false);
}
</script>
3. html部分<!--树形菜单-->
<!-- 做刷新页面用-->
<form action="manage/article/view.do">
<input type="hidden" value="测试" class="btn_newStyle" />
</form>
<form action="manage/article/view.do" name="form1" method="post">
<input type="hidden" name="id" Id="id" value="${node}" />
<input type="hidden" name="Hname" Id="Hname" />
<input type="hidden" name="Hdescribe" Id="Hdescribe" />
<input type="hidden" name="parentID" Id="parentID" />
<input type="hidden" name="isSystemDefine" Id="isSystemDefine" />
<input type="hidden" name="addNewOrEdit" Id="addNewOrEdit" />
<div id="listLayer" style="width:290px; height:700px; z-index:1; overflow-x: auto; overflow-y: auto;visibility: visible;">
<div style="width:100%;background-image: url(whitetopbottom.gif)">
<table>
<tr>
<td align="center" width="290">
<input type="button" value="新增下级" class="btn_newStyle" onClick="$('#addNewOrEdit').val(1);$('#divQuery').slideDown('1000');$('#name').val('');$('#describe').val('');"/>
<input type="button" value="编辑" class="btn_newStyle" onClick="ifCanModify();"/>
<input type="button" value="删除" class="btn_newStyle" onClick="validate()"/>
</td>
</tr>
</table>
</div>
<div id="divQuery" style="display:none;width:285px;border:#A6B8D0 1px solid;background-color:#D1DFF1;margin-top: 2px;padding: 1px;">
<div style="border:#ffffff 1px solid;padding: 7px;">
<div style="height:135px;padding-top:13px;background-color:#C7D6E9">
<table cellspacing="0" cellpadding="0" style="width:100%;" border="0" style="font-size:9pt;">
<tr>
<tr>
<td align="center" >类别名称:</td>
<td ><input type="text" name="name" id="name" maxlength="6" size="15" ></td>
</tr>
<tr>
<td align="center">描述:</td>
<td >
<textarea name="describe" id="describe" onpropertychange="if(value.length>85) value=value.substr(0,85)" cols="13" rows="4" ></textarea>
</td>
</tr>
<tr>
<td height="30px;" align="center" nowrap="nowrap" colspan="2">
<input type="button" value=" 保 存 "onClick="saveNewTreeNode()" class="btn_href" />
<input type="button" value=" 关 闭 " class="btn_href" onClick="$('#divQuery').slideUp('1000')"/>
</td>
</tr>
</table>
</div>
</div>
</div>
<div>
<table class="bg_table" cellpadding="0" cellspacing="0">
<tr valign="top">
<td>
<script type="text/javascript">
<s:if test="#request.articleTypelist.size!=0">
//alert('dd');
tree = new dTree('tree','/pages');
<s:iterator value="#request.articleTypelist" status="stuts">
tree.add('<s:property value="id" />',
'<s:property value="parentID" />',
'<s:property value="name" escape="false"/>',
'<s:property value="isSystemDefine" escape="false"/>',
'url=manage/article/view.do^id=<s:property value="id" />^parentID=<s:property value="parentID" />^name=<s:property value="name" escape="false"/>^describe=<s:property value="describe" escape="false"/>^isSystemDefine=<s:property value="isSystemDefine" escape="false"/>',
'<%=path%>/plug/Dtree/dtreeimg/menufolder.gif',
'<%=path%>/plug/Dtree/dtreeimg/menufolderopen.gif',
false,
false,
true);
</s:iterator>
</s:if>
document.write(tree);
</script>
</td>
<td></td>
</tr>
</table>
</div>
</div>
</form>
4.struts2标签:<%@ taglib uri="/struts-tags" prefix="s"%> 注意编码 用utf-8
5:备注:<s:property value="id" />是表的主键,<s:property value="parentID" />父级ID,escape="false"/:避免struts2的unicode编码显示
- tree.rar (127.1 KB)
- 下载次数: 273
发表评论
-
如何编译成功cas最新maven项目
2015-12-17 14:11 9096从官网 github上下载 https://github.co ... -
程序员是一个很好的职业!
2012-05-16 09:53 1664<br><img src="htt ... -
java自动包装和自动解包装转换
2011-12-17 14:40 1270int i=42; int j; Integer exam ... -
struts2+spring3+ibatis下类似淘宝搜索的的三级互联效果
2011-10-20 21:57 2117项目框架 struts2+spring3+ibatis 用了 ... -
在公交车上想出的一个java算法
2011-04-05 22:33 1614回老家要做2个小时公交,是在太无聊了,脑海开始跳动波涛,于 ... -
swfupload #2049 鬼一样的问题终于解决了
2011-03-28 23:16 1714用到 老外的插件 swfupload 来弄多文件上传 遇 ... -
Exception starting filter struts2 Unable to load configuration
2011-03-27 17:49 2146因为xerce.jar和xml-apis.jar这两个j ... -
hibernate.cfg.xml配置总结
2011-03-14 12:47 1109自己亲自试过,绝对OK! Hibernate的描述文件可 ... -
spring 的scope="prototype"
2011-03-13 17:03 1613悲剧 惨剧 喜剧,心情极其复杂,搞了一天的问题,spring ... -
javascript/JS限制用户名只能输入字母和数字下划线
2011-01-25 11:00 19242javascript/JS限制用户名只能输入字母和数字下划线 ... -
jsp导出数据到excel(小例子)
2010-12-27 13:48 2903<%@ page contentType="a ... -
js正则判断文本框只能输入0-50
2010-11-02 11:18 1568function test(){var num=documen ... -
JS简洁版下拉树
2010-10-20 15:40 2515这是struts2的应用其他也可以根据需要灵活改动: ... -
树表格
2010-10-20 10:44 2664<script type=" ... -
ibatis批量删除
2010-10-18 10:16 7026弄得头大的ibatis批量删除终于搞定了, 原来错误一直是没有 ... -
struts2根据主键更新某个列方法
2010-09-10 09:36 1277public boolean ChangeReturnSt ...
相关推荐
在Java Web开发中,动态树形菜单是一种常见的用户界面元素,尤其在管理系统的导航部分,它能够以层次结构展示数据,使用户能直观地浏览和操作复杂的数据结构。本示例是一个基于Java实现的JSP动态树形菜单功能,旨在...
在Java编程中,树形菜单是一种常见的用户界面元素,它以层次结构展示数据,通常用于文件系统、组织架构或程序功能导航。这个压缩包“treemenu”很可能包含了一个简单的WinFrom应用程序,其中实现了树形菜单的功能。...
HTML树形菜单是一种常见的网页交互元素...在实际开发中,开发者可能会根据需求选择不同的实现方式,从简单的纯JavaScript实现到使用成熟的前端框架,如React、Vue或Angular,来构建更复杂、功能更丰富的树形菜单组件。
树形菜单在IT界是一种常见的用户界面元素,尤其在数据层级结构复杂的应用中,如文件管理系统、组织架构展示、导航菜单等。它以图形化的方式展现了数据间的层次关系,使得用户能够直观地理解和操作这些数据。本文将...
在这个“jsp树形菜单 dtree tree 树形菜单”的项目中,我们将探讨如何利用JSP、dtree库以及可能的Struts框架来创建一个动态的树形菜单。 首先,JSP(JavaServer Pages)是一种基于Java的技术,用于创建动态Web内容...
在IT行业中,树形菜单是一种常见的用户界面元素,尤其在网站和应用程序的导航设计中扮演着重要角色。这种菜单结构模仿了计算机科学中的树数据结构,以层级方式展示信息,使得用户可以方便地浏览和访问多级内容。下面...
在这个“ajax树形菜单 动态显示”的项目中,我们关注的是如何利用Ajax技术来实现一个交互式的、只在需要时加载内容的树形菜单。 树形菜单是一种常见的用户界面元素,它通过层级结构来展示信息,常用于网站导航、...
JS无限级树形菜单3种
在JavaScript编程中,树形菜单是一种常见的用户界面元素,它以层级结构展示数据,通常用于网站导航、文件系统浏览或数据库记录的展示。本压缩包包含两个文件:"可以拖动的IEtree树型.htm" 和 "树型结构_lj不错.htm"...
在本案例中,"好看实用js树形菜单"是指利用JavaScript实现的一种交互式的、可视化的菜单结构,它通常用于网站或应用程序的导航,帮助用户更方便地浏览和访问层次结构的数据。 树形菜单的核心在于其递归的结构,每个...
在IT行业中,构建一个无限级树形菜单是常见的需求,特别是在Web应用中,用于组织和展示层次结构的数据。本项目“s2sh+freemarker+jquery+jquery-treeview 无限级树形菜单”就是这样一个解决方案,它整合了多种技术来...
树形菜单栏在网页设计中是一种常见的交互元素,主要用于组织和展示层次结构的数据或功能模块。在HTML中实现树形菜单栏,通常结合JavaScript、CSS以及可能的服务器端技术来完成。这里我们将深入探讨如何使用HTML和...
JavaScript树形菜单是一种常见的网页交互元素,用于展示层次结构的数据,比如网站导航、文件系统或者组织结构图。在网页设计中,它能有效地节省空间,提高用户体验,让用户能够以直观的方式浏览和操作多层次的信息。...
而Bootstrap Treeview.js是一个专门用于创建树形结构的JavaScript库,它可以轻松地集成到Bootstrap环境中,实现下拉框中的树形菜单。 首先,要实现Bootstrap树形下拉框,你需要包含以下关键文件: 1. Bootstrap CSS...
在网页设计中,创建交互式的用户界面是至关重要的,而CSS树形菜单就是实现这一目标的有效工具。"很不错的css树形菜单"这个项目显然旨在提供一个可扩展、易维护的解决方案,帮助开发者构建出层次清晰、易于导航的菜单...
在IT领域,树形菜单是一种常见的用户界面元素,尤其在网页设计和软件开发中,它被广泛用于组织和展示层次化的数据。树形菜单通常由节点(或称为项)组成,每个节点可以有子节点,形成一个类似树状的结构。这种结构...
在本话题中,我们主要讨论的是使用JavaScript实现的树形菜单,它是一种常见的用户界面元素,用于展示层次结构的数据。 树形菜单在网页设计中扮演着重要角色,它可以将复杂的层级关系以简洁直观的方式呈现给用户。...
关于JS树形菜单的啊 网页关于JS树形菜单的啊 网页关于JS树形菜单的啊 网页关于JS树形菜单的啊 网页关于JS树形菜单的啊 网页关于JS树形菜单的啊 网页关于JS树形菜单的啊 网页关于JS树形菜单的啊 网页关于JS树形菜单的...
在网页设计和开发中,树形菜单是一种常见且实用的导航结构,尤其适用于展示层级关系清晰的信息或功能。本文将深入探讨"实用树形菜单插件"这一主题,旨在帮助开发者更好地理解和应用这类插件。 首先,我们来理解什么...