JS通用方法扩展
- /*
- * 系统中JS的扩展函数
- *
- *
- */
- // 清除两边的空格
- String.prototype.trim = function() {
- returnthis.replace(/(^\s*)|(\s*$)/g, '');
- };
- // 合并多个空白为一个空白
- String.prototype.ResetBlank = function() {
- var regEx = /\s+/g;
- returnthis.replace(regEx, ' ');
- };
- // 保留数字
- String.prototype.GetNum = function() {
- var regEx = /[^\d]/g;
- returnthis.replace(regEx, '');
- };
- // 保留中文
- String.prototype.GetCN = function() {
- var regEx = /[^\u4e00-\u9fa5\uf900-\ufa2d]/g;
- returnthis.replace(regEx, '');
- };
- // String转化为Number
- String.prototype.ToInt = function() {
- return isNaN(parseInt(this)) ? this.toString() : parseInt(this);
- };
- // 得到字节长度
- String.prototype.GetLen = function() {
- var regEx = /^[\u4e00-\u9fa5\uf900-\ufa2d]+$/;
- if (regEx.test(this)) {
- returnthis.length * 2;
- } else {
- var oMatches = this.match(/[\x00-\xff]/g);
- var oLength = this.length * 2 - oMatches.length;
- return oLength;
- }
- };
- // 获取文件全名
- String.prototype.GetFileName = function() {
- var regEx = /^.*\/([^\/\?]*).*$/;
- returnthis.replace(regEx, '$1');
- };
- // 获取文件扩展名
- String.prototype.GetExtensionName = function() {
- var regEx = /^.*\/[^\/]*(\.[^\.\?]*).*$/;
- returnthis.replace(regEx, '$1');
- };
- /******add By 刘景宁 2010-12-09 *******/
- String.prototype.replaceAll = function(reallyDo, replaceWith, ignoreCase) {
- if (!RegExp.prototype.isPrototypeOf(reallyDo)) {
- returnthis.replace(new RegExp(reallyDo, (ignoreCase ? "gi" : "g")), replaceWith);
- } else {
- returnthis.replace(reallyDo, replaceWith);
- }
- };
- //格式化字符串 add By 刘景宁 2010-12-09
- String.Format = function() {
- if (arguments.length == 0) {
- return'';
- }
- if (arguments.length == 1) {
- return arguments[0];
- }
- var reg = /{(\d+)?}/g;
- var args = arguments;
- var result = arguments[0].replace(reg, function($0, $1) {
- return args[parseInt($1) + 1];
- });
- return result;
- };
- // 数字补零
- Number.prototype.LenWithZero = function(oCount) {
- var strText = this.toString();
- while (strText.length < oCount) {
- strText = '0' + strText;
- }
- return strText;
- };
- // Unicode还原
- Number.prototype.ChrW = function() {
- return String.fromCharCode(this);
- };
- // 数字数组由小到大排序
- Array.prototype.Min2Max = function() {
- var oValue;
- for (var i = 0; i < this.length; i++) {
- for (var j = 0; j <= i; j++) {
- if (this[i] < this[j]) {
- oValue = this[i];
- this[i] = this[j];
- this[j] = oValue;
- }
- }
- }
- returnthis;
- };
- // 数字数组由大到小排序
- Array.prototype.Max2Min = function() {
- var oValue;
- for (var i = 0; i < this.length; i++) {
- for (var j = 0; j <= i; j++) {
- if (this[i] > this[j]) {
- oValue = this[i];
- this[i] = this[j];
- this[j] = oValue;
- }
- }
- }
- returnthis;
- };
- // 获得数字数组中最大项
- Array.prototype.GetMax = function() {
- var oValue = 0;
- for (var i = 0; i < this.length; i++) {
- if (this[i] > oValue) {
- oValue = this[i];
- }
- }
- return oValue;
- };
- // 获得数字数组中最小项
- Array.prototype.GetMin = function() {
- var oValue = 0;
- for (var i = 0; i < this.length; i++) {
- if (this[i] < oValue) {
- oValue = this[i];
- }
- }
- return oValue;
- };
- // 获取当前时间的中文形式
- Date.prototype.GetCNDate = function() {
- var oDateText = '';
- oDateText += this.getFullYear().LenWithZero(4) + new Number(24180).ChrW();
- oDateText += this.getMonth().LenWithZero(2) + new Number(26376).ChrW();
- oDateText += this.getDate().LenWithZero(2) + new Number(26085).ChrW();
- oDateText += this.getHours().LenWithZero(2) + new Number(26102).ChrW();
- oDateText += this.getMinutes().LenWithZero(2) + new Number(20998).ChrW();
- oDateText += this.getSeconds().LenWithZero(2) + new Number(31186).ChrW();
- oDateText += new Number(32).ChrW() + new Number(32).ChrW() + new Number(26143).ChrW() + new Number(26399).ChrW() + new String('26085199682010819977222352011620845').substr(this.getDay() * 5, 5).ToInt().ChrW();
- return oDateText;
- };
- //扩展Date格式化
- Date.prototype.Format = function(format) {
- var o = {
- "M+": this.getMonth() + 1, //月份
- "d+": this.getDate(), //日
- "h+": this.getHours() % 12 == 0 ? 12 : this.getHours() % 12, //小时
- "H+": this.getHours(), //小时
- "m+": this.getMinutes(), //分
- "s+": this.getSeconds(), //秒
- "q+": Math.floor((this.getMonth() + 3) / 3), //季度
- "S": this.getMilliseconds() //毫秒
- };
- var week = {
- "0": "\u65e5",
- "1": "\u4e00",
- "2": "\u4e8c",
- "3": "\u4e09",
- "4": "\u56db",
- "5": "\u4e94",
- "6": "\u516d"
- };
- if (/(y+)/.test(format)) {
- format = format.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
- }
- if (/(E+)/.test(format)) {
- format = format.replace(RegExp.$1, ((RegExp.$1.length > 1) ? (RegExp.$1.length > 2 ? "\u661f\u671f" : "\u5468") : "") + week[this.getDay() + ""]);
- }
- 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;
- }
- Date.prototype.Diff = function(interval, objDate) {
- //若参数不足或 objDate 不是日期类型則回传 undefined
- if (arguments.length < 2 || objDate.constructor != Date) { return undefined; }
- switch (interval) {
- //计算秒差
- case's': return parseInt((objDate - this) / 1000);
- //计算分差
- case'n': return parseInt((objDate - this) / 60000);
- //计算時差
- case'h': return parseInt((objDate - this) / 3600000);
- //计算日差
- case'd': return parseInt((objDate - this) / 86400000);
- //计算周差
- case'w': return parseInt((objDate - this) / (86400000 * 7));
- //计算月差
- case'm': return (objDate.getMonth() + 1) + ((objDate.getFullYear() - this.getFullYear()) * 12) - (this.getMonth() + 1);
- //计算年差
- case'y': return objDate.getFullYear() - this.getFullYear();
- //输入有误
- default: return undefined;
- }
- };
- //检测是否为空
- Object.prototype.IsNullOrEmpty = function() {
- var obj = this;
- var flag = false;
- if (obj == null || obj == undefined || typeof (obj) == 'undefined' || obj == '') {
- flag = true;
- } elseif (typeof (obj) == 'string') {
- obj = obj.trim();
- if (obj == '') {//为空
- flag = true;
- } else {//不为空
- obj = obj.toUpperCase();
- if (obj == 'NULL' || obj == 'UNDEFINED' || obj == '{}') {
- flag = true;
- }
- }
- }
- else {
- flag = false;
- }
- return flag;
- };
JS通用方法扩展的更多相关文章
- js数组方法扩展
/** * Created by Administrator on 2016/9/1. */ //数组去重 Array.prototype.unique = function(){ this.sort ...
- JS通用方法总结(一)
/** * id数组转换为json字符串 */ function arrayTojson(arr) { var jsonIds = "["; for ( var i = 0; i ...
- js通用方法检測浏览器是否已安装指定插件(IE与非IE通用)
/* * 检測是否已安装指定插件 * * pluginName 插件名称 */ function checkPlugins(pluginName) { var np = navigator.plugi ...
- 扩展JQuery和JS的方法
//JS的扩展方法: 1 定义类静态方法扩展 2 定义类对象方法扩展 var aClass = function(){} //1 定义这个类的静态方法 aC ...
- JS,JQuery的扩展方法
转 http://blog.csdn.net/tuwen/article/details/11464693 //JS的扩展方法: 1 定义类静态方法扩展 2 定义类对象方法扩展 ...
- 原生js事件委托(事件代理)方法扩展
原生js事件委托(事件代理)方法扩展: 通过Node底层原型扩展委托方法 /** * 事件委托方法 * @param eventName {string}:事件名称,如'click' * @param ...
- js添加事件通用方法
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- 使用 highchart 绘制柱状图的通用方法与接口
本文给出使用 highchart 绘制柱状图的通用方法与接口, 只要指定相应的数据结构和配置, 就可以直接拿来使用. 一. 数据结构与基本接口 一般绘制图形, 会涉及到较复杂的数据结构, 比如使 ...
- String对象方法扩展
/** *字符串-格式化 */ String.prototype.format = function(){ var args = arguments;//获取函数传递参数数组,以便在replace回调 ...
随机推荐
- 基于lua的网页脚本开发语言cgilua(转)
这里为大家介绍基于lua脚本实现的网页开发语言,cgilua 介绍 cgilua使用Lua是一个用于创建动态网页的服务器端脚本语言.纯LUA脚本和LUA页(LP)的支持,cgilua.Lua脚本是一个 ...
- redmine使用汇总redmine软件工程过程
1.强制性当一个新的问题:轨道.议题.叙述性说明.状态.优先.分配给.父任务(假设没有可以不填,假设有请务必填写).开始日期.预计时间.党羽,请注意,这时候一定不要填写完成时间 2.如果你想在实时登记 ...
- OTN&互换amp; P-OTN有效降低100G 网络成本 (两)
OTN互换& P-OTN有效降低100G 网络成本 (两) 在全球范围内.网流量的增长速度是空前的,导致此现象的缘由包含云服务的增长.移动宽带和基于互联网的视频点播服务的增长. Cisco估计 ...
- OCP解决问题052-- DROP PROFILE app_user
133.You created a profile APP_USER and assigned it to the users. After a month, you decide to drop t ...
- NYOJ 300 && hdu 2276 Kiki & Little Kiki 2 (矩阵高速功率)
pid=300">Kiki & Little Kiki 2 时间限制:5000 ms | 内存限制:65535 KB 难度:4 描写叙述 There are n light ...
- hdu 1150 Machine Schedule(最小顶点覆盖)
pid=1150">Machine Schedule Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/327 ...
- 大哥可以写KMP该——达到strstr()
在最后采访,面试官要求实现strstr(),当场就蒙了. 这个题目是模式匹配问题.<算法导论>里列出了几种字符串匹配算法: 朴素算法 | Rabin-Karp | 有限自己主动机算法 | ...
- Chapter 1 Securing Your Server and Network(4):使用虚拟服务帐号
原文:Chapter 1 Securing Your Server and Network(4):使用虚拟服务帐号 原文出处:http://blog.csdn.net/dba_huangzj/arti ...
- S性能 Sigmoid Function or Logistic Function
S性能 Sigmoid Function or Logistic Function octave码 x = -10:0.1:10; y = zeros(length(x), 1); for i = 1 ...
- 【Espruino】NO.03 从点灯开始
http://blog.csdn.net/qwert1213131/article/details/26819773 本文属于个人理解,能力有限,纰漏在所难免,还望指正! [小鱼有点电] 点灯程序应该 ...