在JavaScript的开发中,我们都会写一些工具类来帮我们简化一些业务操作的逻辑,一下就貼几个我在项目开发过程中常用的工具类。表达能力有限,各位看官还是看源码吧。

一、日期处理工具类。
/**
* 日期处理工具类
* @Authors: jackyWHJ
* @date 2013-10-18
*
*/
var DateUtils = {
/**
* 得到日期在一年当中的周数
*/
getISOYearWeek: function(date) {
var commericalyear = this.getCommerialYear(date);
var date2 = this.getYearFirstWeekDate(commericalyear);
var day1 = date.getDay();
if (day1 == 0) day1 = 7;
var day2 = date2.getDay();
if (day2 == 0) day2 = 7;
var d = Math.round((date.getTime() - date2.getTime() + (day2 - day1) * (24 * 60 * 60 * 1000)) / 86400000);
return Math.floor(d / 7) + 1;
},
/**
* 得到一年之中的第一周的日期
*/
getYearFirstWeekDate: function(commericalyear) {
var yearfirstdaydate = new Date(commericalyear, 0, 1);
var daynum = yearfirstdaydate.getDay();
var monthday = yearfirstdaydate.getDate();
if (daynum == 0) daynum = 7;
if (daynum <= 4) {
return new Date(yearfirstdaydate.getFullYear(), yearfirstdaydate.getMonth(), monthday + 1 - daynum);
} else {
return new Date(yearfirstdaydate.getFullYear(), yearfirstdaydate.getMonth(), monthday + 8 - daynum);
}
},
/**
* 获取当前日期的年份
*/
getCommerialYear: function(date) {
var daynum = date.getDay();
var monthday = date.getDate();
if (daynum == 0) daynum = 7;
var thisthurdaydate = new Date(date.getFullYear(), date.getMonth(), monthday + 4 - daynum);
return thisthurdaydate.getFullYear();
},
/**
* 获取周一
*/
getWeekStartDate: function(date) {
var nowDayOfWeek = (date.getDay() == 0) ? 6 : date.getDay() - 1;
var t = new Date(date); //复制并操作新对象,避免改动原对象
//t.setDate(t.getDate() - nowDayOfWeek);
t.setTime(t.getTime() - nowDayOfWeek * 86400000);
return t;
},
/**
* 获取周日。本周一+6天
*/
getWeekEndDate: function(date) {
var t = new Date(date); //复制并操作新对象,避免改动原对象
//t.setDate(this.getWeekStartDate(date).getDate() + 6); //date来计算会有出错的情况出现比如10.1这一周
t.setTime(this.getWeekStartDate(date).getTime() + 6 * 86400000);
return t;
},
/**
* 日期格式化,第一个参数为日期,第二个参数为日期格式化的格式,返回一个格式化后的字符串
*/
dateFormat: function(date, format) {
var o = {
"M+": date.getMonth() + 1, //month
"d+": date.getDate(), //day
"h+": date.getHours(), //hour
"m+": date.getMinutes(), //minute
"s+": date.getSeconds(), //second
"q+": Math.floor((date.getMonth() + 3) / 3), //quarter
"S": date.getMilliseconds() //millisecond
};
if (/(y+)/.test(format)) {
format = format.replace(RegExp.$1, (date.getFullYear() + "").substr(4 - RegExp.$1.length));
} for (var k in o) {
if (new RegExp("(" + k + ")").test(format)) {
format = format.replace(RegExp.$1, RegExp.$1.length == 1 ? o[k] : ("00" + o[k]).substr(("" + o[k]).length));
}
}
return format;
},
/**
* 判断输入的日期格式是否为 yyyy-mm-dd 或 yyyy-m-d
*/
isDate: function (dateString) {
//判断日期是否为空
if (dateString.trim() == "") {
alert("日期为空!请输入格式正确的日期\n\r日期格式:yyyy-mm-dd\n\r例 如:2013-08-08\n\r");
return false;
} else {
dateString = dateString.trim();
} //年月日正则表达式
var r = dateString.match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/);
if (r == null) {
alert("请输入格式正确的日期\n\r日期格式:yyyy-mm-dd\n\r例 如:2013-08-08\n\r");
return false;
}
var d = new Date(r[1], r[3] - 1, r[4]);
var num = (d.getFullYear() == r[1] && (d.getMonth() + 1) == r[3] && d.getDate() == r[4]);
if (num == 0) {
alert("请输入格式正确的日期\n\r日期格式:yyyy-mm-dd\n\r例 如:2013-08-08\n\r");
}
return (num != 0); }
};
二、表格合并工具类。
/**
* 表格通用工具,目前只有合并表格功能,以后慢慢完善
* @Authors: jackyWHJ
* @date 2013-10-18
*
*/
var TableUtils = { /**
* 函数说明:合并指定表格(表格id为wTableId)指定列(列数为wTableColumn)的相同文本的相邻单元格
* 参数说明:wTableId 为需要进行合并单元格的表格的id。如在HTMl中指定表格 id="data" ,此参数应为 #data
* 参数说明:wTableColumn 为需要合并单元格的所在列。为数字,从最左边第一列为1开始算起。
*/
tableColMerger: function(wTableId, wTableColumn) { var wTableFirstTd = ""; var wTableCurrentTd = ""; var wTableSpanNum = 0;
var wTableObj = $(wTableId + " tr td:nth-child(" + wTableColumn + ")");
wTableObj.each(function(i) {
if (i == 0) {
wTableFirstTd = $(this);
wTableSpanNum = 1; } else {
wTableCurrentTd = $(this);
if (wTableFirstTd.text() == wTableCurrentTd.text()) {
wTableSpanNum++;
wTableCurrentTd.hide(); //remove();
} else {
wTableFirstTd = $(this);
wTableSpanNum = 1;
}
}
wTableFirstTd.attr("rowSpan", wTableSpanNum);
});
}, /**
* 函数说明:合并指定表格(表格id为wTableId)指定行(行数为wTableRownum)的相同文本的相邻单元格
* 参数说明:wTableId 为需要进行合并单元格的表格id。如在HTMl中指定表格 id="data" ,此参数应为 #data
* 参数说明:wTableRownum 为需要合并单元格的所在行。其参数形式请参考jQuery中nth-child的参数。
* 如果为数字,则从最左边第一行为1开始算起。
* "even" 表示偶数行
* "odd" 表示奇数行
* "3n+1" 表示的行数为1、4、7、10.
* 参数说明:wTableMaxcolnum 为指定行中单元格对应的最大列数,列数大于这个数值的单元格将不进行比较合并。
* 此参数可以为空,为空则指定行的所有单元格要进行比较合并。
*/
tableRowMerger: function(wTableId, wTableRownum, wTableMaxcolnum) {
if (wTableMaxcolnum == void 0) {
wTableMaxcolnum = 0;
}
var wTableFirstTd = "";
var wTableCurrentTd = "";
var wTableSpanNum = 0;
$(wTableId + " tr:nth-child(" + wTableRownum + ")").each(function(i) {
var wTableObj = $(this).children();
wTableObj.each(function(i) {
if (i == 0) {
wTableFirstTd = $(this);
wTableSpanNum = 1;
} else if ((wTableMaxcolnum > 0) && (i > wTableMaxcolnum)) {
return "";
} else {
wTableCurrentTd = $(this);
if (wTableFirstTd.text() == wTableCurrentTd.text()) {
wTableSpanNum++;
wTableCurrentTd.hide(); //remove();
} else {
wTableFirstTd = $(this);
wTableSpanNum = 1;
}
}
wTableFirstTd.attr("colSpan", wTableSpanNum);
});
});
}, /**
* 函数说明:合并指定表格(表格id为wTableId)指定按照列(列数为fromTableColumn)的合并方式合并目标列(列数为toTableColumn)的单元格
* 参数说明:wTableId 为需要进行合并单元格的表格的id。如在HTMl中指定表格 id="data" ,此参数应为 #data
* 参数说明:fromTableColumn 已经合并的单元格所在列。为数字,从最左边第一列为1开始算起。
* 参数说明:toTableColumn 目标列,为需要合并单元格的所在列。为数字,从最左边第一列为1开始算起。
*/
tableColMergerSpecial: function (wTableId, fromTableColumn,toTableColumn) { var wTableCurrentTd = "";
var blockRowArr = {}; //用来存放不需要隐藏的行索引
var fromTableObj = $(wTableId + " tr td:nth-child(" + fromTableColumn + ")");
fromTableObj.each(function (i) {
wTableCurrentTd = $(this);
if (wTableCurrentTd.attr("rowSpan")) {
blockRowArr[i] = wTableCurrentTd.attr("rowSpan");
}
});
if (1 > blockRowArr.length) {
//样本列不存在合并;
return;
}
var toTableObj = $(wTableId + " tr td:nth-child(" + toTableColumn + ")");
var isBlock = false; //是否显示
toTableObj.each(function (i) {
wTableCurrentTd = $(this);
isBlock = false;
for (var j in blockRowArr) {
if (i == j) {
isBlock = true;
break;
}
}
if (isBlock) {
wTableCurrentTd.attr("rowSpan", blockRowArr[i]);
} else {
wTableCurrentTd.hide(); //remove();
}
});
}, /**
* 函数说明:隐藏指定表格(表格id为wTableId)指定列(列数为wTableColumn)
* 参数说明:wTableId 为需要进行隐藏列的表格的id。如在HTMl中指定表格 id="data" ,此参数应为 #data
* 参数说明:wTableColumn 为需要隐藏的所在列。为数字,从最左边第一列为1开始算起。
*/
tableColHide: function (wTableId, wTableColumn) { var wTableCurrentTd = "";
//隐藏列头
$(wTableId + " tr th:nth-child(" + wTableColumn + ")").hide();
//遍历表格隐藏单元格
var wTableObj = $(wTableId + " tr td:nth-child(" + wTableColumn + ")");
wTableObj.each(function (i) {
wTableCurrentTd = $(this);
wTableCurrentTd.hide(); //remove();
});
},
};
三、数字处理工具类。
/**  数字格式通用工具,目前只写了数字加千分位功能,以后慢慢完善
* @Authors: jackyWHJ
* @date 2013-10-18
*
*/
var NumberFormatter = {
//函数说明:给数字加千分位显示
//参数说明:num 需要加千分位的数字 numToThousandsSeparator: function (num) {
//如果传进来的值不是数字,则原值返回
if (!Number(num) || num < 1000) {
return num;
}
num = num + "";
var re = /(-?\d+)(\d{3})/;
//正则判断
while (re.test(num)) {
//符合条件则进行替换
num = num.replace(re, "$1,$2");
}
return num;
}
};
这个加千分位的司徒正美有一篇博客很有意思。“如何将阿拉伯数字每三位一逗号分隔,如:15000000转化为15,000,000
 
四:将url的查询参数解析成字典对象
无非就是拆字符或者用正则匹配来解决,因为url允许用户随意输入,如果用拆字符的方式,有任何一处没有考虑到容错,就会导致整个js都报错。而正则就没有这个问题,他只匹配出正确的配对,非法的全部过滤掉,简单,方便。
function getQueryObject(url) {
url = url == null ? window.location.href : url;
var search = url.substring(url.lastIndexOf("?") + 1);
var obj = {};
var reg = /([^?&=]+)=([^?&=]*)/g;
search.replace(reg, function (rs, $1, $2) {
var name = decodeURIComponent($1);
var val = decodeURIComponent($2);
val = String(val);
obj[name] = val;
return rs;
});
return obj;
}

实用篇:说说我在JavaScript项目中使用的工具类的更多相关文章

  1. 自己项目中PHP常用工具类大全分享

    <?php /** * 助手类 * @author www.shouce.ren * */ class Helper { /** * 判断当前服务器系统 * @return string */ ...

  2. 在维护项目中的UUID工具类

    import java.util.UUID; /** * <p> * Title:uuID生成器 * </p> * <p> * Description:UUID 标 ...

  3. iOS开发小技巧--微博项目中的键盘工具条

    微博项目中的键盘工具条 项目中的键盘工具条不能使用inputAccessoryView,因为inputAccessoryView不能实现键盘隐藏的时候,工具条还显示在眼前,如图: 所以,果断决定将工具 ...

  4. Entity Framework 的小实例:在项目中添加一个实体类,并做插入操作

    Entity Framework 的小实例:在项目中添加一个实体类,并做插入操作 1>. 创建一个控制台程序2>. 添加一个 ADO.NET实体数据模型,选择对应的数据库与表(Studen ...

  5. 设计模式(一)单例模式:创建模式 ASPNET CORE WEB 应用程序的启动 当项目中 没有STARTUP.CS 类如何设置启动 配置等等

    设计模式(一)单例模式:创建模式 先聊一下关于设计的几个原则(1)单一原则(SRP):一个类应该仅有一个引起它变化的原因 :意思就是 (一个类,最好只负责一件事情,并且只有一个引起它变化的原因(2)开 ...

  6. 四、spring集成ibatis进行项目中dao层基类封装

    Apache iBatis(现已迁至Google Code下发展,更名为MyBatis)是当前IT项目中使用很广泛的一个半自动ORM框架,区别于Hibernate之类的全自动框架,iBatis对数据库 ...

  7. Java8中的LocalDateTime工具类

    网上搜索了半天都没有找到Java8的LocalDateTime的工具类,只好自己写了一个,常用功能基本都有.还在用Date的Java同道该换换了. 个人项目地址:https://github.com/ ...

  8. Android 中替代 sharedpreferences 工具类的实现

    Android 中替代 sharedpreferences 工具类的实现 背景 想必大家一定用过 sharedpreferences 吧!就我个人而言,特别讨厌每次 put 完数据还要 commit. ...

  9. JAVA中封装JSONUtils工具类及使用

    在JAVA中用json-lib-2.3-jdk15.jar包中提供了JSONObject和JSONArray基类,用于JSON的序列化和反序列化的操作.但是我们更习惯将其进一步封装,达到更好的重用. ...

随机推荐

  1. 重启nginx后丢失nginx.pid的解决方法(转)

    一,nginx的停止操作 停止操作是通过向nginx进程发送信号来实现的.步骤1:查询nginx主进程号 ps -ef | grep nginx 在进程列表里 面找master进程,它的编号就是主进程 ...

  2. mkdir的参数-p的作用

    mkdir -p /nfs 也就是加上-p参数,之前只知道是递归创建目录,于是就发问了,得到的答案是: -p, --parents              no error if existing, ...

  3. apue学习笔记(第三章 文件I/O)

    本章开始讨论UNIX系统,先说明可用的文件I/O函数---打开文件.读写文件等 UNIX系统中的大多数文件I/O只需用到5个函数:open.read.write.lseek以及close open函数 ...

  4. Mac下面的SecureCRT(附破解方案) 更新到最新的7.3.2(转)

    转自 http://bbs.weiphone.com/read-htm-tid-6939481.html 继续更新到7.3.2的破解.只是升级了下secureCRT到7.3.2,方法还是不变 相信很多 ...

  5. MapReduce小文件处理之CombineFileInputFormat实现

    在MapReduce使用过程中.一般会遇到输入文件特别小(几百KB.几十MB).而Hadoop默认会为每一个文件向yarn申请一个container启动map,container的启动关闭是很耗时的. ...

  6. How to Use HTML5 FUll Screen API(怎样使用HTML5全屏接口)

    原文链接:http://www.sitepoint.com/use-html5-full-screen-api/ 假设你不太喜欢变化太快的东西,那么web开发可能不适合你. 我曾在2012年末有写过F ...

  7. 【机器学习详解】SMO算法剖析(转载)

    [机器学习详解]SMO算法剖析 转载请注明出处:http://blog.csdn.net/luoshixian099/article/details/51227754 CSDN−勿在浮沙筑高台 本文力 ...

  8. 篇二、理解Android Studio的视图和目录分析,这个是转载

    看不清的话可以可以将图片在新窗口中打开,以原图的大小显示.   原文链接:http://blog.csdn.net/siyehuazhilian/article/details/42123563   ...

  9. Unity3D引擎之渲染技术系列一

    笔者介绍:姜雪伟,IT公司技术合伙人,IT高级讲师,CSDN社区专家,特邀编辑,畅销书作者.国家专利发明人;已出版书籍:<手把手教你架构3D游戏引擎>电子工业出版社和<Unity3D ...

  10. Linux 能PING IP 但不能PING 主机域名的解决方法 vim /etc/nsswitch.conf hosts: files dns wins

    Linux 能PING IP 但不能PING 主机域名的解决方法 转载 2013年12月25日 10:24:27 13749 . vi /etc/nsswitch.conf hosts: files ...