tableSort.class.js
复制代码 代码如下:
/* * 表格名不能为空,可为已获取的对象或名字 * 表头名默认为:tag * 通过自行编写接口可实现不同的触发排序方式 * * 作者:Auntion * E-mail:Auntion@Gmail.com * OICQ:82874972 * * 日期:2007年04月22日 - 测试 - 待修正 */ var tableSort= function(element,tagName,upStyle,downStyle){this.table= (typeof(element) == 'string') ? TAGDom.fromId(element) : element;this.td = this.table.getElementsByTagName("td"); this.hName= (tagName.length<1) ? "tag" : tagName;this.rows = this.table.rows;this.byUp = (upStyle == undefined) ? "DescUp" : upStyle ;this.byDown = (downStyle == undefined) ? "DescDown" : downStyle ;var totalTd = [];var totalNr = [];var totalTag= [];this.tempCellIndex; this.tempStatus = {};var setAllTag = function(){ for(var i = 0; i < this.td.length; i++){if(this.td[i].className === this.hName) totalTag.push(this.td[i]);}}.bind(this);var getStatus = function(tagName){this.tempStatus[tagName] = (this.tempStatus[tagName] == true) ? false : true;for(tags in this.tempStatus){if(tags == tagName) return this.tempStatus[tags];else delete this.tempStatus[tags];}}.bind(this);var changeShow = function(cellIn,status){for(var i=0; i<totalTag.length; i++){if(totalTag[i].cellIndex == cellIn){if(status == true) totalTag[i].className = this.byUp;else if(status == false) totalTag[i].className = this.byDown;}else{totalTag[i].className = this.hName;}}}.bind(this);var startSort = function(status){for (var i = totalNr[this.tempCellIndex].length - 1; i > 0; i--){for (var j = 0; j < i; ++j){if ( (status == true) ? totalNr[this.tempCellIndex][j] > totalNr[this.tempCellIndex][j + 1] : totalNr[this.tempCellIndex][j] < totalNr[this.tempCellIndex][j + 1] ){var temp = totalNr[this.tempCellIndex][j + 1];totalNr[this.tempCellIndex][j + 1] = totalNr[this.tempCellIndex][j];totalNr[this.tempCellIndex][j] = temp;for(var n=0; n<totalNr.length; n++){if(n != this.tempCellIndex){var temps = totalNr[n][j+1];totalNr[n][j + 1] = totalNr[n][j];totalNr[n][j] = temps;}}}}};InsertContect();}.bind(this);var InsertContect = function(){ for(var i=0; i<totalTd.length; i++){for(var j=0; j<totalTd[i].length; j++){totalTd[i][j].innerHTML = totalNr[i][j];}};totalTd.length = 0;totalNr.length = 0;};this.init = function(status){for(var i=0; i<(this.td.length/this.rows.length); i++){totalTd[i] = new Array();totalNr[i] = new Array();for(var j=0; j<this.rows.length; j++){if(this.rows[j].cells[i].className !== this.hName){totalTd[i][j-1] = this.rows[j].cells[i];if(IsNumber(this.rows[j].cells[i].innerHTML) == true){totalNr[i][j-1] = parseInt(this.rows[j].cells[i].innerHTML);}else{totalNr[i][j-1] = this.rows[j].cells[i].innerHTML;}}}}startSort(status);} /********************************************************************************************************************************/ /**通过点击标签触发排序事件**/ //public: 通过默认鼠标事键触发 (interface example)(设置用户接口的范例) this.toTagStart = function(){ setAllTag(); //获取标签 for(var i=0; i<totalTag.length; i++){ totalTag[i].sIndex = function(cIndex){ this.tempCellIndex=cIndex }.bind(this); //设置列index totalTag[i].gStatus = function(values){ return getStatus(values) }; //获取与设置状态 totalTag[i].ceShow = function(i,s){ changeShow(i,s) }; //改变显示的东西 totalTag[i].stSort = function(status){ this.init(status) }.bind(this); //初始化 totalTag[i].onselectstart = function(){ return false }; //点击不选中文字 totalTag[i].onclick = function(){ this.sIndex(this.cellIndex); this.status = this.gStatus(this.firstChild.nodeValue); this.ceShow(this.cellIndex,this.status); this.stSort(this.status); } } } }
Language.ext.js
复制代码 代码如下:
/* * By Auntion QQ:82874972 Blog:Auntion@blogbus.com Email:Auntion@Gmail.com 请勿删除此部分注释.谢谢! ver date-2007-02-01 * */ var isIe = /msie/i.test(navigator.userAgent); var TAGDom = { fromId: function(i){ return document.getElementById(i); }, fromName: function(i){ return document.getElementById(i); }, fromClass: function(className,baseId) { this.fatherId = null; if(!baseId){ this.fatherId = document; }else{ this.fatherId = DOM.fromId(baseId); } var basic = fatherId.getElementsByTagName("*") || document.all; var child = null; var classNames = null; var aggregate = []; for (var i = 0; i < basic.length; i++) { child = basic[i]; classNames = child.className.split(" "); for (var j = 0; j < classNames.length; j++) { if (classNames[j] == className) { aggregate.push(child); break; } } } return aggregate; } }; function externalStyle (element, target) { this.setReturn; if (element.currentStyle){ this.setReturn = element.currentStyle[target]; }else if (window.getComputedStyle){ this.setReturn = getComputedStyle (element,"").getPropertyValue(target); } return this.setReturn; } String.prototype.toInt = function(){ return parseInt(this.replace(/[a-zA-Z]+/,'')); } String.prototype.trim = function(){ return this.replace(/(^\s*)|(\s*$)/g, ""); } Function.prototype.bind = function(e) { var source = this; return function() { return source.apply(e,arguments); } } function IsNumber(_str){ var tmp_str = _str.trim(); var pattern = /^(- ¦\+)?\d+(\d+)?$/; return pattern.test(tmp_str); }
使用实例_1.htm
复制代码 代码如下:
<html> <head> <title>Auntion - TableSort 测试交流</title> <style type="text/css"> #bodys{ border-top:1px solid #0099FF; border-left:1px solid #0099FF; } #bodys td { border-bottom:1px solid #0099FF; border-right:1px solid #0099FF; font-size:12px; height:22px; line-height:22px; text-align:left; padding-left:10px; background:#DFEFFF; color:#666666; } #bodys td.tag { background:#95D5FF; color:#333333; font-weight:900; height:28px; line-height:28px; cursor:pointer; } #bodys td.DescUp { background:#FFFFCC url("byUp.gif") no-repeat right 6px; color:#333333; font-weight:900; height:28px; line-height:28px; cursor:pointer; } #bodys td.DescDown { background:#FFFFCC url("byDown.gif") no-repeat right 6px; color:#333333; font-weight:900; height:28px; line-height:28px; cursor:pointer; } </style> <script language="javascript" type="text/javascript" src="Language.ext.js"></script> <script language="javascript" type="text/javascript" src="tableSort.class.js"></script> </head> <body> <table border="0" cellspacing="0" cellpadding="0" id="bodys"> <tr> <td width="45" class="tag">选择</td> <td width="50" class="tag">数字</td> <td width="50" class="tag">字母</td> <td width="80" class="tag">名字</td> <td width="150" class="tag">地址</td> <td width="80" class="tag">时间</td> </tr> <tr> <td><input type="checkbox" checked></td> <td>1</td> <td>a</td> <td>谢诗圆</td> <td>http://www.php.cn/;/td> <td>2007-12-16</td> </tr> <tr> <td><input type="checkbox" checked></td> <td>4</td> <td>c</td> <td>auntion</td> <td>http://www.php.cn/;/td> <td>2006-12-06</td> </tr> <tr> <td><input type="checkbox"></td> <td>3</td> <td>b</td> <td>疯狂的石头</td> <td>http://www.php.cn/;/td> <td>2007-03-12</td> </tr> <tr> <td><input type="checkbox"></td> <td>3.2</td> <td>d</td> <td>谢某人</td> <td>http://www.php.cn/;/td> <td>2000-01-01</td> </tr> <tr> <td><input type="checkbox" checked></td> <td>5</td> <td>f</td> <td>小小强</td> <td>http://www.php.cn/;/td> <td>2008-12-31</td> </tr> <tr> <td><input type="checkbox"></td> <td>7</td> <td>e</td> <td>疯狂的man</td> <td>http://www.php.cn/;/td> <td>2006-11-12</td> </tr> <tr> <td><input type="checkbox"></td> <td>71</td> <td>g</td> <td>小强</td> <td>http://www.php.cn/;/td> <td>2002-08-23</td> </tr> <tr> <td><input type="checkbox" checked></td> <td>8</td> <td>h</td> <td>王庆</td> <td>http://www.php.cn/;/td> <td>1999-08-25</td> </tr> </table> <script language="javascript" type="text/javascript"> var apply = new tableSort("bodys","tag"); apply.toTagStart(); //这里将使用已经定义的一种默认触发方式. </script> </body> </html>
以上就是Auntion-TableSort javascript类文件_javascript技巧的内容,更多相关内容请关注PHP中文网(www.php.cn)!

不同JavaScript引擎在解析和执行JavaScript代码时,效果会有所不同,因为每个引擎的实现原理和优化策略各有差异。1.词法分析:将源码转换为词法单元。2.语法分析:生成抽象语法树。3.优化和编译:通过JIT编译器生成机器码。4.执行:运行机器码。V8引擎通过即时编译和隐藏类优化,SpiderMonkey使用类型推断系统,导致在相同代码上的性能表现不同。

JavaScript在现实世界中的应用包括服务器端编程、移动应用开发和物联网控制:1.通过Node.js实现服务器端编程,适用于高并发请求处理。2.通过ReactNative进行移动应用开发,支持跨平台部署。3.通过Johnny-Five库用于物联网设备控制,适用于硬件交互。

我使用您的日常技术工具构建了功能性的多租户SaaS应用程序(一个Edtech应用程序),您可以做同样的事情。 首先,什么是多租户SaaS应用程序? 多租户SaaS应用程序可让您从唱歌中为多个客户提供服务

本文展示了与许可证确保的后端的前端集成,并使用Next.js构建功能性Edtech SaaS应用程序。 前端获取用户权限以控制UI的可见性并确保API要求遵守角色库

JavaScript是现代Web开发的核心语言,因其多样性和灵活性而广泛应用。1)前端开发:通过DOM操作和现代框架(如React、Vue.js、Angular)构建动态网页和单页面应用。2)服务器端开发:Node.js利用非阻塞I/O模型处理高并发和实时应用。3)移动和桌面应用开发:通过ReactNative和Electron实现跨平台开发,提高开发效率。

JavaScript的最新趋势包括TypeScript的崛起、现代框架和库的流行以及WebAssembly的应用。未来前景涵盖更强大的类型系统、服务器端JavaScript的发展、人工智能和机器学习的扩展以及物联网和边缘计算的潜力。

JavaScript是现代Web开发的基石,它的主要功能包括事件驱动编程、动态内容生成和异步编程。1)事件驱动编程允许网页根据用户操作动态变化。2)动态内容生成使得页面内容可以根据条件调整。3)异步编程确保用户界面不被阻塞。JavaScript广泛应用于网页交互、单页面应用和服务器端开发,极大地提升了用户体验和跨平台开发的灵活性。

Python更适合数据科学和机器学习,JavaScript更适合前端和全栈开发。 1.Python以简洁语法和丰富库生态着称,适用于数据分析和Web开发。 2.JavaScript是前端开发核心,Node.js支持服务器端编程,适用于全栈开发。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

WebStorm Mac版
好用的JavaScript开发工具

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。