jqueryのFlexigridの改造、選択した行の内容の取得をサポートして、2つの表の行は互いに移動して、行はイベントを選択して、dwrをサポートします


flexigridに追加されました
$.fn.flexGetRows = function () { // function to add data to grid danielinbiti
	return this[0].grid.getRows();
};
$.fn.addRows = function (rowList) { // function to add data to grid danielinbiti
	return this[0].grid.addRows(rowList);
};
$.fn.getSelectRowsToGrid = function () { // function to add data to grid danielinbiti
	return this[0].grid.getSelectRowsToGrid();
};
$.fn.getGridAllRows = function () { // function to add data to grid danielinbiti
	return this[0].grid.getGridAllRows();
};
$.fn.getGridAllRowsForObj = function () { // function to add data to grid danielinbiti
	return this[0].grid.getGridAllRowsForObj();
};
$.fn.clearSelect = function () { // function to add data to grid danielinbiti
	return this[0].grid.clearSelect();
};
$.fn.deleteSelectRows = function () { // function to add data to grid danielinbiti
	return this[0].grid.deleteSelectRows();
};
$.fn.queryData = function (params) { // function to add data to grid danielinbiti
	return this[0].grid.queryData(params);
};

行選択メソッドパラメータが追加されました
onRowClick:function(){return true},//add by danielinbiti
Flexigridの改造後のソースコード
/*
 * Flexigrid for jQuery -  v1.1
 *
 * Copyright (c) 2008 Paulo P. Marinas (code.google.com/p/flexigrid/)
 * Dual licensed under the MIT or GPL Version 2 licenses.
 * http://jquery.org/license
 *
 */
(function ($) {
	$.addFlex = function (t, p) {
		if (t.grid) return false; //return if already exist
		p = $.extend({ //apply default properties
			height: 200, //default height
			width: 'auto', //auto width
			striped: true, //apply odd even stripes
			novstripe: false,
			minwidth: 30, //min width of columns
			minheight: 80, //min height of columns
			resizable: true, //allow table resizing
			url: false, //URL if using data from AJAX
			dwrAction:function(){},
			method: 'POST', //data sending method
			dataType: 'xml', //type of data for AJAX, either xml or json
			errormsg: 'Connection Error',
			usepager: false,
			nowrap: true,
			page: 1, //current page
			total: 1, //total pages
			useRp: true, //use the results per page select box
			rp: 15, //results per page
			rpOptions: [10, 15, 20, 30, 50], //allowed per-page values 
			title: false,
			pagestat: 'Displaying {from} to {to} of {total} items',
			pagetext: 'Page',
			outof: 'of',
			findtext: 'Find',
			procmsg: 'Processing, please wait ...',
			query: '',
			qtype: '',
			nomsg: 'No items',
			minColToggle: 1, //minimum allowed column to be hidden
			showToggleBtn: true, //show or hide column toggle popup
			hideOnSubmit: true,
			autoload: true,
			blockOpacity: 0.5,
			preProcess: false,
			onDragCol: false,
			onToggleCol: false,
			onChangeSort: false,
			onSuccess: false,
			onError: false,
			onRowClick:function(){return true},//add by jej
			onSubmit: false //using a custom populate function
		}, p);
		$(t).show() //show if hidden
			.attr({
				cellPadding: 0,
				cellSpacing: 0,
				border: 0
			}) //remove padding and spacing
			.removeAttr('width'); //remove width properties
		//create grid class
		var g = {
			hset: {},
			rePosDrag: function () {
				var cdleft = 0 - this.hDiv.scrollLeft;
				if (this.hDiv.scrollLeft > 0) cdleft -= Math.floor(p.cgwidth / 2);
				$(g.cDrag).css({
					top: g.hDiv.offsetTop + 1
				});
				var cdpad = this.cdpad;
				$('div', g.cDrag).hide();
				$('thead tr:first th:visible', this.hDiv).each(function () {
					var n = $('thead tr:first th:visible', g.hDiv).index(this);
					var cdpos = parseInt($('div', this).width());
					if (cdleft == 0) cdleft -= Math.floor(p.cgwidth / 2);
					cdpos = cdpos + cdleft + cdpad;
					if (isNaN(cdpos)) {
						cdpos = 0;
					}
					$('div:eq(' + n + ')', g.cDrag).css({
						'left': cdpos + 'px'
					}).show();
					cdleft = cdpos;
				});
			},
			fixHeight: function (newH) {
				newH = false;
				if (!newH) newH = $(g.bDiv).height();
				var hdHeight = $(this.hDiv).height();
				$('div', this.cDrag).each(
					function () {
						$(this).height(newH + hdHeight);
					}
				);
				var nd = parseInt($(g.nDiv).height());
				if (nd > newH) $(g.nDiv).height(newH).width(200);
				else $(g.nDiv).height('auto').width('auto');
				$(g.block).css({
					height: newH,
					marginBottom: (newH * -1)
				});
				var hrH = g.bDiv.offsetTop + newH;
				if (p.height != 'auto' && p.resizable) hrH = g.vDiv.offsetTop;
				$(g.rDiv).css({
					height: hrH
				});
			},
			dragStart: function (dragtype, e, obj) { //default drag function start
				if (dragtype == 'colresize') {//column resize
					$(g.nDiv).hide();
					$(g.nBtn).hide();
					var n = $('div', this.cDrag).index(obj);
					var ow = $('th:visible div:eq(' + n + ')', this.hDiv).width();
					$(obj).addClass('dragging').siblings().hide();
					$(obj).prev().addClass('dragging').show();
					this.colresize = {
						startX: e.pageX,
						ol: parseInt(obj.style.left),
						ow: ow,
						n: n
					};
					$('body').css('cursor', 'col-resize');
				} else if (dragtype == 'vresize') {//table resize
					var hgo = false;
					$('body').css('cursor', 'row-resize');
					if (obj) {
						hgo = true;
						$('body').css('cursor', 'col-resize');
					}
					this.vresize = {
						h: p.height,
						sy: e.pageY,
						w: p.width,
						sx: e.pageX,
						hgo: hgo
					};
				} else if (dragtype == 'colMove') {//column header drag
					$(g.nDiv).hide();
					$(g.nBtn).hide();
					this.hset = $(this.hDiv).offset();
					this.hset.right = this.hset.left + $('table', this.hDiv).width();
					this.hset.bottom = this.hset.top + $('table', this.hDiv).height();
					this.dcol = obj;
					this.dcoln = $('th', this.hDiv).index(obj);
					this.colCopy = document.createElement("div");
					this.colCopy.className = "colCopy";
					this.colCopy.innerHTML = obj.innerHTML;
					if ($.browser.msie) {
						this.colCopy.className = "colCopy ie";
					}
					$(this.colCopy).css({
						position: 'absolute',
						float: 'left',
						display: 'none',
						textAlign: obj.align
					});
					$('body').append(this.colCopy);
					$(this.cDrag).hide();
				}
				$('body').noSelect();
			},
			dragMove: function (e) {
				if (this.colresize) {//column resize
					var n = this.colresize.n;
					var diff = e.pageX - this.colresize.startX;
					var nleft = this.colresize.ol + diff;
					var nw = this.colresize.ow + diff;
					if (nw > p.minwidth) {
						$('div:eq(' + n + ')', this.cDrag).css('left', nleft);
						this.colresize.nw = nw;
					}
				} else if (this.vresize) {//table resize
					var v = this.vresize;
					var y = e.pageY;
					var diff = y - v.sy;
					if (!p.defwidth) p.defwidth = p.width;
					if (p.width != 'auto' && !p.nohresize && v.hgo) {
						var x = e.pageX;
						var xdiff = x - v.sx;
						var newW = v.w + xdiff;
						if (newW > p.defwidth) {
							this.gDiv.style.width = newW + 'px';
							p.width = newW;
						}
					}
					var newH = v.h + diff;
					if ((newH > p.minheight || p.height < p.minheight) && !v.hgo) {
						this.bDiv.style.height = newH + 'px';
						p.height = newH;
						this.fixHeight(newH);
					}
					v = null;
				} else if (this.colCopy) {
					$(this.dcol).addClass('thMove').removeClass('thOver');
					if (e.pageX > this.hset.right || e.pageX < this.hset.left || e.pageY > this.hset.bottom || e.pageY < this.hset.top) {
						//this.dragEnd();
						$('body').css('cursor', 'move');
					} else {
						$('body').css('cursor', 'pointer');
					}
					$(this.colCopy).css({
						top: e.pageY + 10,
						left: e.pageX + 20,
						display: 'block'
					});
				}
			},
			dragEnd: function () {
				if (this.colresize) {
					var n = this.colresize.n;
					var nw = this.colresize.nw;
					$('th:visible div:eq(' + n + ')', this.hDiv).css('width', nw);
					$('tr', this.bDiv).each(
						function () {
							$('td:visible div:eq(' + n + ')', this).css('width', nw);
						}
					);
					this.hDiv.scrollLeft = this.bDiv.scrollLeft;
					$('div:eq(' + n + ')', this.cDrag).siblings().show();
					$('.dragging', this.cDrag).removeClass('dragging');
					this.rePosDrag();
					this.fixHeight();
					this.colresize = false;
				} else if (this.vresize) {
					this.vresize = false;
				} else if (this.colCopy) {
					$(this.colCopy).remove();
					if (this.dcolt != null) {
						if (this.dcoln > this.dcolt) $('th:eq(' + this.dcolt + ')', this.hDiv).before(this.dcol);
						else $('th:eq(' + this.dcolt + ')', this.hDiv).after(this.dcol);
						this.switchCol(this.dcoln, this.dcolt);
						$(this.cdropleft).remove();
						$(this.cdropright).remove();
						this.rePosDrag();
						if (p.onDragCol) {
							p.onDragCol(this.dcoln, this.dcolt);
						}
					}
					this.dcol = null;
					this.hset = null;
					this.dcoln = null;
					this.dcolt = null;
					this.colCopy = null;
					$('.thMove', this.hDiv).removeClass('thMove');
					$(this.cDrag).show();
				}
				$('body').css('cursor', 'default');
				$('body').noSelect(false);
			},
			toggleCol: function (cid, visible) {
				var ncol = $("th[axis='col" + cid + "']", this.hDiv)[0];
				var n = $('thead th', g.hDiv).index(ncol);
				var cb = $('input[value=' + cid + ']', g.nDiv)[0];
				if (visible == null) {
					visible = ncol.hidden;
				}
				if ($('input:checked', g.nDiv).length < p.minColToggle && !visible) {
					return false;
				}
				if (visible) {
					ncol.hidden = false;
					$(ncol).show();
					cb.checked = true;
				} else {
					ncol.hidden = true;
					$(ncol).hide();
					cb.checked = false;
				}
				$('tbody tr', t).each(
					function () {
						if (visible) {
							$('td:eq(' + n + ')', this).show();
						} else {
							$('td:eq(' + n + ')', this).hide();
						}
					}
				);
				this.rePosDrag();
				if (p.onToggleCol) {
					p.onToggleCol(cid, visible);
				}
				return visible;
			},
			switchCol: function (cdrag, cdrop) { //switch columns
				$('tbody tr', t).each(
					function () {
						if (cdrag > cdrop) $('td:eq(' + cdrop + ')', this).before($('td:eq(' + cdrag + ')', this));
						else $('td:eq(' + cdrop + ')', this).after($('td:eq(' + cdrag + ')', this));
					}
				);
				//switch order in nDiv
				if (cdrag > cdrop) {
					$('tr:eq(' + cdrop + ')', this.nDiv).before($('tr:eq(' + cdrag + ')', this.nDiv));
				} else {
					$('tr:eq(' + cdrop + ')', this.nDiv).after($('tr:eq(' + cdrag + ')', this.nDiv));
				}
				if ($.browser.msie && $.browser.version < 7.0) {
					$('tr:eq(' + cdrop + ') input', this.nDiv)[0].checked = true;
				}
				this.hDiv.scrollLeft = this.bDiv.scrollLeft;
			},
			scroll: function () {
				this.hDiv.scrollLeft = this.bDiv.scrollLeft;
				this.rePosDrag();
			},
			getRows: function(){
				//add by jej
				var rtnList = new Array();
				var objRows = $('.trSelected', $(t));
				if(objRows!=null){
					for(var i=0;i<objRows.length;i++){
						 var row = objRows[i];
						 var rowMap = new Object();
						 for(var j=0;j<row.cells.length;j++){
					       var cellName = p.colModel[j].name;
					       var value = row.cells[j].innerText;
					       value=value.replace(/^
+|
+$/g,""); var s = "rowMap." + cellName + '="'+ value + '"'; eval(s); } rtnList[rtnList.length] = rowMap; } } return rtnList; }, getSelectRowsToGrid: function(){ //add by jej var rtnList = new Array(); var objRows = $('.trSelected', $(t)); if(objRows!=null){ for(var i=0;i<objRows.length;i++){ var row = objRows[i]; var arr = new Array(); for(var j=0;j<row.cells.length;j++){ var value = row.cells[j].innerText; value=value.replace(/^
+|
+$/g,""); arr[j] = value; } rtnList[rtnList.length] = arr; } } return rtnList; }, strToJson:function(str){ var json = eval('(' + str + ')'); return json; }, getGridAllRows :function(){ var rtnList = new Array(); $('tbody tr',$(t)).each(function () { var arr = new Array(); for(var i=0;i<this.cells.length;i++){ var value = this.cells[i].innerText; value=value.replace(/^
+|
+$/g,""); arr[i] = value; } rtnList[rtnList.length] = arr; }) return rtnList; }, getGridAllRowsForObj :function(){ var rtnList = new Array(); $('tbody tr',$(t)).each(function () { var rowMap = new Object(); for(var i=0;i<this.cells.length;i++){ var cellName = p.colModel[i].name; var value = this.cells[i].innerText; value=value.replace(/^
+|
+$/g,""); var s = "rowMap." + cellName + '="'+ value + '"'; eval(s) } rtnList[rtnList.length] = rowMap; }) return rtnList; }, clearSelect:function(){ var objRows = $('.trSelected', $(t)); for(var i=0;i<objRows.length;i++){ $(objRows[i]).removeClass('trSelected'); } }, deleteSelectRows:function(){ var objRows = $('.trSelected', $(t)); for(var i=0;i<objRows.length;i++){ $(objRows[i]).remove(); } }, addRows:function(inrowList){ if(inrowList&&inrowList.length>0){ var rowList = this.getGridAllRows(); for(var i=0;i<inrowList.length;i++){ rowList[rowList.length] = inrowList[i]; } var str = '{"total":"1","page":"0","rows":['; for(var i=0;i<rowList.length;i++){ var rowArr = rowList[i]; var rowstr = '{"id":"'+i+'","cell":['; for(var j=0;j<rowArr.length;j++){ if(j>0){ rowstr = rowstr + ','; } rowstr = rowstr + '"' + rowArr[j] + '"'; } rowstr = rowstr + ']}'; if(i>0){ str = str + ','; } str = str + rowstr; } str = str + ']}'; var inData = this.strToJson(str); //var tbodylist = $('tbody', $(t)); //var flag = false; //if(tbodylist.length>0){ // flag = true; //} this.addData(inData,false); } }, addData: function (data,isAppend) { //parse data if (p.dataType == 'json') { data = $.extend({rows: [], page: 0, total: 0}, data); } if (p.preProcess) { data = p.preProcess(data); } $('.pReload', this.pDiv).removeClass('loading'); this.loading = false; if (!data) { $('.pPageStat', this.pDiv).html(p.errormsg); return false; } if (p.dataType == 'xml') { p.total = +$('rows total', data).text(); } else { p.total = data.total; } if (p.total == 0) { $('tr, a, td, div', t).unbind(); $(t).empty(); p.pages = 1; p.page = 1; this.buildpager(); $('.pPageStat', this.pDiv).html(p.nomsg); return false; } p.pages = Math.ceil(p.total / p.rp); if (p.dataType == 'xml') { p.page = +$('rows page', data).text(); } else { p.page = data.page; } this.buildpager(); //build new body var tbody = null; if(isAppend){ var tbodylist = $('tbody', $(t)); tbody = tbodylist[0]; }else{ tbody = document.createElement('tbody'); } if (p.dataType == 'json') { $.each(data.rows, function (i, row) { var tr = document.createElement('tr'); if (i % 2 && p.striped) { tr.className = 'erow'; } if (row.id) { tr.id = 'row' + row.id; } $('thead tr:first th', g.hDiv).each( //add cell function () { var td = document.createElement('td'); var idx = $(this).attr('axis').substr(3); td.align = this.align; // If the json elements aren't named (which is typical), use numeric order if (typeof row.cell[idx] != "undefined") { td.innerHTML = (row.cell[idx] != null) ? row.cell[idx] : '';//null-check for Opera-browser } else { td.innerHTML = row.cell[p.colModel[idx].name]; } $(td).attr('abbr', $(this).attr('abbr')); $(tr).append(td); td = null; } ); if ($('thead', this.gDiv).length < 1) {//handle if grid has no headers for (idx = 0; idx < cell.length; idx++) { var td = document.createElement('td'); // If the json elements aren't named (which is typical), use numeric order if (typeof row.cell[idx] != "undefined") { td.innerHTML = (row.cell[idx] != null) ? row.cell[idx] : '';//null-check for Opera-browser } else { td.innerHTML = row.cell[p.colModel[idx].name]; } $(tr).append(td); td = null; } } $(tbody).append(tr); tr = null; }); } else if (p.dataType == 'xml') { var i = 1; $("rows row", data).each(function () { i++; var tr = document.createElement('tr'); if (i % 2 && p.striped) { tr.className = 'erow'; } var nid = $(this).attr('id'); if (nid) { tr.id = 'row' + nid; } nid = null; var robj = this; $('thead tr:first th', g.hDiv).each(function () { var td = document.createElement('td'); var idx = $(this).attr('axis').substr(3); td.align = this.align; td.innerHTML = $("cell:eq(" + idx + ")", robj).text(); $(td).attr('abbr', $(this).attr('abbr')); $(tr).append(td); td = null; }); if ($('thead', this.gDiv).length < 1) {//handle if grid has no headers $('cell', this).each(function () { var td = document.createElement('td'); td.innerHTML = $(this).text(); $(tr).append(td); td = null; }); } $(tbody).append(tr); tr = null; robj = null; }); } $('tr', t).unbind(); if(!isAppend){ $(t).empty(); $(t).append(tbody); } this.addCellProp(); this.addRowProp(); this.rePosDrag(); tbody = null; data = null; i = null; if (p.onSuccess) { p.onSuccess(this); } if (p.hideOnSubmit) { $(g.block).remove(); } this.hDiv.scrollLeft = this.bDiv.scrollLeft; if ($.browser.opera) { $(t).css('visibility', 'visible'); } }, changeSort: function (th) { //change sortorder if (this.loading) { return true; } $(g.nDiv).hide(); $(g.nBtn).hide(); if (p.sortname == $(th).attr('abbr')) { if (p.sortorder == 'asc') { p.sortorder = 'desc'; } else { p.sortorder = 'asc'; } } $(th).addClass('sorted').siblings().removeClass('sorted'); $('.sdesc', this.hDiv).removeClass('sdesc'); $('.sasc', this.hDiv).removeClass('sasc'); $('div', th).addClass('s' + p.sortorder); p.sortname = $(th).attr('abbr'); if (p.onChangeSort) { p.onChangeSort(p.sortname, p.sortorder); } else { this.populate(); } }, buildpager: function () { //rebuild pager based on new properties $('.pcontrol input', this.pDiv).val(p.page); $('.pcontrol span', this.pDiv).html(p.pages); var r1 = (p.page - 1) * p.rp + 1; var r2 = r1 + p.rp - 1; if (p.total < r2) { r2 = p.total; } var stat = p.pagestat; stat = stat.replace(/{from}/, r1); stat = stat.replace(/{to}/, r2); stat = stat.replace(/{total}/, p.total); $('.pPageStat', this.pDiv).html(stat); }, queryData:function(params){ this.populate(params); }, populate: function (queryCond) { //get latest data if (this.loading) { return true; } if (p.onSubmit) { var gh = p.onSubmit(); if (!gh) { return false; } } this.loading = true; if (!p.url) { return false; } $('.pPageStat', this.pDiv).html(p.procmsg); $('.pReload', this.pDiv).addClass('loading'); $(g.block).css({ top: g.bDiv.offsetTop }); if (p.hideOnSubmit) { $(this.gDiv).prepend(g.block); } if ($.browser.opera) { $(t).css('visibility', 'hidden'); } if (!p.newp) { p.newp = 1; } if (p.page > p.pages) { p.page = p.pages; } var param = [{ name: 'page', value: p.newp }, { name: 'rp', value: p.rp }, { name: 'sortname', value: p.sortname }, { name: 'sortorder', value: p.sortorder }, { name: 'query', value: p.query }, { name: 'qtype', value: p.qtype }]; if(queryCond!=null){ param[param.length]={name:"queryCond",value:queryCond}; }; if (p.params) { for (var pi = 0; pi < p.params.length; pi++) { param[param.length] = p.params[pi]; } } if(p.method=='dwr'){ if(typeof p.dwrAction =="function"){ p.dwrAction(param); } }else{ $.ajax({ type: p.method, url: p.url, data: param, dataType: p.dataType, success: function (data) { g.addData(data); }, error: function (XMLHttpRequest, textStatus, errorThrown) { try { if (p.onError) p.onError(XMLHttpRequest, textStatus, errorThrown); } catch (e) {} } }); } }, doSearch: function () { p.query = $('input[name=q]', g.sDiv).val(); p.qtype = $('select[name=qtype]', g.sDiv).val(); p.newp = 1; this.populate(); }, changePage: function (ctype) { //change page if (this.loading) { return true; } switch (ctype) { case 'first': p.newp = 1; break; case 'prev': if (p.page > 1) { p.newp = parseInt(p.page) - 1; } break; case 'next': if (p.page < p.pages) { p.newp = parseInt(p.page) + 1; } break; case 'last': p.newp = p.pages; break; case 'input': var nv = parseInt($('.pcontrol input', this.pDiv).val()); if (isNaN(nv)) { nv = 1; } if (nv < 1) { nv = 1; } else if (nv > p.pages) { nv = p.pages; } $('.pcontrol input', this.pDiv).val(nv); p.newp = nv; break; } if (p.newp == p.page) { return false; } if (p.onChangePage) { p.onChangePage(p.newp); } else { this.populate(); } }, addCellProp: function () { $('tbody tr td', g.bDiv).each(function () { var tdDiv = document.createElement('div'); var n = $('td', $(this).parent()).index(this); var pth = $('th:eq(' + n + ')', g.hDiv).get(0); if (pth != null) { if (p.sortname == $(pth).attr('abbr') && p.sortname) { this.className = 'sorted'; } $(tdDiv).css({ textAlign: pth.align, width: $('div:first', pth)[0].style.width }); if (pth.hidden) { $(this).css('display', 'none'); } } if (p.nowrap == false) { $(tdDiv).css('white-space', 'normal'); } if (this.innerHTML == '') { this.innerHTML = ' '; } tdDiv.innerHTML = this.innerHTML; var prnt = $(this).parent()[0]; var pid = false; if (prnt.id) { pid = prnt.id.substr(3); } if (pth != null) { if (pth.process) pth.process(tdDiv, pid); } $(this).empty().append(tdDiv).removeAttr('width'); //wrap content }); }, getCellDim: function (obj) {// get cell prop for editable event var ht = parseInt($(obj).height()); var pht = parseInt($(obj).parent().height()); var wt = parseInt(obj.style.width); var pwt = parseInt($(obj).parent().width()); var top = obj.offsetParent.offsetTop; var left = obj.offsetParent.offsetLeft; var pdl = parseInt($(obj).css('paddingLeft')); var pdt = parseInt($(obj).css('paddingTop')); return { ht: ht, wt: wt, top: top, left: left, pdl: pdl, pdt: pdt, pht: pht, pwt: pwt }; }, addRowProp: function () { $('tbody tr', g.bDiv).each(function () { $(this).click(function (e) { var obj = (e.target || e.srcElement); if (obj.href || obj.type) return true; $(this).toggleClass('trSelected'); if (p.singleSelect) $(this).siblings().removeClass('trSelected'); if(p.onRowClick && typeof(p.onRowClick)=='function'){ p.onRowClick(e); } }).mousedown(function (e) { if (e.shiftKey) { $(this).toggleClass('trSelected'); g.multisel = true; this.focus(); $(g.gDiv).noSelect(); } }).mouseup(function () { if (g.multisel) { g.multisel = false; $(g.gDiv).noSelect(false); } }).hover(function (e) { if (g.multisel) { $(this).toggleClass('trSelected'); } }, function () {}); if ($.browser.msie && $.browser.version < 7.0) { $(this).hover(function () { $(this).addClass('trOver'); }, function () { $(this).removeClass('trOver'); }); } }); }, pager: 0 }; if (p.colModel) { //create model if any thead = document.createElement('thead'); var tr = document.createElement('tr'); for (var i = 0; i < p.colModel.length; i++) { var cm = p.colModel[i]; var th = document.createElement('th'); th.innerHTML = cm.display; if (cm.name && cm.sortable) { $(th).attr('abbr', cm.name); } $(th).attr('axis', 'col' + i); if (cm.align) { th.align = cm.align; } if (cm.width) { $(th).attr('width', cm.width); } if ($(cm).attr('hide')) { th.hidden = true; } if (cm.process) { th.process = cm.process; } $(tr).append(th); } $(thead).append(tr); $(t).prepend(thead); } // end if p.colmodel //init divs g.gDiv = document.createElement('div'); //create global container g.mDiv = document.createElement('div'); //create title container g.hDiv = document.createElement('div'); //create header container g.bDiv = document.createElement('div'); //create body container g.vDiv = document.createElement('div'); //create grip g.rDiv = document.createElement('div'); //create horizontal resizer g.cDrag = document.createElement('div'); //create column drag g.block = document.createElement('div'); //creat blocker g.nDiv = document.createElement('div'); //create column show/hide popup g.nBtn = document.createElement('div'); //create column show/hide button g.iDiv = document.createElement('div'); //create editable layer g.tDiv = document.createElement('div'); //create toolbar g.sDiv = document.createElement('div'); g.pDiv = document.createElement('div'); //create pager container if (!p.usepager) { g.pDiv.style.display = 'none'; } g.hTable = document.createElement('table'); g.gDiv.className = 'flexigrid'; if (p.width != 'auto') { g.gDiv.style.width = p.width + 'px'; } //add conditional classes if ($.browser.msie) { $(g.gDiv).addClass('ie'); } if (p.novstripe) { $(g.gDiv).addClass('novstripe'); } $(t).before(g.gDiv); $(g.gDiv).append(t); //set toolbar if (p.buttons) { g.tDiv.className = 'tDiv'; var tDiv2 = document.createElement('div'); tDiv2.className = 'tDiv2'; for (var i = 0; i < p.buttons.length; i++) { var btn = p.buttons[i]; if (!btn.separator) { var btnDiv = document.createElement('div'); btnDiv.className = 'fbutton'; btnDiv.innerHTML = "<div><span>" + btn.name + "</span></div>"; if (btn.bclass) $('span', btnDiv).addClass(btn.bclass).css({ paddingLeft: 20 }); btnDiv.onpress = btn.onpress; btnDiv.name = btn.name; if (btn.onpress) { $(btnDiv).click(function () { this.onpress(this.name, g.gDiv); }); } $(tDiv2).append(btnDiv); if ($.browser.msie && $.browser.version < 7.0) { $(btnDiv).hover(function () { $(this).addClass('fbOver'); }, function () { $(this).removeClass('fbOver'); }); } } else { $(tDiv2).append("<div class='btnseparator'></div>"); } } $(g.tDiv).append(tDiv2); $(g.tDiv).append("<div style='clear:both'></div>"); $(g.gDiv).prepend(g.tDiv); } g.hDiv.className = 'hDiv'; $(t).before(g.hDiv); g.hTable.cellPadding = 0; g.hTable.cellSpacing = 0; $(g.hDiv).append('<div class="hDivBox"></div>'); $('div', g.hDiv).append(g.hTable); var thead = $("thead:first", t).get(0); if (thead) $(g.hTable).append(thead); thead = null; if (!p.colmodel) var ci = 0; $('thead tr:first th', g.hDiv).each(function () { var thdiv = document.createElement('div'); if ($(this).attr('abbr')) { $(this).click(function (e) { if (!$(this).hasClass('thOver')) return false; var obj = (e.target || e.srcElement); if (obj.href || obj.type) return true; g.changeSort(this); }); if ($(this).attr('abbr') == p.sortname) { this.className = 'sorted'; thdiv.className = 's' + p.sortorder; } } if (this.hidden) { $(this).hide(); } if (!p.colmodel) { $(this).attr('axis', 'col' + ci++); } $(thdiv).css({ textAlign: this.align, width: this.width + 'px' }); thdiv.innerHTML = this.innerHTML; $(this).empty().append(thdiv).removeAttr('width').mousedown(function (e) { g.dragStart('colMove', e, this); }).hover(function () { if (!g.colresize && !$(this).hasClass('thMove') && !g.colCopy) { $(this).addClass('thOver'); } if ($(this).attr('abbr') != p.sortname && !g.colCopy && !g.colresize && $(this).attr('abbr')) { $('div', this).addClass('s' + p.sortorder); } else if ($(this).attr('abbr') == p.sortname && !g.colCopy && !g.colresize && $(this).attr('abbr')) { var no = (p.sortorder == 'asc') ? 'desc' : 'asc'; $('div', this).removeClass('s' + p.sortorder).addClass('s' + no); } if (g.colCopy) { var n = $('th', g.hDiv).index(this); if (n == g.dcoln) { return false; } if (n < g.dcoln) { $(this).append(g.cdropleft); } else { $(this).append(g.cdropright); } g.dcolt = n; } else if (!g.colresize) { var nv = $('th:visible', g.hDiv).index(this); var onl = parseInt($('div:eq(' + nv + ')', g.cDrag).css('left')); var nw = jQuery(g.nBtn).outerWidth(); var nl = onl - nw + Math.floor(p.cgwidth / 2); $(g.nDiv).hide(); $(g.nBtn).hide(); $(g.nBtn).css({ 'left': nl, top: g.hDiv.offsetTop }).show(); var ndw = parseInt($(g.nDiv).width()); $(g.nDiv).css({ top: g.bDiv.offsetTop }); if ((nl + ndw) > $(g.gDiv).width()) { $(g.nDiv).css('left', onl - ndw + 1); } else { $(g.nDiv).css('left', nl); } if ($(this).hasClass('sorted')) { $(g.nBtn).addClass('srtd'); } else { $(g.nBtn).removeClass('srtd'); } } }, function () { $(this).removeClass('thOver'); if ($(this).attr('abbr') != p.sortname) { $('div', this).removeClass('s' + p.sortorder); } else if ($(this).attr('abbr') == p.sortname) { var no = (p.sortorder == 'asc') ? 'desc' : 'asc'; $('div', this).addClass('s' + p.sortorder).removeClass('s' + no); } if (g.colCopy) { $(g.cdropleft).remove(); $(g.cdropright).remove(); g.dcolt = null; } }); //wrap content }); //set bDiv g.bDiv.className = 'bDiv'; $(t).before(g.bDiv); $(g.bDiv).css({ height: (p.height == 'auto') ? 'auto' : p.height + "px" }).scroll(function (e) { g.scroll() }).append(t); if (p.height == 'auto') { $('table', g.bDiv).addClass('autoht'); } //add td & row properties g.addCellProp(); g.addRowProp(); //set cDrag var cdcol = $('thead tr:first th:first', g.hDiv).get(0); if (cdcol != null) { g.cDrag.className = 'cDrag'; g.cdpad = 0; g.cdpad += (isNaN(parseInt($('div', cdcol).css('borderLeftWidth'))) ? 0 : parseInt($('div', cdcol).css('borderLeftWidth'))); g.cdpad += (isNaN(parseInt($('div', cdcol).css('borderRightWidth'))) ? 0 : parseInt($('div', cdcol).css('borderRightWidth'))); g.cdpad += (isNaN(parseInt($('div', cdcol).css('paddingLeft'))) ? 0 : parseInt($('div', cdcol).css('paddingLeft'))); g.cdpad += (isNaN(parseInt($('div', cdcol).css('paddingRight'))) ? 0 : parseInt($('div', cdcol).css('paddingRight'))); g.cdpad += (isNaN(parseInt($(cdcol).css('borderLeftWidth'))) ? 0 : parseInt($(cdcol).css('borderLeftWidth'))); g.cdpad += (isNaN(parseInt($(cdcol).css('borderRightWidth'))) ? 0 : parseInt($(cdcol).css('borderRightWidth'))); g.cdpad += (isNaN(parseInt($(cdcol).css('paddingLeft'))) ? 0 : parseInt($(cdcol).css('paddingLeft'))); g.cdpad += (isNaN(parseInt($(cdcol).css('paddingRight'))) ? 0 : parseInt($(cdcol).css('paddingRight'))); $(g.bDiv).before(g.cDrag); var cdheight = $(g.bDiv).height(); var hdheight = $(g.hDiv).height(); $(g.cDrag).css({ top: -hdheight + 'px' }); $('thead tr:first th', g.hDiv).each(function () { var cgDiv = document.createElement('div'); $(g.cDrag).append(cgDiv); if (!p.cgwidth) { p.cgwidth = $(cgDiv).width(); } $(cgDiv).css({ height: cdheight + hdheight }).mousedown(function (e) { g.dragStart('colresize', e, this); }); if ($.browser.msie && $.browser.version < 7.0) { g.fixHeight($(g.gDiv).height()); $(cgDiv).hover(function () { g.fixHeight(); $(this).addClass('dragging') }, function () { if (!g.colresize) $(this).removeClass('dragging') }); } }); } //add strip if (p.striped) { $('tbody tr:odd', g.bDiv).addClass('erow'); } if (p.resizable && p.height != 'auto') { g.vDiv.className = 'vGrip'; $(g.vDiv).mousedown(function (e) { g.dragStart('vresize', e) }).html('<span></span>'); $(g.bDiv).after(g.vDiv); } if (p.resizable && p.width != 'auto' && !p.nohresize) { g.rDiv.className = 'hGrip'; $(g.rDiv).mousedown(function (e) { g.dragStart('vresize', e, true); }).html('<span></span>').css('height', $(g.gDiv).height()); if ($.browser.msie && $.browser.version < 7.0) { $(g.rDiv).hover(function () { $(this).addClass('hgOver'); }, function () { $(this).removeClass('hgOver'); }); } $(g.gDiv).append(g.rDiv); } // add pager if (p.usepager) { g.pDiv.className = 'pDiv'; g.pDiv.innerHTML = '<div class="pDiv2"></div>'; $(g.bDiv).after(g.pDiv); var html = ' <div class="pGroup"> <div class="pFirst pButton"><span></span></div><div class="pPrev pButton"><span></span></div> </div> <div class="btnseparator"></div> <div class="pGroup"><span class="pcontrol">' + p.pagetext + ' <input type="text" size="4" value="1" /> ' + p.outof + ' <span> 1 </span></span></div> <div class="btnseparator"></div> <div class="pGroup"> <div class="pNext pButton"><span></span></div><div class="pLast pButton"><span></span></div> </div> <div class="btnseparator"></div> <div class="pGroup"> <div class="pReload pButton"><span></span></div> </div> <div class="btnseparator"></div> <div class="pGroup"><span class="pPageStat"></span></div>'; $('div', g.pDiv).html(html); $('.pReload', g.pDiv).click(function () { g.populate() }); $('.pFirst', g.pDiv).click(function () { g.changePage('first') }); $('.pPrev', g.pDiv).click(function () { g.changePage('prev') }); $('.pNext', g.pDiv).click(function () { g.changePage('next') }); $('.pLast', g.pDiv).click(function () { g.changePage('last') }); $('.pcontrol input', g.pDiv).keydown(function (e) { if (e.keyCode == 13) g.changePage('input') }); if ($.browser.msie && $.browser.version < 7) $('.pButton', g.pDiv).hover(function () { $(this).addClass('pBtnOver'); }, function () { $(this).removeClass('pBtnOver'); }); if (p.useRp) { var opt = '', sel = ''; for (var nx = 0; nx < p.rpOptions.length; nx++) { if (p.rp == p.rpOptions[nx]) sel = 'selected="selected"'; else sel = ''; opt += "<option value='" + p.rpOptions[nx] + "' " + sel + " >" + p.rpOptions[nx] + "  </option>"; } $('.pDiv2', g.pDiv).prepend("<div class='pGroup'><select name='rp'>" + opt + "</select></div> <div class='btnseparator'></div>"); $('select', g.pDiv).change(function () { if (p.onRpChange) { p.onRpChange(+this.value); } else { p.newp = 1; p.rp = +this.value; g.populate(); } }); } //add search button if (p.searchitems) { $('.pDiv2', g.pDiv).prepend("<div class='pGroup'> <div class='pSearch pButton'><span></span></div> </div> <div class='btnseparator'></div>"); $('.pSearch', g.pDiv).click(function () { $(g.sDiv).slideToggle('fast', function () { $('.sDiv:visible input:first', g.gDiv).trigger('focus'); }); }); //add search box g.sDiv.className = 'sDiv'; var sitems = p.searchitems; var sopt = '', sel = ''; for (var s = 0; s < sitems.length; s++) { if (p.qtype == '' && sitems[s].isdefault == true) { p.qtype = sitems[s].name; sel = 'selected="selected"'; } else { sel = ''; } sopt += "<option value='" + sitems[s].name + "' " + sel + " >" + sitems[s].display + "  </option>"; } if (p.qtype == '') { p.qtype = sitems[0].name; } $(g.sDiv).append("<div class='sDiv2'>" + p.findtext + " <input type='text' value='" + p.query +"' size='30' name='q' class='qsbox' /> "+ " <select name='qtype'>" + sopt + "</select></div>"); //Split into separate selectors because of bug in jQuery 1.3.2 $('input[name=q]', g.sDiv).keydown(function (e) { if (e.keyCode == 13) { g.doSearch(); } }); $('select[name=qtype]', g.sDiv).keydown(function (e) { if (e.keyCode == 13) { g.doSearch(); } }); $('input[value=Clear]', g.sDiv).click(function () { $('input[name=q]', g.sDiv).val(''); p.query = ''; g.doSearch(); }); $(g.bDiv).after(g.sDiv); } } $(g.pDiv, g.sDiv).append("<div style='clear:both'></div>"); // add title if (p.title) { g.mDiv.className = 'mDiv'; g.mDiv.innerHTML = '<div class="ftitle">' + p.title + '</div>'; $(g.gDiv).prepend(g.mDiv); if (p.showTableToggleBtn) { $(g.mDiv).append('<div class="ptogtitle" title="Minimize/Maximize Table"><span></span></div>'); $('div.ptogtitle', g.mDiv).click(function () { $(g.gDiv).toggleClass('hideBody'); $(this).toggleClass('vsble'); }); } } //setup cdrops g.cdropleft = document.createElement('span'); g.cdropleft.className = 'cdropleft'; g.cdropright = document.createElement('span'); g.cdropright.className = 'cdropright'; //add block g.block.className = 'gBlock'; var gh = $(g.bDiv).height(); var gtop = g.bDiv.offsetTop; $(g.block).css({ width: g.bDiv.style.width, height: gh, background: 'white', position: 'relative', marginBottom: (gh * -1), zIndex: 1, top: gtop, left: '0px' }); $(g.block).fadeTo(0, p.blockOpacity); // add column control if ($('th', g.hDiv).length) { g.nDiv.className = 'nDiv'; g.nDiv.innerHTML = "<table cellpadding='0' cellspacing='0'><tbody></tbody></table>"; $(g.nDiv).css({ marginBottom: (gh * -1), display: 'none', top: gtop }).noSelect(); var cn = 0; $('th div', g.hDiv).each(function () { var kcol = $("th[axis='col" + cn + "']", g.hDiv)[0]; var chk = 'checked="checked"'; if (kcol.style.display == 'none') { chk = ''; } $('tbody', g.nDiv).append('<tr><td class="ndcol1"><input type="checkbox" ' + chk + ' class="togCol" value="' + cn + '" /></td><td class="ndcol2">' + this.innerHTML + '</td></tr>'); cn++; }); if ($.browser.msie && $.browser.version < 7.0) $('tr', g.nDiv).hover(function () { $(this).addClass('ndcolover'); }, function () { $(this).removeClass('ndcolover'); }); $('td.ndcol2', g.nDiv).click(function () { if ($('input:checked', g.nDiv).length <= p.minColToggle && $(this).prev().find('input')[0].checked) return false; return g.toggleCol($(this).prev().find('input').val()); }); $('input.togCol', g.nDiv).click(function () { if ($('input:checked', g.nDiv).length < p.minColToggle && this.checked == false) return false; $(this).parent().next().trigger('click'); }); $(g.gDiv).prepend(g.nDiv); $(g.nBtn).addClass('nBtn') .html('<div></div>') .attr('title', 'Hide/Show Columns') .click(function () { $(g.nDiv).toggle(); return true; } ); if (p.showToggleBtn) { $(g.gDiv).prepend(g.nBtn); } } // add date edit layer $(g.iDiv).addClass('iDiv').css({ display: 'none' }); $(g.bDiv).append(g.iDiv); // add flexigrid events $(g.bDiv).hover(function () { $(g.nDiv).hide(); $(g.nBtn).hide(); }, function () { if (g.multisel) { g.multisel = false; } }); $(g.gDiv).hover(function () {}, function () { $(g.nDiv).hide(); $(g.nBtn).hide(); }); //add document events $(document).mousemove(function (e) { g.dragMove(e) }).mouseup(function (e) { g.dragEnd() }).hover(function () {}, function () { g.dragEnd() }); //browser adjustments if ($.browser.msie && $.browser.version < 7.0) { $('.hDiv,.bDiv,.mDiv,.pDiv,.vGrip,.tDiv, .sDiv', g.gDiv).css({ width: '100%' }); $(g.gDiv).addClass('ie6'); if (p.width != 'auto') { $(g.gDiv).addClass('ie6fullwidthbug'); } } g.rePosDrag(); g.fixHeight(); //make grid functions accessible t.p = p; t.grid = g; // load data if (p.url && p.autoload) { g.populate(); } return t; }; var docloaded = false; $(document).ready(function () { docloaded = true }); $.fn.flexigrid = function (p) { return this.each(function () { if (!docloaded) { $(this).hide(); var t = this; $(document).ready(function () { $.addFlex(t, p); }); } else { $.addFlex(this, p); } }); }; //end flexigrid $.fn.flexReload = function (p) { // function to reload grid return this.each(function () { if (this.grid && this.p.url) this.grid.populate(); }); }; //end flexReload $.fn.flexOptions = function (p) { //function to update general options return this.each(function () { if (this.grid) $.extend(this.p, p); }); }; //end flexOptions $.fn.flexToggleCol = function (cid, visible) { // function to reload grid return this.each(function () { if (this.grid) this.grid.toggleCol(cid, visible); }); }; //end flexToggleCol $.fn.flexAddData = function (data) { // function to add data to grid return this.each(function () { if (this.grid) this.grid.addData(data); }); }; $.fn.flexGetRows = function () { // function to add data to grid jej return this[0].grid.getRows(); }; $.fn.addRows = function (rowList) { // function to add data to grid jej return this[0].grid.addRows(rowList); }; $.fn.getSelectRowsToGrid = function () { // function to add data to grid jej return this[0].grid.getSelectRowsToGrid(); }; $.fn.getGridAllRows = function () { // function to add data to grid jej return this[0].grid.getGridAllRows(); }; $.fn.getGridAllRowsForObj = function () { // function to add data to grid jej return this[0].grid.getGridAllRowsForObj(); }; $.fn.clearSelect = function () { // function to add data to grid jej return this[0].grid.clearSelect(); }; $.fn.deleteSelectRows = function () { // function to add data to grid jej return this[0].grid.deleteSelectRows(); }; $.fn.queryData = function (params) { // function to add data to grid jej return this[0].grid.queryData(params); }; $.fn.noSelect = function (p) { //no select plugin by me :-) var prevent = (p == null) ? true : p; if (prevent) { return this.each(function () { if ($.browser.msie || $.browser.safari) $(this).bind('selectstart', function () { return false; }); else if ($.browser.mozilla) { $(this).css('MozUserSelect', 'none'); $('body').trigger('focus'); } else if ($.browser.opera) $(this).bind('mousedown', function () { return false; }); else $(this).attr('unselectable', 'on'); }); } else { return this.each(function () { if ($.browser.msie || $.browser.safari) $(this).unbind('selectstart'); else if ($.browser.mozilla) $(this).css('MozUserSelect', 'inherit'); else if ($.browser.opera) $(this).unbind('mousedown'); else $(this).removeAttr('unselectable', 'on'); }); } }; //end noSelect })(jQuery);

呼び出しの主な例は,ページ内のcssなどを無視し,主にどのように使用すればよいかを参照すればよい.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="zh-cn" lang="zh-cn" xmlns:v="urn:schemas-microsoft-com:vml">
<head>
<link rel="stylesheet" type="text/css" href="js/widget/flexigrid-1.1/css/flexigrid.css" />
<link rel="stylesheet" type="text/css" href="css/zsclssel.css" />
<script src="js/jquery/jquery-1.8.3.js" type="text/javascript"></script>
<script type="text/javascript" src="<%=config.getServletContext().getContextPath()%>/dwr/engine.js"></script> 
<script type="text/javascript" src="<%=config.getServletContext().getContextPath()%>/dwr/util.js"></script>
<script type="text/javascript" src="<%=config.getServletContext().getContextPath()%>/dwr/interface/ZhfxGridAction.js"></script>
<script type="text/javascript" src="js/widget/flexigrid-1.1/js/flexigrid.js"></script>
<link rel="stylesheet" type="text/css" href="js/widget/idealforms/jquery.idealforms.min.css"/>
<script type="text/javascript" src="js/widget/idealforms/jquery.idealforms.js"></script>
<script type="text/javascript">
    window.returnValue = null;
    var $jq = jQuery.noConflict();
    var selforcls = 'total';
    var fretype = 1;
	$jq(document).ready(function(){
	    var options = {
	    	onFail: function() {
	    	},
	    	onSuccess: function(e) { }
	    }
	    var $myform = $jq('#my-form').idealforms(options);
	    $forminputs = $myform.data('idealforms');
	    
	    $jq("#datagriddivview").flexigrid({
	    	colModel : [
	    		{display: '    ', name : 'zbName', width : 280, sortable : false, align: 'center'},
	    		{display: '    ', name : 'preType', width : 80, sortable : false, align: 'left'}
	    	],
	    	usepager: true,
	    	title: '     ',
	    	useRp: true,
	    	height:450,
	    	rp: 20,
	    	rpOptions: [20,50,100],
	    	dwrAction:getData, //js  ,    dwr,      flexigrid ,     ,       
	    	method:'dwr', //       dwr   add by danielinbiti
	    	url:true,
	    	resizable:false,
	    	pagestat: '',
			pagetext: 'Page',
			outof: 'of',
			procmsg: '       ...',
			nomsg: '    ',
	    	dataType:'json'
	    });   
	    function strToJson(str){ 
	    	var json = eval('(' + str + ')'); 
	    	return json; 
    	}
	    function getData(param){
	    	var pageNum = 0;
	    	var perPageNum = 0;
	    	var queryMap = null;
	    	for(var i=0;i<param.length;i++){
	    		if(param[i].name=='page'){
	    			pageNum = param[i].value;
	    		}else if(param[i].name=='rp'){
	    			perPageNum = param[i].value;
	    		}else if(param[i].name=='queryCond'){
	    		   if(param[i].value instanceof Object){
	    		      queryMap = param[i].value;
	    		   }
	    		}
	    	}
	    	ZhfxGridAction.getSubClassInfo(selforcls,fretype,queryMap,perPageNum,pageNum,2,function(data){
	    		var jsondata = strToJson(data);
		    	$jq("#datagriddivview").flexAddData(jsondata);
	    	});
	    }
	    $jq("#datagriddivresult").flexigrid({
	    	colModel : [
	    		{display: '    ', name : 'zbName', width : 280, sortable : false, align: 'center'},
	    		{display: '    ', name : 'preType', width : 80, sortable : false, align: 'left'}
	    	],
	    	usepager: false,
	    	title: '      ',
	    	useRp: true,
	    	rp: 20,
	    	height:450,
	    	rpOptions: [20,50,100],
	    	url:true,
	    	resizable:false,
	    	pagestat: '',
			pagetext: 'Page',
			outof: 'of',
			procmsg: '       ...',
			nomsg: '    ',
	    	dataType:'json'
	    }); 
	    $jq("#datagriddivresult").flexAddData({});
	});
	function moveRightRow(){
	   var rowList = $jq("#datagriddivview").getSelectRowsToGrid();
	   var selList = $jq("#datagriddivresult").getGridAllRows();
	   var flag = true;
	   var resultRows = new Array();
	   
	   for(var i=0;i<rowList.length;i++){
	      var row = rowList[i];
	      flag = true;
	      for(var j=0;j<selList.length;j++){
	         var selRow = selList[j];
	         if(selRow[0]==row[0]){
	            flag = false;
	            break;
	         }
	      }
	      if(flag){
	         resultRows[resultRows.length] = row;
	      }
	   }
	   $jq("#datagriddivresult").addRows(resultRows);
	   $jq("#datagriddivview").clearSelect();
	}
	function delRows(){
	    $jq("#datagriddivresult").deleteSelectRows();
	}
	function saveData(){
	    var selList = $jq("#datagriddivresult").getGridAllRows();
	    var rtnArr = new Array();
	    if(selList!=null){
	      for(var i=0;i<selList.length;i++){
	         rtnArr[rtnArr.length] = selList[i][0];
	      }
	    }
	    window.returnValue = rtnArr;
	    window.close();
	}
	function queryData(){
	    var name = $jq("#zsname").val();
	    var isLink = $jq("#zslinkstatusselect").val();
	    var params={
	         zbName:name,
	         isLink:isLink
	    };
	    $jq("#datagriddivview").queryData(params);
	}
</script>
</head>
<body>
  <div id="div_head"></div>
  <div id="div_body">
     <div>
        <form id="my-form">
            <div>
               <div class="onrowcss">
	       	     <div><label>
	       	               :</label><input id="zsname" name="zsname" type="text"/></div>
	       	   </div>
	       	   <div class="onrowcss">
	       	     <div>
			  	     <label>         :</label>
			  	     <select id="zslinkstatusselect" name="zslinkstatusselect">
			              <option value="0,1">  </option>
			              <option value="0">   </option>
			              <option value="1">   </option>
			         </select>
		         </div>
	           </div>
	           <div class="divbtncss onrowcss">
	             <div>
	                <button id="btnquery" class="divquerycss" type="button" onclick="queryData()">  </button>
	             </div>
	           </div>
	       	</div>
	    </form>
     </div>
     <div>
         <div class="divgridclass onrowcss">
	       <div id="datagriddivview"></div>
	     </div>
	     <div id="divselbutton" class="divselbuttoncss onrowcss" align="center">
	        <input type="button" id="btnSelDown" class="btnclass divseldown" value="" onclick="moveRightRow()"/>
         </div>
	     <div class="onrowcss">
		     <div class="divgridclass gridwidth">
		     	<div id="datagriddivresult"></div>
		     </div>
		     <div id="divresultbuttons" class="divresultbuttonscss" align="center">
		        <input type="button" id="btnDel" class="btnclass" value="  " onclick="delRows()"/>
		        <input type="button" id="btnDel" class="btnclass" value="  " onclick="saveData()"/>
		     </div>
	     </div>
     </div>
  </div>
  <div id="div_foot">
  </div>
</body>
</html>

jsページダウンロードリンクhttp://download.csdn.net/detail/danielinbiti/5573615