- 浏览: 529690 次
- 性别:
- 来自: 山东济南
文章分类
最新评论
-
dragon_8844:
非常不错,nice
java.util.concurrent 多线程框架 -
wusendong:
很好的文章!受益匪浅,谢谢!
java.util.concurrent 多线程框架 -
SINCE1978:
你也关注并发啊
java.util.concurrent 多线程框架 -
lku1314:
这个不错 刚刚找到这个组建 以前孤陋寡闻了 像lz学习!标 ...
quartz 在WEB中应用小结 -
lliiqiang:
人们对于目标需要的需求明确的去做,对于目标以外的因素是随机的执 ...
flex和后端的数据交互(一)--XML和HTTPService
最近因为一个机会研究了一下dhtmlxgrid的1.4专业版,以下是自己的总结,有差漏或错误请各位网友积极指正!
(由于版权的问题,附件中只有我自己添加的js和css文件)
1. 添加自己的自定义右键菜单
在1.4的专业版中已经添加了自定义右键菜单并且也有示例,但是当在grid上可以选择多个单元格进行操作时,在所选区域上右击却不能显示右键菜单,
原因是grid在有区域被选择后没有修改自己的oncontextmenu属性;我用它自己的右键菜单尝试修改,没有成功。所以自己修改了一个右键菜单添加到了其
中;
以下是我自己修改后的一个右键菜单的js源码,其中添加了不少专业版中的功能;
下面是右键菜单的样式表:
然后将右键菜单添加到grid中:
(1) 修改dhtmlXGridObject对象中的this.init 方法,这个方法在dhtmlXGrid.js文件中。
示例代码如下,注释之间的代码是新增代码:
(2) 将右键菜单隐藏操作添加到grid的单击事件中,即修改this.obj.onclick 属性方法,也是在dhtmlXGrid.js文件中;
将原方法中添加hideMenu()方法;修改后的代码如下:
(3) 修改dhtmlXGridObject对象中的_OnSelectionStop 方法,使得在单元格选择区域(选择区域的实现其实就是添加了一个div区域)上,也可以有
自定义的右键菜单,使得当单击区域时区域消失,右击区域显示菜单;这个方法在dhtmlXGrid_selection.js文件中,代码如下:
(4) 为了实现右键菜单的功能,还需要在表格初始化方法init()前添加mygrid.setRightMenuObject("mygrid"),其中参数就是声明的grid对象名称。
2. 表格左侧添加行号
行号其实就是在原有的grid上添加一个列,放置每一行的indexid就可以了;专业版中已经给出了添加列的属性方法。
(1) 声明两个变量:
(2) 添加一个linenumber列类型,它不接受编辑,只可以选择;要修改的文件是dhtmlXGridCell.js;
在该文件中添加以下代码:
(3) 在dhtmlXGrid.js中添加设定标志位和添加行号的方法:
(4) 因为在初始化构建表格时,dhtmlxgrid本身默认采用的是异步模式,这时候是取不到每一行的id的;在直接浏览html页面时可以成功添加行号,
但是在服务器中不行;并且采用异步模式还有很多隐患,所以修改dhtmlxgrid的数据加载模式:
(5) 在能够引起行号变化的地方,添加重新设置行号的方法:
(6) 在页面中的init()方法后设置是否添加行号标志;
还有需要说明的一点是,添加行号后可能会影响到dhtmlxgrid自己的数据存储方法,这个我还没有修改它自带的数据存储方法,以后修改了再把代码贴上来,数据显示肯定没有问题!
这样右键菜单添加完成,看看示例的截图吧:
我是说是给你要显示的中文做字符转化。另外,xml数据流的构建最好还是用专门的构建包来做,我原来用的是jdom。
这应该是你后端数据读取的问题,在web服务器中设定一下或者进行数据编码格式转换试一下!
行号用方法可以获得的,getSelectedID() or getIndexID(),应该还有别的方法。
这里添加的是列,第一个参数是列的索引号!
insertColumn()这个方法是在专业版中有的!
dhtmlxgrid与后台的数据交互也是基于ajax实现的,专业版中都已经有很完善的方法来实现数据加载和保存,包括一个单元格修改后失去焦点就进行的保存;普通版中没有这些功能,你可以自己实现数据的保存,但是加载你可以用dhtmlxgrid自己的加载方式,毕竟他自己的处理已经很完善了;当然你也可以自己修改dhtmlxgrid的数据交互方面的代码(dhtmlXCommon.js)。
我见有网友实现过和prototype的结合使用,想必和mootools的结合也应该没有问题!
ASP.net我不懂,我原来用java代码测试的,struts MVC、spring MVC和jsp页面处理的都没有问题;你再查看一下后端代码。返回的xml文件流要通过response写回,并且不要进行页面跳转!
ASP.Net返回的字符串是在.aspx.cs中进行response:
然后在js中处理服务器端返回的数据流,不知道是不是对ASP.Net支持不好。现在问题通过其他方式解决了,但是还有很多不懂的地方,需要慢慢挖掘:)
右键功能的实现我会参考你的方法,感谢你的帮助!
另外,你有尝试过dhtmlxGrid和mootools结合使用吗?我还没有深入研究两者的源代码就先这样做了,暂时没有发现兼容性的问题。
ASP.net我不懂,我原来用java代码测试的,struts MVC、spring MVC和jsp页面处理的都没有问题;你再查看一下后端代码。返回的xml文件流要通过response写回,并且不要进行页面跳转!
顺便,如果有网友对修改的部分有问题可以联系我,留下email,我可以把专业版的相关部分代码发给你!
为什么要加载一个字符串呢?
如果你想实现grid普通版和后端数据交互的话,可以参考我的另一个帖子:http://www.iteye.com/topic/53104
(由于版权的问题,附件中只有我自己添加的js和css文件)
1. 添加自己的自定义右键菜单
在1.4的专业版中已经添加了自定义右键菜单并且也有示例,但是当在grid上可以选择多个单元格进行操作时,在所选区域上右击却不能显示右键菜单,
原因是grid在有区域被选择后没有修改自己的oncontextmenu属性;我用它自己的右键菜单尝试修改,没有成功。所以自己修改了一个右键菜单添加到了其
中;
以下是我自己修改后的一个右键菜单的js源码,其中添加了不少专业版中的功能;
// contruct main menu object function contextMenu() { this.items = new Array(); this.addItem = function (item) { this.items[this.items.length] = item; }; this.show = function (oDoc) { var strShow = ""; var i; strShow = "<div id=\"rightmenu\" class=\"menudiv\">"; strShow += "<table border=\"0\" height=\""; strShow += this.items.length * 20; strShow += "\" cellpadding=\"0\" cellspacing=\"0\">"; strShow += "<tr height=\"3\"><td width=\"2\"></td><td>"; strShow += "<table border=\"0\" width=\"100%\" height=\"100%\" cellpadding=0 cellspacing=0 >"; strShow += "<tr><td width=\"23\"></td><td><img src=\" \" height=\"1\" border=\"0\"></td></tr></table>"; strShow += "</td><td width=\"2\"></td></tr>"; strShow += "<tr><td></td><td>"; strShow += "<table border=\"0\" width=\"100%\" height=\"100%\" cellpadding=3 cellspacing=0 >"; oDoc.write(strShow); for (i = 0; i < this.items.length; i++) { this.items[i].show(oDoc); } strShow = "</table></td><td></td></tr>"; strShow += "<tr height=\"3\"><td></td><td>"; strShow += "<table border=\"0\" width=\"100%\" height=\"100%\" cellpadding=0 cellspacing=0>"; strShow += "<tr><td width=\"23\"></td><td><img src=\" \" height=\"1\" border=\"0\"></td></tr></table>"; strShow += "</td><td></td></tr>"; strShow += "</table></div>\n"; oDoc.write(strShow); }; } // contruct menu Item object function contextItem(text, icon, id, type) { this.text = text ? text : ""; this.icon = icon ? icon : ""; this.id = id ? id : ""; this.type = type ? type : "menu"; this.show = function (oDoc) { var strShow = ""; if (this.type == "menu") { strShow += "<tr id='" + this.id + "' "; strShow += "onmouseover=\"changeStyle(this, 'on');\" "; strShow += "onmouseout=\"changeStyle(this, 'out');\" "; //strShow += "onclick=""; //strShow += this.cmd; strShow += ">"; strShow += "<td class=\"ltdexit\" width=\"16\">"; if (this.icon == "") { strShow += " "; } else { strShow += "<img border=\"0\" src=\""; strShow += this.icon; strShow += "\" width=\"16\" height=\"16\" style=\"POSITION: relative\"></img>"; } strShow += "</td><td class=\"mtdexit\">"; strShow += this.text; strShow += "</td><td class=\"rtdexit\" width=\"5\"> </td></tr>"; } else { if (this.type == "separator") { //strShow += "<tr><td class="ltdexit"> </td>"; strShow += "<td class=\"mtdexit\" style='height:10px;' colspan=\"3\"><hr class='hrLine' color=\"#7EC0EE\" size=\"1\"></td></tr>"; } } oDoc.write(strShow); }; } // change style of every menu item when mouse over function changeStyle(obj, cmd) { if (obj) { try { var imgObj = obj.children(0).children(0); if (cmd == "on") { obj.children(0).className = "ltdfocus"; obj.children(1).className = "mtdfocus"; obj.children(2).className = "rtdfocus"; if (imgObj) { if (imgObj.tagName.toUpperCase() == "IMG") { imgObj.style.left = "-1px"; imgObj.style.top = "-1px"; } } } else { if (cmd == "out") { obj.children(0).className = "ltdexit"; obj.children(1).className = "mtdexit"; obj.children(2).className = "rtdexit"; if (imgObj) { if (imgObj.tagName.toUpperCase() == "IMG") { imgObj.style.left = "0px"; imgObj.style.top = "0px"; } } } } } catch (e) { } } } //show right menu on page function showMenu() { var x, y, w, h, ox, oy; x = event.clientX; y = event.clientY; var obj = document.getElementById("rightmenu"); if (obj == null) { return true; } ox = document.body.clientWidth; oy = document.body.clientHeight; if (x > ox || y > oy) { return false; } w = obj.offsetWidth; h = obj.offsetHeight; if ((x + w) > ox) { x = x - w; } if ((y + h) > oy) { y = y - h; } obj.style.posLeft = x + document.body.scrollLeft; obj.style.posTop = y + document.body.scrollTop; obj.style.visibility = "visible"; return false; } //hide right menu function hideMenu() { if (event.button == 0) { var obj = document.getElementById("rightmenu"); if (obj == null) { return true; } obj.style.visibility = "hidden"; obj.style.posLeft = 0; obj.style.posTop = 0; } } //the mothed of contruct right menu dhtmlXGridObject.prototype.makeMenu = function () { var self = this; var myMenu, item; myMenu = new contextMenu(); item = new contextItem("copy", "", "cellCopy", "menu"); myMenu.addItem(item); item = new contextItem("cut", "", "cellCut", "menu"); myMenu.addItem(item); item = new contextItem("paste", "", "cellPaste", "menu"); myMenu.addItem(item); item = new contextItem("add row", "", "rowAdd", "menu"); myMenu.addItem(item); item = new contextItem("", "", "", "separator"); myMenu.addItem(item); item = new contextItem("delete cell(s)", "", "cellDelete", "menu"); myMenu.addItem(item); item = new contextItem("delete row", "", "rowDelete", "menu"); myMenu.addItem(item); myMenu.show(document); delete item; delete myMenu; if (this.objName) { this.objName = "mygrid"; } //add action to every menu item document.getElementById("cellCopy").onclick = new Function(new String(this.objName + ".doRightMenuCopy();")); document.getElementById("cellCut").onclick = new Function(new String(this.objName + ".doRightMenuCut()")); document.getElementById("cellPaste").onclick = new Function(new String(this.objName + ".doRightMenuPaste()")); document.getElementById("rowAdd").onclick = new Function(new String(this.objName + ".doRightMenuAddRow()")); document.getElementById("cellDelete").onclick = new Function(new String(this.objName + ".doRightMenuDelete();")); document.getElementById("rowDelete").onclick = new Function(new String(this.objName + ".deleteSelectedItem();")); }; function toggleMenu(isEnable) { if (isEnable) { document.oncontextmenu = showMenu; } else { document.oncontextmenu = new function () { return true; }; } } //the mothed of show right menu in dhtmlXGridObject dhtmlXGridObject.prototype.showRightMenu = function () { document.attachEvent("onclick", hideMenu); showMenu(); document.attachEvent("oncontextmenu", new Function("return false")); }; //set the name of grid object(it's necessary if you want to response the menu item click) dhtmlXGridObject.prototype.setRightMenuObject = function (para) { this.objName = para; }; //response to click copy item dhtmlXGridObject.prototype.doRightMenuCopy = function () { //alert("doCopy"); if (this._selectionArea) { this.setCSVDelimiter("\t"); this.copyBlockToClipboard(); } else { if (this.cell) { if (!(this.cellType[this.cell._cellIndex] == "linenumber") && !this.editor) { window.clipboardData.setData("text", this.cells(this.getSelectedId(), this.cell._cellIndex).getValue()); } } } }; //response to click cut item dhtmlXGridObject.prototype.doRightMenuCut = function () { //alert("doCut"); if (this._selectionArea) { this.setCSVDelimiter("\t"); this.copyBlockToClipboard(); } else { if (this.cell) { if (!(this.cellType[this.cell._cellIndex] == "linenumber") && !this.editor) { window.clipboardData.setData("text", this.cells(this.getSelectedId(), this.cell._cellIndex).getValue()); } } } this.doRightMenuDelete(); }; //response to click paste item dhtmlXGridObject.prototype.doRightMenuPaste = function () { //alert("doPaste"); this.pasteBlockFromClipboard(); }; //add new row dhtmlXGridObject.prototype.doRightMenuAddRow = function () { var cc = this.getColumnCount(); var newrow = new Array(cc + 1); this.addRow((new Date()).valueOf(), newrow, this.getRowIndex(this.getSelectedId())); cc = null; newrow = null; }; //response to click delete item dhtmlXGridObject.prototype.doRightMenuDelete = function () { //alert("doDelete"); if (this._selectionArea) { this.clearSelection(); var startRow = this._selectionArea.LeftTopRow; var startCol = this._selectionArea.LeftTopCol; var endRow = this._selectionArea.RightBottomRow; var endCol = this._selectionArea.RightBottomCol; for (var i = startRow; i < endRow + 1; i++) { for (var j = startCol; j < endCol + 1; j++) { if (!(this.cellType[j] == "linenumber")) { this.cells(this.getRowId(i), j).setValue(); } } } startRow = null; startCol = null; endRow = null; endCol = null; } else { if (this.cell) { if (!(this.cellType[this.cell._cellIndex] == "linenumber") && !this.editor) { this.cells(this.getSelectedId(), this.cell._cellIndex).setValue(); } } } };
下面是右键菜单的样式表:
TABLE { font-family: \"Tahoma\", \"Verdana\", \"\u5b8b\u4f53\"; font-size: 9pt } .mtdfocus { background-color: #EDF5FE; border-bottom: #B0E2FF 1px solid; border-top: #B0E2FF 1px solid; cursor: hand } .mtdexit { background-color: whitesmoke; border-bottom: #ffffff 1px solid; border-top: #ffffff 1px solid; } .ltdfocus { background-color: #EDF5FE; border-bottom: #B0E2FF 1px solid; border-top: #B0E2FF 1px solid; border-left: whitesmoke 1px solid; cursor: hand } .ltdexit { background-color: whitesmoke; border-bottom: #ffffff 1px solid; border-top: #ffffff 1px solid; border-left: whitesmoke 1px solid } .rtdfocus { background-color: #EDF5FE; border-bottom: #B0E2FF 1px solid; border-top: #B0E2FF 1px solid; border-right: whitesmoke 1px solid; cursor: hand } .rtdexit { background-color: whitesmoke; border-bottom: #ffffff 1px solid; border-top: #ffffff 1px solid; border-right: whitesmoke 1px solid } .menudiv { background-color: whitesmoke; border: #00B2EE 1px solid; left: 0px; position: absolute; top: 0px; visibility: hidden; z-index: 10; } .hrLine { position: absolute; bottom: 52px; }
然后将右键菜单添加到grid中:
(1) 修改dhtmlXGridObject对象中的this.init 方法,这个方法在dhtmlXGrid.js文件中。
示例代码如下,注释之间的代码是新增代码:
this.init = function (fl) { if ((this.isTreeGrid()) && (!this._h2)) { this._aEx = new _dhtmlxArray(); this._h2 = new dhtmlxHierarchy(); if ((this._fake) && (!this._realfake)) { this._fake._h2 = this._h2; } this._tgc = {imgURL:null}; } if (!this._hstyles) { return; } //daoger_start //constructe components of right menu this.makeMenu(); //add rightclick action this.setOnRightClick(this.showRightMenu); //daoger_end this.editStop(); this.lastClicked = null; this.resized = null; this.fldSorted = this.r_fldSorted = null; this.gridWidth = 0; this.gridHeight = 0; this.cellWidthPX = new Array(0); this.cellWidthPC = new Array(0); if (this.hdr.rows.length > 0) { this.clearAll(true); } ...... //方法的以后部分省略
(2) 将右键菜单隐藏操作添加到grid的单击事件中,即修改this.obj.onclick 属性方法,也是在dhtmlXGrid.js文件中;
将原方法中添加hideMenu()方法;修改后的代码如下:
...... this.obj.onmousemove = this._drawTooltip; //daoger_start //this.obj.onclick = new Function("e", "this.grid._doClick(e||window.event);if (this.grid._sclE)this.grid.editCell(e||window.event);(e||event).cancelBubble=true;"); //hide right menu when left click this.obj.onclick = new Function("e", "hideMenu();this.grid._doClick(e||window.event);if (this.grid._sclE)this.grid.editCell(e||window.event);(e||event).cancelBubble=true;"); //daoger_end if (_isMacOS) { this.entBox.oncontextmenu = new Function("e", "return this.grid._doContClick(e||window.event);"); } ......
(3) 修改dhtmlXGridObject对象中的_OnSelectionStop 方法,使得在单元格选择区域(选择区域的实现其实就是添加了一个div区域)上,也可以有
自定义的右键菜单,使得当单击区域时区域消失,右击区域显示菜单;这个方法在dhtmlXGrid_selection.js文件中,代码如下:
dhtmlXGridObject.prototype._OnSelectionStop = function (event) { var self = this; if (this._blsTimer) { window.clearTimeout(this._blsTimer); } this.obj.onmousedown = function (e) { e = e || event; //daoger_start //self._OnSelectionStart(e, this); //define the different operations of right click and left click if (e.button == 1) { self._OnSelectionStart(e, this);//do select } else { if (e.button == 2) { self.showRightMenu();//show right menu } } //daoger_end return true; }; this.obj.onmousemove = this.obj.onmmold || null; document.body.onmouseup = this._oldDMP || null; if (parseInt(this._selectionObj.style.width) < 2 && parseInt(this._selectionObj.style.height) < 2) { this._HideSelection(); } else { var src = this.getFirstParentOfType(event.srcElement || event.target, "TD"); if ((!src) || (!src.parentNode.idd)) { src = this._endSelectionCell; } while (src.tagName.toLowerCase() != "td") { src = src.parentNode; } this._stopSelectionCell = src; this._selectionArea = this._RedrawSelectionPos(this._startSelectionCell, this._stopSelectionCell); this.callEvent("onBlockSelected", []); } };
(4) 为了实现右键菜单的功能,还需要在表格初始化方法init()前添加mygrid.setRightMenuObject("mygrid"),其中参数就是声明的grid对象名称。
2. 表格左侧添加行号
行号其实就是在原有的grid上添加一个列,放置每一行的indexid就可以了;专业版中已经给出了添加列的属性方法。
(1) 声明两个变量:
var lineflag = false;//是否添加行号判定标志 var itemsid = new Array(0);//所有行的id数组
(2) 添加一个linenumber列类型,它不接受编辑,只可以选择;要修改的文件是dhtmlXGridCell.js;
在该文件中添加以下代码:
//daoger_start //create linenumber type of column function eXcell_linenumber(cell) { this.base = eXcell_ed; this.base(cell); this.editable = false; this.edit = function () { }; this.isDisabled = function () { return true; }; } //take on all mothed of ed type eXcell_linenumber.prototype = new eXcell_ed; //daoger_end
(3) 在dhtmlXGrid.js中添加设定标志位和添加行号的方法:
//daoger_start_addLineNumber //the mothed of add line number on the first column dhtmlXGridObject.prototype.addLineNumber = function () { var linecell = null; itemsid = this.getAllItemIds().split(","); if (itemsid.length > 1) { for (var i = 0; i < itemsid.length; i++) { linecell = this.cells(itemsid[i], 0); linecell.setValue(this.getRowIndex(itemsid[i]) + 1); } } }; dhtmlXGridObject.prototype.setLineFlag = function (para) { if (para) { lineflag = true; } if (lineflag) { //add line number column at the first index this.insertColumn(0, " ", "linenumber", 30); //add line number on this column this.addLineNumber(); } }; //daoger_end
(4) 因为在初始化构建表格时,dhtmlxgrid本身默认采用的是异步模式,这时候是取不到每一行的id的;在直接浏览html页面时可以成功添加行号,
但是在服务器中不行;并且采用异步模式还有很多隐患,所以修改dhtmlxgrid的数据加载模式:
//daoger_start this.xmlLoader = new dtmlXMLLoaderObject(this.doLoadDetails, window, false, this.no_cashe); //this.xmlLoader = new dtmlXMLLoaderObject(this.doLoadDetails, window, true, this.no_cashe); //daoger_end
(5) 在能够引起行号变化的地方,添加重新设置行号的方法:
this._onHeaderClick = function (e) { var that = this.grid; var el = that.getFirstParentOfType(_isIE ? event.srcElement : e.target, "TD"); if (!(this.grid.callEvent("onHeaderClick", [el._cellIndexS, (e || event)]))) { return false; } if (this.grid.resized == null) { that.sortField(el._cellIndexS, false, el); } //daoger_start //reset line number of the first column after sorting if (lineflag) { that.addLineNumber(); } //daoger_end }; dhtmlXGridObject.prototype.addRow = function (new_id, text, ind) { var r = this._addRow(new_id, text, ind); if (!this.dragContext) { this.callEvent("onRowAdded", [new_id]); } this.callEvent("onRowCreated", [r.idd, r, null]); if (this.pagingOn) { this.changePage(this.currentPage); } this.setSizes(); r._added = true; this.callEvent("onGridReconstructed", []); //daoger_start //reset line number of the first column after add a new row if (lineflag) { this.addLineNumber(); } //daoger_end return r; }; dhtmlXGridObject.prototype.deleteRow = function (row_id, node) { if (!node) { node = this.getRowById(row_id); } if (!node) { return; } this.editStop(); if (this.callEvent("onBeforeRowDeleted", [row_id]) == false) { return false; } if (this.cellType._dhx_find("tree") != -1) { this._removeTrGrRow(node); } else { if (node.parentNode) { node.parentNode.removeChild(node); } var ind = this.rowsCol._dhx_find(node); if (ind != -1) { this.rowsCol._dhx_removeAt(ind); } else { ind = this.rowsBuffer[0]._dhx_find(row_id); if (ind >= 0) { this.rowsBuffer[0]._dhx_removeAt(ind); this.rowsBuffer[1]._dhx_removeAt(ind); } } this.rowsAr[row_id] = null; } for (var i = 0; i < this.selectedRows.length; i++) { if (this.selectedRows[i].idd == row_id) { this.selectedRows._dhx_removeAt(i); } } this.callEvent("onGridReconstructed", []); if (this.pagingOn) { this.changePage(); } this.setSizes(); //daoger_start //reset line number of the first column after deleting a row if (lineflag) { this.addLineNumber(); } //daoger_end return true; };
(6) 在页面中的init()方法后设置是否添加行号标志;
mygrid.setLineFlag(true);
还有需要说明的一点是,添加行号后可能会影响到dhtmlxgrid自己的数据存储方法,这个我还没有修改它自带的数据存储方法,以后修改了再把代码贴上来,数据显示肯定没有问题!
这样右键菜单添加完成,看看示例的截图吧:
- myDhtmlXGrid.rar (3.7 KB)
- 描述: 右键菜单
- 下载次数: 417
评论
18 楼
daoger
2007-11-28
javaman1982 写道
封装到xml是这么实现的:
response.setContentType("text/xml; charset=gbk");
response.setHeader("Cache-Control", "no-cache");
xml="<?xml version=\"1.0\" encoding=\"gb2312\"?>";
xml+="<rows>";
for(int i=1;i<=personList.size();i++){
Person person=(Person)personList.get(i-1);
xml+="<row id=\""+i+"\">";
xml+="<cell>";
xml+=person.getId();
xml+="</cell>";
xml+="<cell>";
xml+=person.getName().trim();
xml+="</cell>";
xml+="<cell>";
xml+=person.getAddress().trim();
xml+="</cell>";
xml+="</row>";
System.out.println(person.getName().trim());
}
xml+="</rows>";
out.println(xml);
转了还是不行呢?
response.setContentType("text/xml; charset=gbk");
response.setHeader("Cache-Control", "no-cache");
xml="<?xml version=\"1.0\" encoding=\"gb2312\"?>";
xml+="<rows>";
for(int i=1;i<=personList.size();i++){
Person person=(Person)personList.get(i-1);
xml+="<row id=\""+i+"\">";
xml+="<cell>";
xml+=person.getId();
xml+="</cell>";
xml+="<cell>";
xml+=person.getName().trim();
xml+="</cell>";
xml+="<cell>";
xml+=person.getAddress().trim();
xml+="</cell>";
xml+="</row>";
System.out.println(person.getName().trim());
}
xml+="</rows>";
out.println(xml);
转了还是不行呢?
我是说是给你要显示的中文做字符转化。另外,xml数据流的构建最好还是用专门的构建包来做,我原来用的是jdom。
17 楼
javaman1982
2007-11-28
封装到xml是这么实现的:
response.setContentType("text/xml; charset=gbk");
response.setHeader("Cache-Control", "no-cache");
xml="<?xml version=\"1.0\" encoding=\"gb2312\"?>";
xml+="<rows>";
for(int i=1;i<=personList.size();i++){
Person person=(Person)personList.get(i-1);
xml+="<row id=\""+i+"\">";
xml+="<cell>";
xml+=person.getId();
xml+="</cell>";
xml+="<cell>";
xml+=person.getName().trim();
xml+="</cell>";
xml+="<cell>";
xml+=person.getAddress().trim();
xml+="</cell>";
xml+="</row>";
System.out.println(person.getName().trim());
}
xml+="</rows>";
out.println(xml);
转了还是不行呢?
response.setContentType("text/xml; charset=gbk");
response.setHeader("Cache-Control", "no-cache");
xml="<?xml version=\"1.0\" encoding=\"gb2312\"?>";
xml+="<rows>";
for(int i=1;i<=personList.size();i++){
Person person=(Person)personList.get(i-1);
xml+="<row id=\""+i+"\">";
xml+="<cell>";
xml+=person.getId();
xml+="</cell>";
xml+="<cell>";
xml+=person.getName().trim();
xml+="</cell>";
xml+="<cell>";
xml+=person.getAddress().trim();
xml+="</cell>";
xml+="</row>";
System.out.println(person.getName().trim());
}
xml+="</rows>";
out.println(xml);
转了还是不行呢?
16 楼
daoger
2007-11-28
javaman1982 写道
问哈 如果有中文 显示出来都是乱码 页面的编码方式utf-8和gb2312都试了都不行 怎么解决哈 ?
这应该是你后端数据读取的问题,在web服务器中设定一下或者进行数据编码格式转换试一下!
15 楼
daoger
2007-11-28
zhuwei20 写道
this.insertColumn(0, " ", "linenumber", 30);
你添加行号的这个是从哪儿获得的函数?insertColumn()好象免费版里面没有吧?
你添加行号的这个是从哪儿获得的函数?insertColumn()好象免费版里面没有吧?
行号用方法可以获得的,getSelectedID() or getIndexID(),应该还有别的方法。
这里添加的是列,第一个参数是列的索引号!
insertColumn()这个方法是在专业版中有的!
14 楼
javaman1982
2007-11-28
问哈 如果有中文 显示出来都是乱码 页面的编码方式utf-8和gb2312都试了都不行 怎么解决哈 ?
13 楼
zhuwei20
2007-11-27
this.insertColumn(0, " ", "linenumber", 30);
你添加行号的这个是从哪儿获得的函数?insertColumn()好象免费版里面没有吧?
你添加行号的这个是从哪儿获得的函数?insertColumn()好象免费版里面没有吧?
12 楼
lintry
2007-11-13
Ajax直接把data传入的form里面的参数直接传递到url,然后在onComplete里面调用loadXMLString。retrieved是当loadXMLString成功后调用的函数
var myAjax = new Ajax(url, { method: 'post', data:frm, onComplete: function(){ mygrid.loadXMLString(this.response.text, retrieved); } }); myAjax.request();
11 楼
vtsuper
2007-11-13
請問可以提供Ajax.request與loadXMLString的那段code供小弟參考呢?
10 楼
lintry
2007-11-09
因为想使用mootools的Ajax来从服务器端获取xml返回,所以改写了一个loadXMLString,是根据loadXML函数修改的
dhtmlXGridObject.prototype.loadXMLString = function(xmlstring, afterCall){ if (afterCall) this.xmlLoader.waitCall=afterCall; this.xmlLoader.loadXMLString(xmlstring); }
9 楼
vtsuper
2007-11-07
"数据的保存"是指什麼呢???
我已看過這編內容
http://www.iteye.com/topic/53104
但應該不太合用...
我已看過這編內容
http://www.iteye.com/topic/53104
但應該不太合用...
8 楼
daoger
2007-11-07
vtsuper 写道
不知道各位有沒有這樣的經驗
我希望把dhtmlxgrid配合prototype.js的Ajax.request使用,但
dhtmlxgrid 用
ajax.request用
我希望使用ajax.request,因為可以自行控制我需要的effect,但dhtmlxgrid非用loadXML不可..
請問有解釋方法嗎???
我希望把dhtmlxgrid配合prototype.js的Ajax.request使用,但
dhtmlxgrid 用
loadXML(data.php);
ajax.request用
ajaxObj = new Ajax.Request( 'data.php', { method: 'post', postBody: pars, asynchronous: true, onCreate:function(result){ effectStart(); }, onSuccess:function(result){ result(result); }, onComplete:function(result){ effectEnd(); } } );
我希望使用ajax.request,因為可以自行控制我需要的effect,但dhtmlxgrid非用loadXML不可..
請問有解釋方法嗎???
dhtmlxgrid与后台的数据交互也是基于ajax实现的,专业版中都已经有很完善的方法来实现数据加载和保存,包括一个单元格修改后失去焦点就进行的保存;普通版中没有这些功能,你可以自己实现数据的保存,但是加载你可以用dhtmlxgrid自己的加载方式,毕竟他自己的处理已经很完善了;当然你也可以自己修改dhtmlxgrid的数据交互方面的代码(dhtmlXCommon.js)。
7 楼
daoger
2007-11-07
xml 写道
另外,你有尝试过dhtmlxGrid和mootools结合使用吗?
我见有网友实现过和prototype的结合使用,想必和mootools的结合也应该没有问题!
6 楼
vtsuper
2007-11-07
不知道各位有沒有這樣的經驗
我希望把dhtmlxgrid配合prototype.js的Ajax.request使用,但
dhtmlxgrid 用
ajax.request用
我希望使用ajax.request,因為可以自行控制我需要的effect,但dhtmlxgrid非用loadXML不可..
請問有解釋方法嗎???
我希望把dhtmlxgrid配合prototype.js的Ajax.request使用,但
dhtmlxgrid 用
loadXML(data.php);
ajax.request用
ajaxObj = new Ajax.Request( 'data.php', { method: 'post', postBody: pars, asynchronous: true, onCreate:function(result){ effectStart(); }, onSuccess:function(result){ result(result); }, onComplete:function(result){ effectEnd(); } } );
我希望使用ajax.request,因為可以自行控制我需要的effect,但dhtmlxgrid非用loadXML不可..
請問有解釋方法嗎???
5 楼
xml
2007-11-07
daoger 写道
ASP.net我不懂,我原来用java代码测试的,struts MVC、spring MVC和jsp页面处理的都没有问题;你再查看一下后端代码。返回的xml文件流要通过response写回,并且不要进行页面跳转!
ASP.Net返回的字符串是在.aspx.cs中进行response:
protected void Page_Load(object sender, EventArgs e) { Response.Charset = "utf-8"; Response.ContentType = "text/xml"; Response.ContentEncoding = System.Text.Encoding.GetEncoding("utf-8"); string strXml; //程序后面对strXml进行赋值 …………………… Response.Write(strXml); Response.End(); }
然后在js中处理服务器端返回的数据流,不知道是不是对ASP.Net支持不好。现在问题通过其他方式解决了,但是还有很多不懂的地方,需要慢慢挖掘:)
右键功能的实现我会参考你的方法,感谢你的帮助!
另外,你有尝试过dhtmlxGrid和mootools结合使用吗?我还没有深入研究两者的源代码就先这样做了,暂时没有发现兼容性的问题。
4 楼
daoger
2007-11-07
xml 写道
我的测试代码基于ASP.Net,曾经这样写过:
最后是将客户端获得的xml串解析后用mygrid.addRow来构建每一组row,稍微麻烦了一点。
mygrid.loadXML("QInfo.aspx"); //但是返回错误
最后是将客户端获得的xml串解析后用mygrid.addRow来构建每一组row,稍微麻烦了一点。
ASP.net我不懂,我原来用java代码测试的,struts MVC、spring MVC和jsp页面处理的都没有问题;你再查看一下后端代码。返回的xml文件流要通过response写回,并且不要进行页面跳转!
顺便,如果有网友对修改的部分有问题可以联系我,留下email,我可以把专业版的相关部分代码发给你!
3 楼
xml
2007-11-06
我的测试代码基于ASP.Net,曾经这样写过:
最后是将客户端获得的xml串解析后用mygrid.addRow来构建每一组row,稍微麻烦了一点。
mygrid.loadXML("QInfo.aspx"); //但是返回错误
最后是将客户端获得的xml串解析后用mygrid.addRow来构建每一组row,稍微麻烦了一点。
2 楼
daoger
2007-11-06
xml 写道
通过loadXML()可以方便的加载xml文件到grid中,但是如果现在代码中是xml string,除了分节点解析外,有没有直接读取xml string的方法呢?
--重新查看了文档,这是专业版中的方法,我用的是试用版,看来必须得逐步解析了。
--重新查看了文档,这是专业版中的方法,我用的是试用版,看来必须得逐步解析了。
loadXML String() //load content from specified string
为什么要加载一个字符串呢?
如果你想实现grid普通版和后端数据交互的话,可以参考我的另一个帖子:http://www.iteye.com/topic/53104
1 楼
xml
2007-11-05
通过loadXML()可以方便的加载xml文件到grid中,但是如果现在代码中是xml string,除了分节点解析外,有没有直接读取xml string的方法呢?
--重新查看了文档,这是专业版中的方法,我用的是试用版,看来必须得逐步解析了。
--重新查看了文档,这是专业版中的方法,我用的是试用版,看来必须得逐步解析了。
loadXML String() //load content from specified string
发表评论
-
ubuntu14.04下编译安装Tora
2015-08-11 16:19 1199需预先安装oracle客户端;以下类库,有的可能需要提前安 ... -
ubuntu14.04下oracle客户端最小化安装
2015-08-11 16:04 1048在Oracle官网下载Oracle Instant Clien ... -
ubuntu14.04下编译安装QT
2015-08-11 16:03 14941. 首先配置一些编译Qt ... -
55种开源可视化数据分析工具
2015-07-22 14:50 0http://mp.weixin.qq.com/s?__bi ... -
响应式设计理念
2013-09-29 10:00 0概念 响应式Web设计(Responsive Web desi ... -
Liferay 使用随笔
2010-04-19 14:18 01.如何根据权限去除每一个portlet中右上角的选项。 关于 ... -
Liferay中ajax应用用户session超时
2010-03-26 09:31 3905基于Liferay Portal开发ajax应用时,如果长时间 ... -
Liferay portlet实例化配置
2009-11-10 09:06 4363在默认的情况下,一个p ... -
带checkbox的dhtmlxtree菜单树异步加载时的问题解决
2009-10-24 11:27 5955最近一直很忙,自己负责几个模块的设计开发,还有和其他服务接口的 ... -
JS代码示例
2009-10-21 14:23 22771.数组操作时的push var a = [],b = [ ... -
dhtmlxtree异步加载时的一个bug修正
2009-09-15 10:00 3802前面已经对dhtmlx的东西有所介绍,使用中也发现了不少bug ... -
WEB Page to PDF
2009-06-17 11:10 2520现在有很多网页页面转换成PDF文档的支持项目,我使用的是pd4 ... -
Liferay中使用dhtmlxlayout在IE下的问题
2009-06-12 13:43 2087Liferay 中使用dhemtlx系列UI的时候,dhtml ... -
Liferay相关配置
2009-06-10 13:35 1250修改liferay中portlet的加载目录 前面 ... -
Spring JDBC对Oracle10g数据库操作时RowSet的问题
2009-05-19 08:56 3435使用Spring JDBC对Oracle10g进行数据库分页的 ... -
Dynamic Tables In JavaScript for IE and Firefox
2009-05-06 14:03 1704http://www.sweetvision.com/2007 ... -
liferay中对struts桥接处理后的response
2009-04-18 14:29 1828对于在liferay开发平台中 ... -
liferay开发小记---Struts,Spring,Hibernate架构
2009-04-07 11:11 6249liferay有自己的struts和spring扩展,有兴趣的 ... -
liferay开发小记---portlet文件构造
2009-04-03 17:09 3277书接上回,说说portlet的开发,每一个portlet就是对 ... -
liferay开发小记---开发环境的搭建
2009-04-02 13:42 3797用惯了MyEclipse,我的环境也是在它上面搭建的,试用过M ...
相关推荐
5. **扩展性**:DHTMLXGrid支持添加自定义列类型、工具栏按钮和右键菜单,可以灵活扩展其功能。 6. **数据导出**:可以将表格数据导出为CSV、Excel、PDF等多种格式。 7. **集成其他DHTMLX组件**:如DHTMLXChart,...
下面我们将详细探讨如何在dhtmlxGrid中实现这一功能。 一、添加行号的效果 在dhtmlxGrid中添加行号后,每一行数据前面都会有一个数字标识,这个数字代表了该行在表格中的顺序。这种视觉提示对于用户浏览大量数据...
实现这一功能有两种主要的方法: 1. **使用ContextMenuStrip控件**:这是最常见的方法之一,通过设置DataGridView的`ContextMenuStrip`属性来关联一个预定义的上下文菜单。这种方式的优点在于能够灵活地控制菜单项...
在编程领域,易语言是一种基于汉语词汇的编程系统,它为用户提供了一种直观、易于理解的编程环境。本文将深入探讨“易语言高级表格...通过学习和掌握这一功能,开发者可以提高易语言应用程序的用户体验和功能多样性。
然而,`RichTextBox`默认并不提供行号功能,开发者通常需要自己实现这一功能。这个话题“RichTextBox增加行号功能”涉及到的技术点主要包括自定义控件、事件处理以及坐标计算。 首先,为了给`RichTextBox`添加行号...
- 可以结合使用快捷键、菜单栏和右键菜单,根据具体情况选择最方便的操作方式。 8. **版本兼容性**: 这些插入行和列的方法适用于大部分Excel版本,包括Excel 2010、2013、2016、2019以及Office 365订阅版。 ...
这涉及到一些技术难点,下面我们将详细探讨如何实现这一功能。 首先,我们要理解WPF中的数据绑定和自定义控件的概念。在WPF中,数据绑定允许UI元素与后台数据模型直接关联,而自定义控件则允许我们根据需求扩展或...
本话题主要关注的是在易语言中如何实现高级表格(可能指的是“易语言表格控件”)的右键菜单功能,特别是选择当前行的源码。这种功能常见于数据管理应用中,用户可以通过右键点击表格中的某一行,然后执行选定的操作...
jd-gui是一个非常好的java反编译工具。但是有一点就是用它导出的java文件与源代码中的行号大部分是对应不上的。jd-gui采用将行号以注释的方式显示出来比如在某行开头有个这个”/* 100 */” 表示这行代码在源代码里的...
标题中的“易语言高表格右键选中行并弹出菜单源码”指的是在易语言编程环境下,针对具有高表格特性的控件实现的一种功能,即用户通过鼠标右键点击时,能够选中当前行并弹出关联的操作菜单。这个功能在数据管理、表格...
为了提高用户体验,开发者常常会通过JavaScript实现自定义的行号功能,以替代那些体积较大、功能丰富的文本编辑器。 本文将深入探讨如何使用JavaScript为HTML页面中的 `textarea` 添加行号效果,以实现一个轻量级的...
在编程环境中,代码行号显示和自动提示功能是提高开发效率的重要工具。对于经典的Visual C++ 6.0(简称VC6.0)这样的IDE来说,虽然其基础功能强大,但原生并未内置这些便捷特性。然而,通过安装第三方插件,我们可以...
- 如果插件提供了设置选项,可以在插件的菜单或右键菜单中找到,调整行号的颜色、字体大小等显示样式。 - 请注意,不同的插件可能会有不同的使用方式和功能,具体操作需参照插件的说明文档。 4. **注意事项** - ...
银行联行号表-人行大小额系统行号-带省市区归属地 截止2019年底 带联行号归属地,覆盖全国所有银行 人行大小额联行号编码规则 1、联行号工12位 2、前3位代表银行 3、4~7位(4位数字)代表省市 4、8~11位(4位数字)...
在前端开发中,给`textarea`元素添加行号功能是一个常见的需求,特别是在代码编辑器或者文本编辑器的实现中。`textarea-line-number`是一个JavaScript插件,专门用于为`textarea`提供显示行号的功能,提高了用户体验...
在Word中插入代码并实现与IDE(集成开发环境)类似的显示效果,主要是通过设置行号和应用代码高亮样式来实现。以下将详细介绍如何操作。 首先,为了在Word中显示代码行号,你可以采取以下步骤: 1. **插入代码样式...
2. **modSysMenu.bas**:此模块可能涉及到系统菜单的管理和操作,比如添加自定义菜单项到系统右键菜单,或者处理窗口操作相关的功能。 3. **Module1.bas**:通常这是VBScript中的默认模块,可能包含了程序的核心...
"为文本增加行号和去掉行号"这个程序提供了一种便捷的方式来满足这方面的需求。下面将详细阐述相关知识点: 1. **文本处理**:在计算机科学中,文本处理指的是对文本数据进行操作,如读取、修改、分析和格式化。...
自己写的一个继承自JTable的带有行号显示功能的表格,支持增删,设置行高等动态操作。