- 浏览: 10512 次
- 性别:
- 来自: 珠海
最新评论
-
qinzhenzhou:
onload, onerror 是<script> ...
javascript控件开发之动态加载(1) -
nangonglingxue:
这个onload事件跟onerror事件在什么时候用的??
javascript控件开发之动态加载(1) -
nangonglingxue:
楼主, importObj.onload = importOb ...
javascript控件开发之动态加载(1) -
网易YY:
支持楼主,想跟楼主学习
javascript控件开发之动态加载(1) -
rex0654335:
好牛B 的样子
javascript控件开发之动态加载(2)
在网页中,<DIV>本身就有滚动条,在显示文本内容的时候,原始的滚动条已够用,一般如果我们想实现一个类似列表的控件时,也可以把所有的列表数据输出到一个完整的<table>标签,再嵌入到一个DIV中即可,然而如果数据量达到几千行时,完全生成<table>的话,将会非常的占用内存,因此较好的办法是用虚拟展示的方式,
所谓虚拟展示就是把数据用一个数组存储, 然后只生成可见部分的DOM元素,比如可见行是10行,那就创建10个<tr>,通过刷新的方式,在这10行中,滚动显示所有的数据,这样,滚动条就是主要的一环节,
以上的说明等到我们做后面的列表展示控件时,大家就会明白,在此就不再详细说明,接下来我们进入主题,开发我们的滚动条控件。
本次我们做的滚动特性有,上、下两个按钮和拖动的按钮,其余特性遵照平时系统滚动条的规则来开发,其中滚动区域是通过设置明细数量来设置滚动数量,比如,总共有1000条数据,然后界面能显示50条,那滚动数量则是1000-50条,通过这个数据来绘制滚动条的滚动数量,这种方式实现滚动条是为后续虚拟滚动做准备
首先,基于行前几篇开发的的框架,我们在目录 component\ui\下添加文件 com.ui.scrollBar.js, 在文件中定义com.ui.scrollBar类,继承com.ui.window类,如下
在滚动条的创建函数中定义一些基本属性,如滚动条类型、滚动总数量、显示数量、滚动位置、滚动一条的步长及拖动按钮最短长度等,如下
定义好基本的属性后,开始绘制滚动条的框架, 这里我们采用<TABLE>来实现, 比如纵向滚动条,则生成一个三行一列的<TABLE>,第一行与第三行用作上下按钮,中间用作滚动区域,(横向的同理),
然后在滚动区域(上边<table>的第二行)中又加入一个两行一列的<table>,用作中间拖动按钮,第一行,绘制边线与背景相同,第二行绘制成按钮,通过调整第一行的行高来设定按钮的位置,
绘制完成后,添加按钮的事件,及拖动事件, 如下:
上边我们只是绘制出滚动条的结构,需要进行样式控制,下边refreshBox函数就是用于控制滚动条的样式及位置的,
这上边用到几个样式,在com.comStyle.css文件中定义如下:
完成以上结构后,只是完成了显示的效果,因为我们这个滚动条是通过设置数据明细数量来设定滚动的,因此需要与象素进行转换计算,以设置拖动按钮的位置,下面我们添加一个刷新函数,用于刷新滚动条的长度、拖动按钮的长度及位置,添加refresh函数,如下:
下面我们实现 拖动的事件,首先要先在鼠标按钮的时候初始化一些属性,再在鼠标弹起的时候,还原一些属性,这里我能通过重写doMouseDown,doMouseUp事件来实现,如下:
下面为鼠标移动事件,当拖动状态dragState等于true时,跟据鼠标的起始位置及当前位置计算滚动按钮的移动距离,并计算相应的滚动明细位置scrollIndex,并且执行滚动事件onScroll绑定的事件,由于滚动事件属于外部事件,这里作异常捕获处理。
下面我们再定义上边用到的上、下明细函数,及上、下翻页函数,如下:
接着,再定义几个属性的设置函数,如下:
最后设置高度,宽度的函数,
到此我们的全部控件编写完成,从上边来看,有点长,但是这点长绝对值得,因为后续控件,将会大大降低实现难度,这里有个缺点,就是没有给向上、下按钮添加图片,不过,如果需要只需要修改样式文件,把图片加上即可,
当然,我们写了控制,那么就要测试一下,下面我们写几行代码,用来测试控件的使用,
首先在test.html文件中添加两个滚动条控件的标签,如下id=test12/13的两个控件:
然后我们在页面控制器中添加一些代码,
如此就可以打开test.html页面查看效果,如图
写到此又靠一段落了,因为前期比较忙,更新的时间长了些,这一编有点长但是思路比较简单,实现难度也不算大,希望大家能看懂,
如果想看效果,可以下载源码包查看
请关注我的下一编,javascript控件开发之列表控件(1)
所谓虚拟展示就是把数据用一个数组存储, 然后只生成可见部分的DOM元素,比如可见行是10行,那就创建10个<tr>,通过刷新的方式,在这10行中,滚动显示所有的数据,这样,滚动条就是主要的一环节,
以上的说明等到我们做后面的列表展示控件时,大家就会明白,在此就不再详细说明,接下来我们进入主题,开发我们的滚动条控件。
本次我们做的滚动特性有,上、下两个按钮和拖动的按钮,其余特性遵照平时系统滚动条的规则来开发,其中滚动区域是通过设置明细数量来设置滚动数量,比如,总共有1000条数据,然后界面能显示50条,那滚动数量则是1000-50条,通过这个数据来绘制滚动条的滚动数量,这种方式实现滚动条是为后续虚拟滚动做准备
首先,基于行前几篇开发的的框架,我们在目录 component\ui\下添加文件 com.ui.scrollBar.js, 在文件中定义com.ui.scrollBar类,继承com.ui.window类,如下
/** * 滚动条控件. * 创建:QZZ * 日期:2014-03-01 */ (function(undefined) { nameSpace("com.ui"); /** * 滚动条控件. */ com.ui.scrollBar = Extend(com.ui.window, { /** * 创建函数 */ create:function() { }, /** * 渲染. */ render:function() { } }); })();
在滚动条的创建函数中定义一些基本属性,如滚动条类型、滚动总数量、显示数量、滚动位置、滚动一条的步长及拖动按钮最短长度等,如下
/** * 创建函数 */ create:function() { this.base(); this.className = "com.ui.scrollBar"; this.logInfo("create"); //绑定明细总数量 this.scrollCount = 0; //显示区域可见数量 this.showCount = 0; //滚动位置 this.scrollIndex = 0; //每步滚动像素长 this.stepLen = 2; //拖动按钮最短长 this.dragBoxMinLen = 20; //横、纵向滚动条 this.option.scrollType = this.option.scrollType || "V"; //滚动条是否可见 this.visible = true; //按钮宽度 this.btnWidth = 15; //初始化宽高属性 if(this.option.scrollType == "V") { this.option.width = this.option.width || 16; this.option.height = this.option.height || 100; } else if(this.option.scrollType == "H") { this.option.width = this.option.width || 100; this.option.height = this.option.height || 16; } this.dragState = false; },
定义好基本的属性后,开始绘制滚动条的框架, 这里我们采用<TABLE>来实现, 比如纵向滚动条,则生成一个三行一列的<TABLE>,第一行与第三行用作上下按钮,中间用作滚动区域,(横向的同理),
然后在滚动区域(上边<table>的第二行)中又加入一个两行一列的<table>,用作中间拖动按钮,第一行,绘制边线与背景相同,第二行绘制成按钮,通过调整第一行的行高来设定按钮的位置,
绘制完成后,添加按钮的事件,及拖动事件, 如下:
/** * 渲染. */ render:function() { this.base(); //创建滚动条结构<table> if(this.scrollTable == null) { this.scrollTable = this.createElement("TABLE"); } //清除原有的行列,结构变化的时候,会有已存在行 while(this.scrollTable.rows.length > 0) { this.scrollTable.deleteRow(0); } //创建拖动按钮结构<TABLE> if(this.dragTable == null) { this.dragTable = this.createElement("TABLE"); } //清除原有行列,结构变化的时候,会有已存在行, while(this.dragTable.rows.length > 0) { this.dragTable.deleteRow(0); } //插入行列 if(this.option.scrollType == "V" && this.scrollTable.rows.length != 3) { this.priorBtn = this.scrollTable.insertRow(0).insertCell(0); this.centerRect = this.scrollTable.insertRow(1).insertCell(0); this.nextBtn = this.scrollTable.insertRow(2).insertCell(0); this.dragLen = this.dragTable.insertRow(0).insertCell(0); this.dragBox = this.dragTable.insertRow(1).insertCell(0); this.centerRect.appendChild(this.dragTable); } else if(this.option.scrollType == "H" && this.scrollTable.rows.length != 1) { var tr = this.scrollTable.insertRow(0); this.priorBtn = tr.insertCell(0); this.centerRect = tr.insertCell(1); this.nextBtn = tr.insertCell(2); var tr1 = this.dragTable.insertRow(0); this.dragLen = tr1.insertCell(0); this.dragBox = tr1.insertCell(1); this.centerRect.appendChild(this.dragTable); } var _this = this; //拖动框鼠标按下事件, 并打印标志dragState,把控件置为焦点 this.dragBox.onmousedown = function(ev) { //拖动状态 _this.dragState = true; _this.focus = true; } //上一个按钮鼠标按下事件,这里处理长按时的效果,采用延迟执行的方式, //scrollPrior()函数,是后续定义的向上滚动一行的函数, this.setInt = null; this.priorBtn.onmousedown = function(ev) { _this.scrollPrior(); _this.mouseDown = true; setTimeout(function() { if(_this.mouseDown) { _this.setInt = setInterval(function() { _this.scrollPrior(); if(_this.scrollIndex == _this.scrollCount - _this.showCount) { clearInterval(_this.setInt); } }, 50);//setInterval } }, 500); //setTimeout } //下一个按钮鼠标按下事件,这里处理长按时的效果,采用延迟执行的方式, //scrollNext()函数,是后续定义的向下滚动一行的函数, this.nextBtn.onmousedown = function(ev) { _this.scrollNext(); _this.mouseDown = true; setTimeout(function() { if(_this.mouseDown) { _this.setInt = setInterval(function() { _this.scrollNext(); if(_this.scrollIndex == _this.scrollCount - _this.showCount) { clearInterval(_this.setInt); }; }, 50); //setInterval } }, 500); //setTimeout } //中间区域鼠标按下事件, 控制向下、上翻页, //scrollPriorPage, scrollNextPage是后继定义的翻页函数。 this.centerRect.onmousedown = function(ev) { var ev = ev || event; if(_this.dragState != true) { var dlen = 0, clen; //debugger; var rect = this.getBoundingClientRect(); if(_this.option.scrollType == "V") { dlen = _this.dragLen.offsetHeight; clen = ev.clientY - rect.top; } else if(_this.option.scrollType == "H") { dlen = _this.dragLen.offsetWidth; clen = ev.clientX - rect.left; } if(clen > dlen) { _this.scrollPriorPage(); } else { _this.scrollNextPage(); } } } //添加到win容器中 this.win.appendChild(this.scrollTable); //刷新滚动条框, 该方法为后继定义的函数,用于刷新滚动的样式及位置。 this.refreshBox(); },
上边我们只是绘制出滚动条的结构,需要进行样式控制,下边refreshBox函数就是用于控制滚动条的样式及位置的,
/** * 刷新布局 */ refreshBox:function() { var rw = this._getRectWidth(), rh = this._getRectHeight() //设置按钮的样式及长、宽度, if(this.option.scrollType == "V") { this.priorBtn.style.height = this.btnWidth - 1 + "px"; this.setStyle(this.priorBtn, "scrollUp"); this.centerRect.style.height = (rh - 2 * this.btnWidth) + "px"; this.setStyle(this.centerRect, "scrollCell"); this.nextBtn.style.height = this.btnWidth - 1 + "px"; this.setStyle(this.nextBtn, "scrollDown"); this.dragTable.style.width = (rw - 1) + "px"; this.dragLen.style.height = "0px"; this.dragBox.style.height = this.btnWidth + "px"; } else if(this.option.scrollType == "H") { this.priorBtn.style.width = this.btnWidth + "px"; this.setStyle(this.priorBtn, "scrollPrior"); this.centerRect.style.width = (rw - 2 * this.btnWidth) + "px"; this.setStyle(this.centerRect, "scrollCell"); this.nextBtn.style.width = this.btnWidth + "px"; this.setStyle(this.nextBtn, "scrollNext"); this.dragTable.style.height = rh + "px"; this.dragLen.style.width = "0px"; this.dragBox.style.width = this.btnWidth + "px"; } //设置滚动区域的样式,及拖动按钮的样式, this.setStyle(this.dragLen, "scrollCell"); this.setStyle(this.dragBox, "scrollDrag"); //设置滚动表格和拖动表格的样式, this.setStyle(this.scrollTable, "scrollBox"); this.setStyle(this.dragTable, "scrollBox"); //设置宽、高 this.scrollTable.style.width = rw + "px"; this.scrollTable.style.height = rh + "px"; },
这上边用到几个样式,在com.comStyle.css文件中定义如下:
.scrollBox { border-collapse:collapse; border-spacing:0px; padding:0px; } .scrollCell { padding:0px; vertical-align:top; background-color:#eeeeee; } .scrollUp { padding:0px; background-color:#ddeeff; border-Bottom:1px solid #C3D2E6; } .scrollDown { padding:0px; background-color:#ddeeff; border-Top:1px solid #C3D2E6; } .scrollPrior { padding:0px; background-color:#ddeeff; border-right:1px solid #C3D2E6; } .scrollNext { padding:0px; background-color:#ddeeff; border-Left:1px solid #C3D2E6; } .scrollDrag { padding:0px; background-color:#ddeeff; border:1px solid #C3D2E6; }
完成以上结构后,只是完成了显示的效果,因为我们这个滚动条是通过设置数据明细数量来设定滚动的,因此需要与象素进行转换计算,以设置拖动按钮的位置,下面我们添加一个刷新函数,用于刷新滚动条的长度、拖动按钮的长度及位置,添加refresh函数,如下:
/** *跟据滚动数据,刷新滚动条位置 */ refresh:function() { //计算滚动区域外的数量 var sl = this.scrollCount - this.showCount; //发生了变化才重新计算 if(sl != this.tmpCount) { //计算总象素长度 var slpx = sl * this.stepLen; //计算拖动框长度 var cenLen = this.option.scrollType == "V"? this.centerRect.offsetHeight:this.centerRect.offsetWidth; var dragBoxLen = cenLen - slpx; //如果计算出来的拖动按钮过短,则重新计算步长,保证按钮不再缩短 if(dragBoxLen < this.dragBoxMinLen) { dragBoxLen = this.dragBoxMinLen; slpx = cenLen - dragBoxLen; this.stepLen = slpx/(this.scrollCount - this.showCount); } else { this.stepLen = 2; } //设置拖动按钮长度 if(this.option.scrollType == "V") { this.dragBox.style.height = (dragBoxLen - 2) + "px"; } else if(this.option.scrollType == "H") { this.dragBox.style.width = (dragBoxLen - 2) + "px"; } //缓存当前数量 this.tmpCount = sl; } //计算拖动框位置 var len = parseInt(this.scrollIndex * this.stepLen, 10); if(len < 0) { len = 0; } else if(len > cenLen - dragBoxLen) { len = cenLen - dragBoxLen } //设置位置值 if(this.option.scrollType == "V") { this.dragLen.style.height = len + "px"; } else if(this.option.scrollType == "H") { this.dragLen.style.width = len + "px"; } },
下面我们实现 拖动的事件,首先要先在鼠标按钮的时候初始化一些属性,再在鼠标弹起的时候,还原一些属性,这里我能通过重写doMouseDown,doMouseUp事件来实现,如下:
/** *鼠标按下事件 */ doMouseDown:function(ev) { this.base(ev); //记录原鼠标的按下位置 this.dragX = ev.clientX; this.dragY = ev.clientY; //记录原按钮的位置, if(this.option.scrollType == "V") { this.dragPosition = this.dragLen.offsetHeight; } else if(this.option.scrollType == "H") { this.dragPosition = this.dragLen.offsetWidth; } //标识按钮状态 this.mouseDown = true; }, /** *鼠标弹起事件 */ doMouseUp:function(ev) { this.base(ev); //还原拖动状态 this.dragState = false; //取消长按效果 if(this.setInt != null) { clearInterval(this.setInt); this.setInt = null; } //标识按钮状态 this.mouseDown = false; },
下面为鼠标移动事件,当拖动状态dragState等于true时,跟据鼠标的起始位置及当前位置计算滚动按钮的移动距离,并计算相应的滚动明细位置scrollIndex,并且执行滚动事件onScroll绑定的事件,由于滚动事件属于外部事件,这里作异常捕获处理。
/** *鼠标移动事件 */ doMouseMove:function(ev) { if(this.dragState) { var len = 0, dragBoxLen = 0, centerLen = 0; //计算设置拖动按钮的位置, if(this.option.scrollType == "V") { dragBoxLen = this._domValue(this.dragBox.style.height); centerLen = this._domValue(this.centerRect.style.height); len = this.dragPosition + ev.clientY - this.dragY; if(len < 0) { len = 0; } else if(len > centerLen - dragBoxLen) { len = centerLen - dragBoxLen; } this.dragLen.style.height = len + "px"; } else if(this.option.scrollType == "H") { dragBoxLen = this._domValue(this.dragBox.style.width); centerLen = this._domValue(this.centerRect.style.width); len = this.dragPosition + ev.clientX - this.dragX; if(len < 0) { len = 0; } else if(len > centerLen - dragBoxLen) { len = centerLen - dragBoxLen - 2; } this.dragLen.style.width = len + "px"; } //计算明细数量位置 var tmpScrollIndex = this.scrollIndex; if(dragBoxLen < 1) { this.scrollIndex = 0; } else if(len >= centerLen - dragBoxLen) { this.scrollIndex = this.scrollCount - this.showCount; } else { this.scrollIndex = parseInt(len/this.stepLen, 10); } //执行滚动事件 if(typeof this.onScroll == "function") { try { this.onScroll(this.scrollIndex, this.scrollIndex - tmpScrollIndex); } catch(e) { this.logInfo("onScroll Error!" + e.message); } } } },
下面我们再定义上边用到的上、下明细函数,及上、下翻页函数,如下:
/** * 向上滚动 */ scrollPrior:function() { if(this.scrollIndex > 0) { this.scrollIndex --; if(typeof this.onScroll == "function") { this.onScroll(this.scrollIndex, -1); } this.refresh(); } }, /** * 向下滚动 */ scrollNext:function() { if(this.scrollIndex < this.scrollCount - this.showCount) { this.scrollIndex ++; if(typeof this.onScroll == "function") { try { this.onScroll(this.scrollIndex, 1); } catch(e) { this.logInfo("onScroll Error!" + e.message); } } this.refresh(); } }, /** * 向上滚动翻页 */ scrollPriorPage:function() { var tmpIndex = this.scrollIndex; this.scrollIndex += this.showCount; if(this.scrollIndex > this.scrollCount - this.showCount) { this.scrollIndex = this.scrollCount - this.showCount; } if(tmpIndex != this.scrollIndex) { if(typeof this.onScroll == "function") { try { this.onScroll(this.scrollIndex, this.scrollIndex - tmpIndex); } catch(e) { this.logInfo("onScroll Error!" + e.message); } } this.refresh(); } }, /** * 向下滚动翻页 */ scrollNextPage:function() { var tmpIndex = this.scrollIndex; this.scrollIndex -= this.showCount; if(this.scrollIndex < 0) { this.scrollIndex = 0; } if(tmpIndex != this.scrollIndex) { if(typeof this.onScroll == "function") { try { this.onScroll(this.scrollIndex, this.scrollIndex - tmpIndex); } catch(e) { this.logInfo("onScroll Error!" + e.message); } } this.refresh(); } },
接着,再定义几个属性的设置函数,如下:
/** *滚动条总数量 */ setScrollCount:function(value) { this.scrollCount = value; }, /** *滚动条显示数量 */ setShowCount:function(value) { if(value >= this.scrollCount) { this.showCount = this.scrollCount; this.dragTable.style.display = "none"; } else { this.showCount = value; this.dragTable.style.display = ""; } }, /** *滚动条滚到第几个位置 */ setScrollIndex:function(index) { if(index < 0) { index = 0; } else if(index > this.scrollCount - this.showCount) { index = this.scrollCount - this.showCount; } if(this.scrollIndex != index) { var tmpIndex = this.scrollIndex; this.scrollIndex = index; if(typeof this.onScroll == "function") { try { this.onScroll(this.scrollIndex, this.scrollIndex - tmpIndex); } catch(e) { this.logInfo("onScroll Error!" + e.message); } } } },
最后设置高度,宽度的函数,
/** * 设置高度. */ setHeight:function(height) { this.base(height); this.refreshBox(); this.refresh(); }, /** * 设置宽度. */ setWidth:function(width) { this.base(width); this.refreshBox(); this.refresh(); }
到此我们的全部控件编写完成,从上边来看,有点长,但是这点长绝对值得,因为后续控件,将会大大降低实现难度,这里有个缺点,就是没有给向上、下按钮添加图片,不过,如果需要只需要修改样式文件,把图片加上即可,
当然,我们写了控制,那么就要测试一下,下面我们写几行代码,用来测试控件的使用,
首先在test.html文件中添加两个滚动条控件的标签,如下id=test12/13的两个控件:
<!DOCTYPE html> <head><title>test</title> <script src="../script/common/init.js" type="text/javascript"></script> </head> <body code="controllor/test.js" scroll="no" style="overflow:hidden"> <div id='test6' code='com.ui.panel' option='{"align":"alTop","height":"60","width":"200","borderWidth":1,"padding":1}'> <div id='test8' code='com.ui.toolButton' option='{"height":"60","width":"60","icon":"image/test3.ico"}'>确定</div> <div id='test9' code='com.ui.toolButton' option='{"height":"60","width":"60","icon":"image/test2.ico"}'>取消</div> <div id='test10' code='com.ui.toolButton' option='{"height":"60","width":"60","type":"split"}'></div> <div id='test11' code='com.ui.toolButton' option='{"height":"60","width":"60","icon":"image/test1.ico"}'>退出</div> </div> <div id='test1' code='com.ui.panel' option='{"align":"alTop","height":"40","width":"200","borderWidth":1,"padding":1}'></div> <div id='test4' code='com.ui.panel' option='{"align":"alBottom","height":"50","width":"200","borderWidth":1,"padding":1}'> <div id='test2' code='com.ui.button' option='{"height":"25","width":"100","top":"12","right":"116"}'></div> <div id='test3' code='com.ui.button' option='{"height":"25","width":"100","top":"12","right":"8"}'></div> </div> <div id='test7' code='com.ui.panel' option='{"align":"alLeft","height":"100","width":"200","borderWidth":1,"padding":1}'></div> <div id='test5' code='com.ui.panel' option='{"align":"alClient","height":"100","width":"200","borderWidth":1,"padding":1}'> <div id='test12' code='com.ui.scrollBar' option='{"height":"200","width":"20","scrollType":"V","borderWidth":1}'></div> <div id='test13' code='com.ui.scrollBar' option='{"height":"20","width":"200","scrollType":"H","borderWidth":1}'></div> </div> </body> </html>
然后我们在页面控制器中添加一些代码,
/** * test.html页面控制类 * 创建:qzz * 日期: 2014-05-01 */ (function(undefined) { /** * 控制类 */ testControllor = Extend(pageControllor, { //初始化页面 initPage:function() { //修改页面上的控件属性,绑定事件 this.test2.onClick = function() { alert("确定"); } this.test2.setCaption("确定"); this.test2.setWidth(50); this.test3.onClick = function() { alert("取消"); } this.test3.setCaption("取消"); this.test11.onClick = function() { alert("退出"); } this.test12.setScrollCount(50); this.test12.setShowCount(10); this.test12.setScrollIndex(17); this.test12.refresh(); this.test13.setScrollCount(100); this.test13.setShowCount(10); this.test13.setScrollIndex(17); this.test13.setWidth(400); //this.test13.refresh(); } }); })(); /** * 页面对象创建,且启动 */ thisWindow.onShow = function() { var tc = new testControllor(); tc.initPage(); }
如此就可以打开test.html页面查看效果,如图
写到此又靠一段落了,因为前期比较忙,更新的时间长了些,这一编有点长但是思路比较简单,实现难度也不算大,希望大家能看懂,
如果想看效果,可以下载源码包查看
请关注我的下一编,javascript控件开发之列表控件(1)
发表评论
-
javascript控件开发之工具栏控件
2014-06-10 23:30 740在前几篇的基础上,本篇将开发工具栏控件,工具栏控件一般包括三部 ... -
javascript控件开发之布局控件
2014-05-14 22:44 787上篇写完了页面控制器,本篇接着写下一个控件--布局控件 ... -
javascript控件开发之页面控制器
2014-05-01 11:46 661本篇,我们主要实现页面控制器,简单说就是用于控制当前h ... -
javascript控件开发之按钮控件
2014-04-23 23:07 717上一篇我们写完了可见窗口的基础控件,本篇我们来实现一个简单 ... -
javascript控件开发之可见控件(2)
2014-04-19 23:06 834经过上一篇,我们 ... -
javascript控件开发之可见控件(1)
2014-04-18 00:29 595上一篇写了第一个基础控件,本篇我们开始编写可见控件com ... -
javascript控件开发之控件初体验
2014-04-12 22:26 964此篇开始,我们正式进入了控件开发之旅,首先,一套好用的控 ... -
javascript控件开发之渲染对象
2014-04-10 21:37 714前面我们写了文件加载,类继承,都比较基础,有了前面的框 ... -
javascript控件开发之继承关系
2014-04-08 00:09 913经过上一篇,我们实现了文件的动态加载, 为了能方便编写 ... -
javascript控件开发之动态加载(2)
2014-04-07 19:34 993上一篇在init.js文件内编写了加载对象, 在这基础 ... -
javascript控件开发之动态加载(1)
2014-04-07 11:56 1818做了几年开发, 平时看着会做框架的高手,那个羡慕妒忌恨 ...
相关推荐
在Windows开发环境中,滚动条控件通常作为标准控件存在于Visual Basic、C++ Builder、Delphi等IDE中,开发者可以通过事件驱动编程来响应用户的滚动操作,例如Scroll事件,然后更新对应的内容视图。在Web开发中,...
然而,原始的GridView控件并未内置滚动条记忆功能,这意味着当用户在浏览大量数据时,一旦离开页面或刷新,滚动位置会重置,这在用户体验上可能不尽人意。 "修改的SmartGridView扩展控件"是为了弥补这个不足而设计...
然而,该控件默认情况下会带有标准的浏览器边框和滚动条,这可能不符合某些设计需求。本篇文章将详细探讨如何通过编程手段去除WebBrowser控件的边框和滚动条,使它更加融入到应用程序的界面设计中。 首先,我们要...
解决 ReportViewer 的双竖滚动条问题需要对 ReportViewer 控件的 CSS 样式和 JavaScript 代码进行修改。通过添加一个名为 "hiddenY" 的 CSS 样式和使用 JavaScript 来隐藏竖滚动条,我们可以成功地解决 ReportViewer...
滚动条控件是用户界面设计中的一个重要元素,它允许用户在内容超过屏幕或窗口显示范围时进行导航。在本文中,我们将深入探讨如何通过代码来定制滚动条的样式、颜色以及其在操作中的功能。 首先,我们要理解滚动条的...
在Web开发中,HTML的`<select>`元素并不直接支持滚动条,但可以通过CSS和JavaScript来模拟实现。CSS可以设置overflow属性为auto或scroll,使得元素在内容溢出时显示滚动条。JavaScript库如jQuery或Vue.js提供API来...
以上就是关于“js 固定位置的层 不随滚动条滚动”的详细解释,以及与之相关的浮动层、固定位置和滚动条的概念。在实际应用中,开发者需要综合运用CSS和JavaScript,兼顾功能实现和性能优化,以提供最佳的用户体验。
JavaScript DataTables 是一款高度可定制、功能强大的前端表格插件,尤其适用于需要处理大量数据的网页应用。这个表格控件支持在PHP、Java和DotNet等后端框架中使用,可以方便地对数据进行排序、搜索、分页和格式化...
在大多数编程环境中,滚动条是自动出现在需要的窗口或控件中的,它们通常由操作系统或UI库自动管理。然而,为了实现自定义控制,我们需要深入到程序逻辑中,对滚动条的行为进行干预。 在Demo中,我们可能使用了一种...
在桌面应用中,开发者可能需要设置控件的大小和滚动条属性,确保它们能够正确响应用户的滚动操作。在Web开发中,CSS的`overflow`属性是关键,它可以设置为`auto`或`scroll`,使元素在内容溢出时自动显示滚动条。 在...
本教程重点讲解如何为Asp.net 2.0开发一个浮动工具条控件,该控件可以实现在网页上动态显示和隐藏,提供便捷的操作界面。"PopupTraceMenuExample"这个文件名很可能是指一个示例项目,用于演示如何创建并应用这种浮动...
例如,在上述案例中,为了获取B*单元格的值,可以在JavaScript中使用`contentPane.curLGP.selectTDCell("A2")`方法,这条语句的作用是强制让焦点跳转到A*单元格。这样一来,原先在B*单元格的数据立即刷新,并且可以...
第14章是关于扩展控件方案的,重点讲解了如何定制gridview多表头,以及如何固定gridview表头并增加滚动条支持。 第15章为自定义控件设计模式下编程的汇总,包括设计时元数据支持、属性编辑器、控件设计器区域等。 ...
在本示例中,我们将讨论如何结合jQuery和AJAX技术,实现在ASP.NET环境中,当用户滚动滚动条时,下拉列表控件自动加载更多数据的功能。 jQuery是一个流行的JavaScript库,它简化了DOM操作、事件处理以及Ajax交互。在...
总的来说,CSS的`position`属性是实现跟随滚动条漂浮层的关键。通过巧妙地设置`top`、`bottom`、`left`和`right`属性,你可以自由地定制漂浮层在页面上的位置,为用户提供更流畅的浏览体验。在实际项目中,可以结合...
3. Linux:Linux环境下的滚动条实现依赖于窗口管理器和桌面环境,例如GTK+和Qt提供了各自的滚动条控件。 4. Web浏览器:HTML5引入了CSS3的滚动条样式控制,允许开发者自定义滚动条的外观和行为。 5. 移动设备:触屏...
在ASP.NET开发中,滚动条(ScrollBar)是一个重要的交互元素,它允许用户浏览超过视口范围的内容。在网页设计和应用程序界面中,滚动条的合理使用可以极大地提升用户体验。本资源包提供了多种滚动条实现方式,适用于...
JavaScript 分页控件是网页开发中常用的一种组件,主要用于处理大量数据展示时的页面加载问题。在2009年3月13日这个时间点上,开发者们可能正在寻找有效的解决方案来优化用户体验,避免一次性加载过多数据导致页面...
14.3 固定gridview表头并增加滚动条支持 527 14.3.1 功能概述 527 14.3.2 代码实现 528 14.4 本章总结 533 第15章 自定义控件设计模式下编程汇总 534 15.1 .net框架对设计时支持 534 15.2 设计时元数据支持 ...