`

扩展Javascript字符串处理

    博客分类:
  • js
阅读更多

扩展Javascript字符串处理

 

做web前端开发,有时会发现原生js对字符串的处理方法很少(竟然不提供“替换所有”这类的方法),用起来不是很方便。

 

今天在网上找到了一些js 字符串处理的代码,记录下来,已备以后使用。

 

代码提供的方法有:

 

1.替换所有replaceAll()
2.反转:reverse()
3.移除左侧空格:ltrim()
4.移除右侧空格:rtrim()
5.移除前后空格:trim()
6.得到左起(10个)字符:lsubstr()
7.得到右起(10个)子符:rsubstr()
8.在字符串里查找另一字符串:位置从0开始(查找“i”):inStr()
9.在字符串里反向查找另一字符串:位置0开始(查找“i”):inStrRev()
10.计算字符串打印长度:lengthW()


11.是否是正确的IP地址(IPV4):isIPV4()
12.是否是正确的长日期:isLongDate()
13.是否是正确的短日期:isShortDate()
14.是否是正确的日期:isDate()
15.是否是手机(中国):isMobile()
16.是否是Email:isEmail()
17.是否是邮编(中国):isZipCode()
18.是否是有汉字:existChinese()
19.是否是合法的文件名/目录名:isFileName()
20.是否是有效链接:isUrl()
21.是否是有效的身份证 (中国):isIDCard()
22.是否是有效的电话号码(中国):isPhoneCall()

23.

是否是数字:isNumeric()
是否是正数:isNumeric('+')
是否是负数:isNumeric('-')
是否是整数:isNumeric('i')
是否是正整数:isNumeric('+i')
是否是负整数:isNumeric('-i')
是否是浮点数:isNumeric('f')
是否是正浮点数:isNumeric('+f')
是否是负浮点数:isNumeric('-f')

24.是否是颜色(#FFFFFF形式):isColor()
25.转换成全角:toCase()
26.对字符串进行Html编码:toHtmlEncode()

 

以下是源码

/*
 * *****************************************
 * 字符串函数扩充
 * *****************************************
 */

/*
 * ===========================================
 * 替换所有
 * ===========================================
 */
String.prototype.replaceAll = function(s1,s2) {
	return this.replace(new RegExp(s1,"gm"),s2);
}

/*
 * ===========================================
 * 字符串反转
 * ===========================================
 */
String.prototype.reverse = function() {
	var retStr = "";
	if (this&&this.length>0) {
		for (var i = this.length - 1; i >= 0; i--) {
			retStr += this.charAt(i);
		}
	}
	return retStr;
}

/*
 * ===========================================
 * 去除左边的空格
 * ===========================================
 */
String.prototype.ltrim = function() {
	return this.replace(/(^\s*)/g, "");
}

/*
 * ===========================================
 * 去除右边的空格
 * ===========================================
 */
String.prototype.rtrim = function() {
	return this.replace(/(\s*$)/g, "");
}

/*
 * ===========================================
 * 去除前后空格
 * ===========================================
 */
String.prototype.trim = function() {
	return this.replace(/(^\s*)|(\s*$)/g, "");
}

/*
 * ===========================================
 * 得到左边的字符串
 * ===========================================
 */
String.prototype.lsubstr = function(len) {
	if (isNaN(len) || len == null) {
		len = this.length;
	} else {
		if (parseInt(len) < 0 || parseInt(len) > this.length) {
			len = this.length;
		}
	}
	return this.substr(0, len);
}

/*
 * ===========================================
 * 得到右边的字符串
 * ===========================================
 */
String.prototype.rsubstr = function(len) {

	if (isNaN(len) || len == null) {
		len = this.length;
	} else {
		if (parseInt(len) < 0 || parseInt(len) > this.length) {
			len = this.length;
		}
	}
	return this.substring(this.length - len, this.length);
}

/*
 * ===========================================
 * 在字符串里查找另一字符串:位置从0开始
 * ===========================================
 */
String.prototype.inStr = function(str) {

	if (str == null) {
		str = "";
	}

	return this.indexOf(str);
}

/*
 * ===========================================
 * 在字符串里反向查找另一字符串:位置0开始
 * ===========================================
 */
String.prototype.inStrRev = function(str) {

	if (str == null) {
		str = "";
	}

	return this.lastIndexOf(str);
}

/*
 * ===========================================
 * 计算字符串打印长度
 * ===========================================
 */
String.prototype.lengthW = function() {
	return this.replace(/[^\x00-\xff]/g, "**").length;
}

/*
 * ===========================================
 * 是否是正确的IP地址(IPV4)
 * ===========================================
 */
String.prototype.isIPV4 = function() {

	var reSpaceCheck = /^(\d+)\.(\d+)\.(\d+)\.(\d+)$/;

	if (reSpaceCheck.test(this)) {
		this.match(reSpaceCheck);
		if (RegExp.$1 <= 255 && RegExp.$1 >= 0 && RegExp.$2 <= 255
				&& RegExp.$2 >= 0 && RegExp.$3 <= 255 && RegExp.$3 >= 0
				&& RegExp.$4 <= 255 && RegExp.$4 >= 0) {
			return true;
		} else {
			return false;
		}
	} else {
		return false;
	}

}

/*
 * ===========================================
 * 是否是正确的长日期
 * ===========================================
 */
String.prototype.isLongDate = function() {
	var r = this
			.replace(/(^\s*)|(\s*$)/g, "")
			.match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/);
	if (r == null) {
		return false;
	}
	var d = new Date(r[1], r[3] - 1, r[4], r[5], r[6], r[7]);
	return (d.getFullYear() == r[1] && (d.getMonth() + 1) == r[3]
			&& d.getDate() == r[4] && d.getHours() == r[5]
			&& d.getMinutes() == r[6] && d.getSeconds() == r[7]);

}

/*
 * ===========================================
 * 是否是正确的短日期
 * ===========================================
 */
String.prototype.isShortDate = function() {
	var r = this.replace(/(^\s*)|(\s*$)/g, "")
			.match(/^(\d{1,4})(-|\/)(\d{1,2})\2(\d{1,2})$/);
	if (r == null) {
		return false;
	}
	var d = new Date(r[1], r[3] - 1, r[4]);
	return (d.getFullYear() == r[1] && (d.getMonth() + 1) == r[3] && d
			.getDate() == r[4]);
}

/*
 * ===========================================
 * 是否是正确的日期
 * ===========================================
 */
String.prototype.isDate = function() {
	return this.isLongDate() || this.isShortDate();
}

/*
 * ===========================================
 * 是否是手机(中国)
 * ===========================================
 */
String.prototype.isMobile = function() {
	return /^0{0,1}[13,15,18][0-9]{9}$/.test(this);
}

/*
 * ===========================================
 * 是否是Email
 * ===========================================
 */
String.prototype.isEmail = function() {
	return /^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/
			.test(this);
}

/*
 * ===========================================
 * 是否是邮编(中国)
 * ===========================================
 */

String.prototype.isZipCode = function() {
	return /^[\\d]{6}$/.test(this);
}

/*
 * ===========================================
 * 是否是有汉字
 * ===========================================
 */
String.prototype.existChinese = function() {
	// [\u4E00-\u9FA5]為漢字﹐[\uFE30-\uFFA0]為全角符號
	//return /^[\x00-\xff]*$/.test(this);
	return /^[\u4E00-\u9FA5]*$/.test(this);
}

/*
 * ===========================================
 * 是否是合法的文件名/目录名
 * ===========================================
 */
String.prototype.isFileName = function() {
	return !/[\\\/\*\?\|:"<>]/g.test(this);
}

/*
 * ===========================================
 * 是否是有效链接
 * ===========================================
 */
String.prototype.isUrl = function() {
	return /^http[s]?:\/\/([\w-]+\.)+[\w-]+([\w-./?%&=]*)?$/i.test(this);
}

/*
 * ===========================================
 * 是否是有效的身份证 (中国)
 * ===========================================
 */
String.prototype.isIDCard = function() {
	var iSum = 0;
	var info = "";
	var sId = this;

	var aCity = {
		11 : "北京",
		12 : "天津",
		13 : "河北",
		14 : "山西",
		15 : "内蒙古",
		21 : "辽宁",
		22 : "吉林",
		23 : "黑龙江",
		31 : "上海",
		32 : "江苏",
		33 : "浙江",
		34 : "安徽",
		35 : "福建",
		36 : "江西",
		37 : "山东",
		41 : "河南",
		42 : "湖北",
		43 : "湖南",
		44 : "广东",
		45 : "广西",
		46 : "海南",
		50 : "重庆",
		51 : "四川",
		52 : "贵州",
		53 : "云南",
		54 : "西藏",
		61 : "陕西",
		62 : "甘肃",
		63 : "青海",
		64 : "宁夏",
		65 : "新疆",
		71 : "台湾",
		81 : "香港",
		82 : "澳门",
		91 : "国外"
	};

	if (!/^\d{17}(\d|x)$/i.test(sId)) {
		return false;
	}
	sId = sId.replace(/x$/i, "a");
	// 非法地区
	if (aCity[parseInt(sId.substr(0, 2))] == null) {
		return false;
	}

	var sBirthday = sId.substr(6, 4) + "-" + Number(sId.substr(10, 2)) + "-"
			+ Number(sId.substr(12, 2));

	var d = new Date(sBirthday.replace(/-/g, "/"))

	// 非法生日
	if (sBirthday != (d.getFullYear() + "-" + (d.getMonth() + 1) + "-" + d
			.getDate())) {
		return false;
	}
	for (var i = 17; i >= 0; i--) {
		iSum += (Math.pow(2, i) % 11) * parseInt(sId.charAt(17 - i), 11);
	}

	if (iSum % 11 != 1) {
		return false;
	}
	return true;

}

/*
 * ===========================================
 * 是否是有效的电话号码(中国)
 * ===========================================
 */
String.prototype.isPhoneCall = function() {
	return /(^[0-9]{3,4}\-[0-9]{3,8}$)|(^[0-9]{3,8}$)|(^\([0-9]{3,4}\)[0-9]{3,8}$)|(^0{0,1}13[0-9]{9}$)/
			.test(this);
}

/*
 * ===========================================
 * 是否是数字
 * ===========================================
 */
String.prototype.isNumeric = function(flag) {
	// 验证是否是数字
	if (isNaN(this)) {

		return false;
	}

	switch (flag) {

		case null : // 数字
		case "" :
			return true;
		case "+" : // 正数
			return /(^\+?|^\d?)\d*\.?\d+$/.test(this);
		case "-" : // 负数
			return /^-\d*\.?\d+$/.test(this);
		case "i" : // 整数
			return /(^-?|^\+?|\d)\d+$/.test(this);
		case "+i" : // 正整数
			return /(^\d+$)|(^\+?\d+$)/.test(this);
		case "-i" : // 负整数
			return /^[-]\d+$/.test(this);
		case "f" : // 浮点数
			return /(^-?|^\+?|^\d?)\d*\.\d+$/.test(this);
		case "+f" : // 正浮点数
			return /(^\+?|^\d?)\d*\.\d+$/.test(this);
		case "-f" : // 负浮点数
			return /^[-]\d*\.\d$/.test(this);
		default : // 缺省
			return true;
	}
}

/*
 * ===========================================
 * 是否是颜色(#FFFFFF形式)
 * ===========================================
 */
String.prototype.isColor = function() {
	var temp = this;
	if (temp == "")
		return true;
	if (temp.length != 7)
		return false;
	return (temp.search(/\#[a-fA-F0-9]{6}/) != -1);
}

/*
 * ===========================================
 * 转换成全角
 * ===========================================
 */
String.prototype.toCase = function() {
	var tmp = "";
	for (var i = 0; i < this.length; i++) {
		if (this.charCodeAt(i) > 0 && this.charCodeAt(i) < 255) {
			tmp += String.fromCharCode(this.charCodeAt(i) + 65248);
		} else {
			tmp += String.fromCharCode(this.charCodeAt(i));
		}
	}
	return tmp
}

/*
 * ===========================================
 * 对字符串进行Html编码
 * ===========================================
 */
String.prototype.toHtmlEncode = function() {
	var str = this;

	str = str.replace(/&/g, "&amp;");
	str = str.replace(/</g, "&lt;");
	str = str.replace(/>/g, "&gt;");
	str = str.replace(/\'/g, "&apos;");
	str = str.replace(/\"/g, "&quot;");
	str = str.replace(/\n/g, "<br>");
	str = str.replace(/\ /g, "&nbsp;");
	str = str.replace(/\t/g, "&nbsp;&nbsp;&nbsp;&nbsp;");

	return str;
}

 

 

 

* 附件是源码及演示demo

 

* 源码来源于网络,如有侵权,敬请告知。

 


分享到:
评论

相关推荐

    头歌教学实践平台 Web前端开发基础 JavaScript学习手册九:字符串

    总结,JavaScript中的字符串是处理文本数据的基本工具。理解和掌握字符串的特性及操作方法,对于Web前端开发者来说至关重要。通过熟练运用这些知识点,开发者能够更高效地处理和展示网页上的文本信息。在实际项目中...

    常用字符串处理整理.rar

    接下来,Jscript.cs可能涉及到JavaScript端的字符串处理,JavaScript在客户端处理字符串时有其独特的方式: 1. JavaScript的字符串拼接:在JavaScript中,"+"运算符可以用于字符串连接。 2. 字符串格式化:虽然...

    工具类_字符串处理

    对于压缩包子文件的文件名称列表“字符串工具类”,这可能是一份包含了各种字符串处理方法的源码文件集合,可能包括自定义的工具类或对已有工具类的扩展。通过研究这些源码,我们可以学习到如何根据项目需求定制自己...

    JavaScript判断一个字符串是否包含指定子字符串的方法

    JavaScript是一种广泛使用的前端脚本语言,它为我们提供了丰富的API,能够操作DOM、处理事件、操作字符串等。在处理字符串时,判断一个...希望通过本文的介绍和示例,能够帮助到进行JavaScript字符串操作的开发者们。

    JavaScript截取中文字符串

    本文将详细介绍一个专门用于处理中文字符串截取的JavaScript函数,该函数能够根据字符的实际编码长度来精确控制截取的长度。 #### 二、关键概念解析 ##### 2.1 字符串截取 字符串截取是指从一个较长的字符串中...

    JavaScript字符串函数大全

    ### JavaScript字符串函数大全 在JavaScript中,字符串是用于处理文本数据的基本类型之一。字符串方法提供了丰富的功能来操作这些文本数据,使得开发人员能够更高效地完成各种任务。下面将详细介绍标题与描述中提及...

    8 个很棒的 JavaScript 字符串操作技术.docx

    这里我们探讨8个高效的JavaScript字符串处理技术,它们能够帮助你编写更简洁、更易维护的代码。 1. **字符串填充**: - `padStart()` 和 `padEnd()` 方法用于在字符串的开始或结束处填充指定的字符,直到达到特定...

    javascript将字符串中的多个空格替换为一个空格的正则实例.docx

    通过以上介绍,我们可以看到,在JavaScript中处理字符串是非常灵活且强大的。利用正则表达式结合内置方法,我们可以轻松地解决诸如去除字符串中多余空格之类的问题。这对于提高代码的健壮性和用户体验都有很大的帮助...

    字符串转ASCII ASCII转字符串

    在编程中,我们经常需要将字符串和ASCII值之间进行转换,以处理或传输数据。以下是对这个主题的详细讲解: 1. 字符串转ASCII 当我们需要将一个字符串转换为ASCII值时,实际上我们是在为每个字符获取其对应的ASCII...

    javascript中使用正则表达式实现删除字符串中的前后空格

    在JavaScript中,处理字符串是一个常见的任务,特别是在开发前台应用程序时。用户输入的内容往往包含不必要的空格,这些空格可能出现在字符串的开始、结束或两者都有。为了确保数据的准确性和整洁性,经常需要编写...

    pys模仿Python字符串分片操作的JavaScript模块

    而“pys”则提供了类似Python的`[start:end:step]`的语法,使开发者能够以更Pythonic的方式处理JavaScript字符串。 1. **Python字符串分片的理解** - **起始索引(start)**:指定分片开始的位置,包含该位置的...

    JS字符串和数组常用扩展

    真实项目中的JS文件,JS字符串和数组常用扩展。

    解析unicode的json字符串的cJSON,支持宽字符串

    通过这些扩展,你可以成功地在CJSON库中处理Unicode的JSON字符串,从而满足跨语言通信的需求。 总之,解析Unicode的JSON字符串的CJSON扩展是解决多语言环境下数据交换的重要步骤。通过对CJSON的源码进行修改和扩展...

    JavaScript程序设计-ES之字符串扩展方法.pdf

    在JavaScript的ES6(ECMAScript 2015)版本中,引入了许多对字符串操作的新特性,使得字符串处理更加灵活和高效。以下是一些主要的字符串扩展方法: 1. `indexOf()`: 这个方法用于检查字符串中是否包含指定的子字符...

    Go-stringish一组可链式字符串助手可减少操纵字符串的痛苦

    5. **扩展性**:如果标准库中没有提供你需要的特定字符串处理功能,`stringish`库的结构允许你方便地添加自定义方法,以满足特定项目的需求。 6. **示例代码**: ```go package main import ( "github....

    js 自定义trim去除字符串左右杂质

    这些方法可以广泛应用于 JavaScript 开发中,对于字符串的处理和操作非常有帮助。 知识点: * JavaScript 中不存在 trim() 方法来去除字符串左右的空格,需要自定义 trim() 方法。 * 使用 String.prototype 来扩展...

    JavaScript常用字符串与数组扩展函数小结_.docx

    ### JavaScript常用字符串与数组扩展函数小结 #### 引言 在现代Web开发中,JavaScript是一种必不可少的语言。作为一门功能强大的脚本语言,它提供了大量的内置对象和方法来处理各种数据类型,其中最常用的就是字符...

Global site tag (gtag.js) - Google Analytics