- 浏览: 55738 次
- 性别:
- 来自: 苏州
文章分类
- 全部博客 (32)
- java (2)
- js (8)
- jquery (4)
- 随便说说 (4)
- Database, SQL (1)
- html (1)
- toolkit (2)
- python (2)
- django (2)
- helper (2)
- cookies (3)
- git (0)
- javascript基础 (1)
- hibernate (0)
- ibatis (0)
- 网上支付 (0)
- openstack (0)
- Mac (1)
- MySQL (1)
- linux (1)
- Postgresql (0)
- J2EE (0)
- 设计模式 (0)
- 面向对象 (0)
- hadoop (1)
- ubuntu (0)
- UML (0)
- Oracle (0)
- virtualbox (0)
- esb (0)
- mybatis (0)
- translate (0)
- struts2 api (1)
- jquery-ui (0)
- spring (0)
- jquery validation (0)
- web (0)
- spring mybatis (0)
- 单元测试 (0)
- eclipse (0)
- maven (0)
- java junit (0)
- editplus (0)
- jpa (0)
- jpa hibernate (1)
- sql (0)
- jpql (0)
- 杂 (0)
- shiro (0)
- filter (0)
- junit (1)
- tomcat (0)
- struts2 (1)
- spring-data jpa (0)
- ImageIO jpg (0)
- cms (0)
- php (0)
- node js (0)
- NodeJS (1)
- keystone (0)
- sublime (1)
- aws ec2 (0)
- pdf (0)
- design pattern (0)
- 条件查询(Criteria Queries) (0)
- jenkins (0)
- bootstrap (0)
- springside (0)
- apache (0)
最新评论
-
tokyo2006:
不错,经验之谈是最好的
收集记录一些在使用Python、Django中遇到的问题及解决方法 -
zhuchao_ko:
自己写的操作等待浮出层
扩展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, "&"); str = str.replace(/</g, "<"); str = str.replace(/>/g, ">"); str = str.replace(/\'/g, "'"); str = str.replace(/\"/g, """); str = str.replace(/\n/g, "<br>"); str = str.replace(/\ /g, " "); str = str.replace(/\t/g, " "); return str; }
* 附件是源码及演示demo
* 源码来源于网络,如有侵权,敬请告知。
- string.utils.rar (3.5 KB)
- 下载次数: 3
发表评论
-
jquery工具
2014-06-12 10:01 0单元测试 http://qunitjs.com/ -
基于jquery的回到顶部插件
2014-06-12 09:15 0/** * 回到顶部功能 */ (function ... -
jquery ui dialog 扩展
2014-06-03 16:04 0jquery ui dialog 扩展 -
jquery固定头部插件
2014-05-22 11:09 0jquery固定头部插件 https:// ... -
jquery cookie 插件
2014-05-18 13:54 0jquery.cookie 使用方法 http://www ... -
Javascript 更新地址url参数的方法
2014-05-17 18:02 1034javascript 更新地址url参数的方法: ... -
解决了jquery.bgiframe.min.js的一个bug (jquery.bgiframe.min.js, line 10 character 978)
2012-02-01 15:31 3627解决了jquery.bgiframe.min.js的一个bug ... -
收集记录一些使用Javascript,JQuery时遇到的问题
2011-12-28 11:04 1070收集记录一些使用Javascript,JQuery时遇到的问题 ... -
如何在不同的浏览器中打开控制台调试JS(转帖加自己的截图)
2011-11-26 14:15 10106今天遇到了一个JS问题,在safari下就是运行不出效果,因此 ... -
正则表达式验证器
2011-08-26 18:13 1111最近在学习正则表达式,为了提高学习的效率,写了一个很简陋的正则 ... -
修改地址栏参数的方法
2011-08-12 16:13 960做web前端开发,有时需要使用js修改地址栏参数。 今 ... -
自己写的操作等待浮出层
2011-06-14 19:59 1220自己写的操作等待浮出层 在实际项目中,用户的某些操作 ...
相关推荐
总结,JavaScript中的字符串是处理文本数据的基本工具。理解和掌握字符串的特性及操作方法,对于Web前端开发者来说至关重要。通过熟练运用这些知识点,开发者能够更高效地处理和展示网页上的文本信息。在实际项目中...
接下来,Jscript.cs可能涉及到JavaScript端的字符串处理,JavaScript在客户端处理字符串时有其独特的方式: 1. JavaScript的字符串拼接:在JavaScript中,"+"运算符可以用于字符串连接。 2. 字符串格式化:虽然...
对于压缩包子文件的文件名称列表“字符串工具类”,这可能是一份包含了各种字符串处理方法的源码文件集合,可能包括自定义的工具类或对已有工具类的扩展。通过研究这些源码,我们可以学习到如何根据项目需求定制自己...
JavaScript是一种广泛使用的前端脚本语言,它为我们提供了丰富的API,能够操作DOM、处理事件、操作字符串等。在处理字符串时,判断一个...希望通过本文的介绍和示例,能够帮助到进行JavaScript字符串操作的开发者们。
本文将详细介绍一个专门用于处理中文字符串截取的JavaScript函数,该函数能够根据字符的实际编码长度来精确控制截取的长度。 #### 二、关键概念解析 ##### 2.1 字符串截取 字符串截取是指从一个较长的字符串中...
### JavaScript字符串函数大全 在JavaScript中,字符串是用于处理文本数据的基本类型之一。字符串方法提供了丰富的功能来操作这些文本数据,使得开发人员能够更高效地完成各种任务。下面将详细介绍标题与描述中提及...
这里我们探讨8个高效的JavaScript字符串处理技术,它们能够帮助你编写更简洁、更易维护的代码。 1. **字符串填充**: - `padStart()` 和 `padEnd()` 方法用于在字符串的开始或结束处填充指定的字符,直到达到特定...
通过以上介绍,我们可以看到,在JavaScript中处理字符串是非常灵活且强大的。利用正则表达式结合内置方法,我们可以轻松地解决诸如去除字符串中多余空格之类的问题。这对于提高代码的健壮性和用户体验都有很大的帮助...
在编程中,我们经常需要将字符串和ASCII值之间进行转换,以处理或传输数据。以下是对这个主题的详细讲解: 1. 字符串转ASCII 当我们需要将一个字符串转换为ASCII值时,实际上我们是在为每个字符获取其对应的ASCII...
在JavaScript中,处理字符串是一个常见的任务,特别是在开发前台应用程序时。用户输入的内容往往包含不必要的空格,这些空格可能出现在字符串的开始、结束或两者都有。为了确保数据的准确性和整洁性,经常需要编写...
而“pys”则提供了类似Python的`[start:end:step]`的语法,使开发者能够以更Pythonic的方式处理JavaScript字符串。 1. **Python字符串分片的理解** - **起始索引(start)**:指定分片开始的位置,包含该位置的...
真实项目中的JS文件,JS字符串和数组常用扩展。
通过这些扩展,你可以成功地在CJSON库中处理Unicode的JSON字符串,从而满足跨语言通信的需求。 总之,解析Unicode的JSON字符串的CJSON扩展是解决多语言环境下数据交换的重要步骤。通过对CJSON的源码进行修改和扩展...
在JavaScript的ES6(ECMAScript 2015)版本中,引入了许多对字符串操作的新特性,使得字符串处理更加灵活和高效。以下是一些主要的字符串扩展方法: 1. `indexOf()`: 这个方法用于检查字符串中是否包含指定的子字符...
5. **扩展性**:如果标准库中没有提供你需要的特定字符串处理功能,`stringish`库的结构允许你方便地添加自定义方法,以满足特定项目的需求。 6. **示例代码**: ```go package main import ( "github....
这些方法可以广泛应用于 JavaScript 开发中,对于字符串的处理和操作非常有帮助。 知识点: * JavaScript 中不存在 trim() 方法来去除字符串左右的空格,需要自定义 trim() 方法。 * 使用 String.prototype 来扩展...
### JavaScript常用字符串与数组扩展函数小结 #### 引言 在现代Web开发中,JavaScript是一种必不可少的语言。作为一门功能强大的脚本语言,它提供了大量的内置对象和方法来处理各种数据类型,其中最常用的就是字符...