基于prototype扩展的JavaScript常用函数库


Posted in Javascript onNovember 30, 2010
/** 
2 * 检索数组元素(原型扩展或重载) 
3 * @param {o} 被检索的元素值 
4 * @type int 
5 * @returns 元素索引 
6 */ 
7 Array.prototype.contains = function(o) { 
8 var index = -1; 
9 for(var i=0;i<this.length;i++){if(this[i]==o){index = i;break;}} 
return index; 
} /** 
* 日期格式化(原型扩展或重载) 
* 格式 YYYY/yyyy/YY/yy 表示年份 
* MM/M 月份 
* W/w 星期 
* dd/DD/d/D 日期 
* hh/HH/h/H 时间 
* mm/m 分钟 
* ss/SS/s/S 秒 
* @param {formatStr} 格式模版 
* @type string 
* @returns 日期字符串 
*/ 
Date.prototype.format = function(formatStr){ 
var str = formatStr; 
var Week = ['日','一','二','三','四','五','六']; 
str=str.replace(/yyyy|YYYY/,this.getFullYear()); 
str=str.replace(/yy|YY/,(this.getYear() % 100)>9?(this.getYear() % 100).toString():'0' + (this.getYear() % 100)); 
str=str.replace(/MM/,(this.getMonth()+1)>9?(this.getMonth()+1).toString():'0' + (this.getMonth()+1)); 
str=str.replace(/M/g,this.getMonth()); 
str=str.replace(/w|W/g,Week[this.getDay()]); 
str=str.replace(/dd|DD/,this.getDate()>9?this.getDate().toString():'0' + this.getDate()); 
str=str.replace(/d|D/g,this.getDate()); 
str=str.replace(/hh|HH/,this.getHours()>9?this.getHours().toString():'0' + this.getHours()); 
str=str.replace(/h|H/g,this.getHours()); 
str=str.replace(/mm/,this.getMinutes()>9?this.getMinutes().toString():'0' + this.getMinutes()); 
str=str.replace(/m/g,this.getMinutes()); 
str=str.replace(/ss|SS/,this.getSeconds()>9?this.getSeconds().toString():'0' + this.getSeconds()); 
str=str.replace(/s|S/g,this.getSeconds()); 
return str; 
} 
/** 
* 比较日期差(原型扩展或重载) 
* @param {strInterval} 日期类型:'y、m、d、h、n、s、w' 
* @param {dtEnd} 格式为日期型或者 有效日期格式字符串 
* @type int 
* @returns 比较结果 
*/ 
Date.prototype.dateDiff = function(strInterval, dtEnd) { 
var dtStart = this; 
if (typeof dtEnd == 'string' ) { //如果是字符串转换为日期型 
dtEnd = StringToDate(dtEnd); 
} 
switch (strInterval) { 
case 's' :return parseInt((dtEnd - dtStart) / 1000); 
case 'n' :return parseInt((dtEnd - dtStart) / 60000); 
case 'h' :return parseInt((dtEnd - dtStart) / 3600000); 
case 'd' :return parseInt((dtEnd - dtStart) / 86400000); 
case 'w' :return parseInt((dtEnd - dtStart) / (86400000 * 7)); 
case 'm' :return (dtEnd.getMonth()+1)+((dtEnd.getFullYear()-dtStart.getFullYear())*12) - (dtStart.getMonth()+1); 
case 'y' :return dtEnd.getFullYear() - dtStart.getFullYear(); 
} 
} 
/** 
* 日期计算(原型扩展或重载) 
* @param {strInterval} 日期类型:'y、m、d、h、n、s、w' 
* @param {Number} 数量 
* @type Date 
* @returns 计算后的日期 
*/ 
Date.prototype.dateAdd = function(strInterval, Number) { 
var dtTmp = this; 
switch (strInterval) { 
case 's' :return new Date(Date.parse(dtTmp) + (1000 * Number)); 
case 'n' :return new Date(Date.parse(dtTmp) + (60000 * Number)); 
case 'h' :return new Date(Date.parse(dtTmp) + (3600000 * Number)); 
case 'd' :return new Date(Date.parse(dtTmp) + (86400000 * Number)); 
case 'w' :return new Date(Date.parse(dtTmp) + ((86400000 * 7) * Number)); 
case 'q' :return new Date(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number*3, dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds()); 
case 'm' :return new Date(dtTmp.getFullYear(), (dtTmp.getMonth()) + Number, dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds()); 
case 'y' :return new Date((dtTmp.getFullYear() + Number), dtTmp.getMonth(), dtTmp.getDate(), dtTmp.getHours(), dtTmp.getMinutes(), dtTmp.getSeconds()); 
} 
} 
/** 
* 取得日期数据信息(原型扩展或重载) 
* @param {interval} 日期类型:'y、m、d、h、n、s、w' 
* @type int 
* @returns 指定的日期部分 
*/ 
Date.prototype.datePart = function(interval){ 
var myDate = this; 
var partStr=''; 
var Week = ['日','一','二','三','四','五','六']; 
switch (interval) 
{ 
case 'y' :partStr = myDate.getFullYear();break; 
case 'm' :partStr = myDate.getMonth()+1;break; 
case 'd' :partStr = myDate.getDate();break; 
case 'w' :partStr = Week[myDate.getDay()];break; 
case 'ww' :partStr = myDate.WeekNumOfYear();break; 
case 'h' :partStr = myDate.getHours();break; 
case 'n' :partStr = myDate.getMinutes();break; 
case 's' :partStr = myDate.getSeconds();break; 
} 
return partStr; 
} 
/** 
* 把日期分割成数组(原型扩展或重载) 
* @type array 
* @returns 日期数组 
*/ 
Date.prototype.toArray = function() { 
var myDate = this; 
var myArray = Array(); 
myArray[0] = myDate.getFullYear(); 
myArray[1] = myDate.getMonth()+1; 
myArray[2] = myDate.getDate(); 
myArray[3] = myDate.getHours(); 
myArray[4] = myDate.getMinutes(); 
myArray[5] = myDate.getSeconds(); 
return myArray; 
} 
/** 
* 取得当前月份的天数(原型扩展或重载) 
* @type int 
* @returns 天数 
*/ 
Date.prototype.daysOfMonth = function(){ 
var myDate = this; 
var ary = myDate.toArray(); 
var date1 = (new Date(ary[0],ary[1]+1,1)); 
var date2 = date1.dateAdd('m',1); 
var result = daysDiff(date1.format('yyyy-MM-dd'),date2.format('yyyy-MM-dd')); 
return result; 
} 
/** 
* 判断闰年(原型扩展或重载) 
* @type boolean 
* @returns 是否为闰年 true/false 
*/ 
Date.prototype.isLeapYear = function() { 
return (0==this.getYear()%4&&((this.getYear()%100!=0)||(this.getYear()%400==0))); 
} 
/** 
* 比较两个日期的天数差(自定义) 
* @param {DateOne} 日期一 
* @param {DateOne} 日期二 
* @type int 
* @returns 比较结果 
*/ 
function daysDiff(DateOne,DateTwo) 
{ 
var OneMonth = DateOne.substring(5,DateOne.lastIndexOf ('-')); 
var OneDay = DateOne.substring(DateOne.length,DateOne.lastIndexOf ('-')+1); 
var OneYear = DateOne.substring(0,DateOne.indexOf ('-')); 
var TwoMonth = DateTwo.substring(5,DateTwo.lastIndexOf ('-')); 
var TwoDay = DateTwo.substring(DateTwo.length,DateTwo.lastIndexOf ('-')+1); 
var TwoYear = DateTwo.substring(0,DateTwo.indexOf ('-')); 
var cha=((Date.parse(OneMonth+'/'+OneDay+'/'+OneYear)- Date.parse(TwoMonth+'/'+TwoDay+'/'+TwoYear))/86400000); 
return Math.abs(cha); 
} 
/** 
* 日期计算(自定义) 
* @param {strInterval} 日期类型:'y、m、d、h、n、s、w' 
* @param {Number} 数量 
* @param {prmDate} 原日期 
* @type Date 
* @returns 计算后的日期 
*/ 
function dateAdd(interval,number,prmDate){ 
number = parseInt(number); 
if (typeof(prmDate)=="string"){ 
prmDate = prmDate.split(/\D/); 
--prmDate[1]; 
eval("var prmDate = new Date("+prmDate.join(",")+")"); 
} 
if (typeof(prmDate)=="object"){ 
var prmDate = prmDate 
} 
switch(interval){ 
case "y": prmDate.setFullYear(prmDate.getFullYear()+number); break; 
case "m": prmDate.setMonth(prmDate.getMonth()+number); break; 
case "d": prmDate.setDate(prmDate.getDate()+number); break; 
case "w": prmDate.setDate(prmDate.getDate()+7*number); break; 
case "h": prmDate.setHours(prmDate.getHour()+number); break; 
case "n": prmDate.setMinutes(prmDate.getMinutes()+number); break; 
case "s": prmDate.setSeconds(prmDate.getSeconds()+number); break; 
case "l": prmDate.setMilliseconds(prmDate.getMilliseconds()+number); break; 
} 
return prmDate; 
} 
/** 
* 获取字符串长度(原型扩展或重载) 
* @type int 
* @returns 字符串长度 
*/ 
String.prototype.len = function() { 
var arr=this.match(/[^\x00-\xff]/ig); 
return this.length+(arr==null?0:arr.length); 
} 
/** 
* 字符串左取指定个数的字符(原型扩展或重载) 
* @param {num} 获取个数 
* @type string 
* @returns 匹配的字符串 
*/ 
String.prototype.left = function(num,mode) { 
if(!/\d+/.test(num)) return(this); 
var str = this.substr(0,num); 
if(!mode) return str; 
var n = str.len() - str.length; 
num = num - parseInt(n/2); 
return this.substr(0,num); 
} 
/** 
* 字符串右取指定个数的字符(原型扩展或重载) 
* @param {num} 获取个数 
* @type string 
* @returns 匹配的字符串 
*/ 
String.prototype.right = function(num,mode) { 
if(!/\d+/.test(num)) return(this); 
var str = this.substr(this.length-num); 
if(!mode) return str; 
var n = str.len() - str.length; 
num = num - parseInt(n/2); 
return this.substr(this.length-num); 
} 
/** 
* 字符串包含(原型扩展或重载) 
* @param {string: str} 要搜索的子字符串 
* @param {bool: mode} 是否忽略大小写 
* @type int 
* @returns 匹配的个数 
*/ 
String.prototype.matchCount = function(str,mode) { 
return eval("this.match(/("+str+")/g"+(mode?"i":"")+").length"); 
} 
/** 
* 去除左右空格(原型扩展或重载) 
* @type string 
* @returns 处理后的字符串 
*/ 
String.prototype.trim = function() { 
return this.replace(/(^\s*)|(\s*$)/g,""); 
} 
/** 
* 去除左空格(原型扩展或重载) 
* @type string 
* @returns 处理后的字符串 
*/ 
String.prototype.lTrim = function() { 
return this.replace(/(^\s*)/g, ""); 
} 
/** 
* 去除右空格(原型扩展或重载) 
* @type string 
* @returns 处理后的字符串 
*/ 
String.prototype.rTrim = function() { 
return this.replace(/(\s*$)/g, ""); 
} 
/** 
* 字符串转换为日期型(原型扩展或重载) 
* @type Date 
* @returns 日期 
*/ 
String.prototype.toDate = function() { 
var converted = Date.parse(this); 
var myDate = new Date(converted); 
if (isNaN(myDate)) {var arys= this.split('-'); myDate = new Date(arys[0],--arys[1],arys[2]); } 
return myDate; 
}
Javascript 相关文章推荐
js实现翻页后保持checkbox选中状态的实现方法
Nov 03 Javascript
jquery 页面滚动到底部自动加载插件集合
Jan 31 Javascript
jQuery之ajax删除详解
Feb 27 Javascript
JavaScript strike方法入门实例(给字符串加上删除线)
Oct 17 Javascript
js实现右下角提示框的方法
Feb 03 Javascript
用JavaScript实现让浏览器停止载入页面的方法
Jan 19 Javascript
浅谈angular2的http请求返回结果的subcribe注意事项
Mar 01 Javascript
通过命令行创建vue项目的方法
Jul 20 Javascript
vue引入axios同源跨域问题
Sep 27 Javascript
Element-ui中元素滚动时el-option超出元素区域的问题
May 30 Javascript
详解vuex的简单todolist例子
Jul 14 Javascript
vue页面更新patch的实现示例
Mar 25 Javascript
关于UTF-8的客户端用AJAX方式获取GB2312的服务器端乱码问题的解决办法
Nov 30 #Javascript
学习面向对象之面向对象的术语
Nov 30 #Javascript
学习面向对象之面向对象的基本概念:对象和其他基本要素
Nov 30 #Javascript
基于JQuery的asp.net树实现代码
Nov 30 #Javascript
JQUERY设置IFRAME的SRC值的代码
Nov 30 #Javascript
juqery 学习之四 筛选过滤
Nov 30 #Javascript
juqery 学习之四 筛选查找
Nov 30 #Javascript
You might like
php cookis创建实现代码
2009/03/16 PHP
php fsockopen中多线程问题的解决办法[翻译]
2011/11/09 PHP
PHP 杂谈《重构-改善既有代码的设计》之三 重新组织数据
2012/04/09 PHP
PHP提示Warning:phpinfo() has been disabled函数禁用的解决方法
2014/12/17 PHP
php开发微信支付获取用户地址
2015/10/04 PHP
简单了解将WordPress中的工具栏移到底部的小技巧
2015/12/31 PHP
PHP程序员学习使用Swoole的理由
2018/06/24 PHP
PHP基于swoole多进程操作示例
2019/08/12 PHP
laravel 获取某个查询的查询SQL语句方法
2019/10/12 PHP
ExtJs使用总结(非常详细)
2012/03/22 Javascript
JQuery DataTable删除行后的页面更新利用Ajax解决
2013/05/17 Javascript
JS实现的3D拖拽翻页效果代码
2015/10/31 Javascript
js实现div在页面拖动效果
2016/05/04 Javascript
需要牢记的JavaScript基础知识
2016/09/25 Javascript
微信小程序 选项卡的简单实例
2017/05/24 Javascript
Node批量爬取头条视频并保存方法
2018/09/20 Javascript
Vue.js中对css的操作(修改)具体方式详解
2018/10/30 Javascript
浅谈Vue.js 中的 v-on 事件指令的使用
2018/11/25 Javascript
详解Vue用cmd创建项目
2019/02/12 Javascript
微信小程序云开发 搭建一个管理小程序
2019/05/17 Javascript
[47:10]完美世界DOTA2联赛PWL S3 LBZS vs Rebirth 第二场 12.16
2020/12/18 DOTA
深入浅析python with语句简介
2018/04/11 Python
Django+python服务器部署与环境部署教程详解
2020/03/30 Python
利用CSS的Sass预处理器(框架)来制作居中效果
2016/03/10 HTML / CSS
详解如何在css中引入自定义字体(font-face)
2018/05/17 HTML / CSS
伦敦一家非常流行的时尚精品店:Oxygen Boutique
2017/01/15 全球购物
国际知名军事风格休闲装品牌:Alpha Industries(阿尔法工业)
2017/05/24 全球购物
微软新西兰官方网站:Microsoft New Zealand
2018/08/17 全球购物
Bally巴利中国官网:经典瑞士鞋履、手袋及配饰奢侈品牌
2018/10/09 全球购物
香港通票:Hong Kong Pass
2019/02/26 全球购物
英国时尚首饰品牌:Missoma
2020/06/29 全球购物
乡村教师党员四风问题对照检查材料思想汇报
2014/10/08 职场文书
文员岗位职责范本
2015/04/16 职场文书
横空出世观后感
2015/06/09 职场文书
法制教育主题班会
2015/08/13 职场文书
多线程Spring通过@Scheduled实现定时任务
2022/05/25 Java/Android