javascript常用自定义字符串处理函数

简介:

下面是我在web开发中常用的字符串处理函数,一般用于输入校验

 

 
  1. /*  
  2.  
  3.  * 去除前后空白字符  
  4.  
  5.  * @author yifangyou  
  6.  
  7.  * @use " bv ".trim()  
  8.  
  9.  * @version gslb 2011-01-16  
  10.  
  11.  * */ 
  12.  
  13. String.prototype.trim = function()  
  14.  
  15. {  
  16.  
  17.     return this.replace(/(^\s*)|(\s*$)/g, "");  
  18.  
  19. }  
  20.  
  21.  
  22.  
  23.  
  24.  
  25.  
  26.  
  27. /*  
  28.  
  29.  * 判断是否以某字符串结尾  
  30.  
  31.  * @author yifangyou  
  32.  
  33.  * @use " bv a".endswith("a")  
  34.  
  35.  * @version gslb 2011-01-16  
  36.  
  37.  * */ 
  38.  
  39. String.prototype.endswith = function(findstr)  
  40.  
  41. {  
  42.  
  43.     if(this.length-findstr.length<0){  
  44.  
  45.             return false;      
  46.  
  47.     }  
  48.  
  49.   if(this.lastIndexOf(findstr)==this.length-findstr.length){  
  50.  
  51.         return true;  
  52.  
  53.     }  
  54.  
  55.     return false;  
  56.  
  57. }  
  58.  
  59.  
  60.  
  61.  
  62.  
  63. /*  
  64.  
  65.  * 只能输入英文数字.-下划线  
  66.  
  67.  * @param str input的value  
  68.  
  69.  * @use <input onkeyup="value=filterchar(value)" onafterpaste="value=filterchar(value)" />  
  70.  
  71.  * @author yifangyou  
  72.  
  73.  * @version gslb 2011-01-16  
  74.  
  75.  * */ 
  76.  
  77. function filterchar(str){  
  78.  
  79.     var p=/[^\w\-\.]/g  
  80.  
  81.     return str.replace(p,'');  
  82.  
  83. }  
  84.  
  85.  
  86.  
  87. /*  
  88.  
  89.  * 过滤特殊字符  
  90.  
  91.  * @param str input的value  
  92.  
  93.  * @use <input onkeyup="value=filterschar(value)" onafterpaste="value=filterschar(value)" />  
  94.  
  95.  * @author yifangyou  
  96.  
  97.  * @version gslb 2011-01-16  
  98.  
  99.  * */ 
  100.  
  101. function filterschar(str){  
  102.  
  103.         var p=/[\'\"#,;&%^\$!\+=\|\\\/ ]/g  
  104.  
  105.         return str.replace(p,'');  
  106.  
  107. }  
  108.  
  109.  
  110.  
  111. /*  
  112.  
  113.  * 过滤特殊字符 剔除,\除外  
  114.  
  115.  * @param str input的value  
  116.  
  117.  * @use <input onkeyup="value=filterschar2(value)" filterschar2="value=filterschar2(value)" />  
  118.  
  119.  * @author yifangyou  
  120.  
  121.  * @version gslb 2011-01-16  
  122.  
  123.  * */ 
  124.  
  125. function filterschar2(str){  
  126.  
  127.         var p=/[\'\"#,;&%^\$!\+=\|\\ ]/g  
  128.  
  129.         return str.replace(p,'');  
  130.  
  131. }  
  132.  
  133.  
  134.  
  135. /*  
  136.  
  137.  * 过滤中文和特殊字符  
  138.  
  139.  * @param str input的value  
  140.  
  141.  * @use <input onkeyup="value=filterchinese(value)" onafterpaste="value=filterchinese(value)" />  
  142.  
  143.  * @author yifangyou  
  144.  
  145.  * @version gslb 2011-01-16  
  146.  
  147.  * */ 
  148.  
  149. function filterchinese(str){  
  150.  
  151.         var p=/[\u4E00-\u9FA5\'\",&%^\$!\+=\|\\\/]/g  
  152.  
  153.         return str.replace(p,'');  
  154.  
  155. }  
  156.  
  157.  
  158.  
  159. /*  
  160.  
  161.  * 只允许输入中英文 "_" "-"  
  162.  
  163.  * @param str input的value  
  164.  
  165.  * @use <input onkeyup="value=filterschar2(value)" filterschar2="value=filterOnlyCE(value)" onafterpaste="value=filterOnlyCE(value)"/>  
  166.  
  167.  * @author yifangyou  
  168.  
  169.  * @version gslb 2011-01-16  
  170.  
  171.  * */ 
  172.  
  173. function filterOnlyCE(str){  
  174.  
  175.     var p=/[^\u4E00-\u9FA5\w\-]/g  
  176.  
  177.         return str.replace(p,'');  
  178.  
  179. }  
  180.  
  181.  
  182.  
  183.  
  184.  
  185.  
  186.  
  187. /*  
  188.  
  189.  * 只能输入数字  
  190.  
  191.  * @param str input的value  
  192.  
  193.  * @use <input onkeyup="value=filterNumeric(value)" onafterpaste="value=filterNumeric(value)" />  
  194.  
  195.  * @author yifangyou  
  196.  
  197.  * @version gslb 2011-01-16  
  198.  
  199.  * */ 
  200.  
  201. function filterNumeric(str){  
  202.  
  203.     var p=/[\D]/g  
  204.  
  205.     return str.replace(p,'');  
  206.  

 




     本文转自yifangyou 51CTO博客,原文链接:http://blog.51cto.com/yifangyou/615896,如需转载请自行联系原作者

相关文章
|
1月前
|
JavaScript 前端开发 Java
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
本文介绍了JavaScript中常用的函数和方法,包括通用函数、Global对象函数以及数组相关函数。详细列出了每个函数的参数、返回值及使用说明,并提供了示例代码。文章强调了函数的学习应结合源码和实践,适合JavaScript初学者和进阶开发者参考。
43 2
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
|
1月前
|
前端开发 JavaScript 开发者
除了 Generator 函数,还有哪些 JavaScript 异步编程解决方案?
【10月更文挑战第30天】开发者可以根据具体的项目情况选择合适的方式来处理异步操作,以实现高效、可读和易于维护的代码。
|
2月前
|
JavaScript 前端开发
JavaScript 函数语法
JavaScript 函数是使用 `function` 关键词定义的代码块,可在调用时执行特定任务。函数可以无参或带参,参数用于传递值并在函数内部使用。函数调用可在事件触发时进行,如用户点击按钮。JavaScript 对大小写敏感,函数名和关键词必须严格匹配。示例中展示了如何通过不同参数调用函数以生成不同的输出。
|
2月前
|
存储 JavaScript 前端开发
JS函数提升 变量提升
【10月更文挑战第6天】函数提升和变量提升是 JavaScript 语言的重要特性,但它们也可能带来一些困惑和潜在的问题。通过深入理解和掌握它们的原理和表现,开发者可以更好地编写和维护 JavaScript 代码,避免因不了解这些机制而导致的错误和不一致。同时,不断提高对执行上下文等相关概念的认识,将有助于提升对 JavaScript 语言的整体理解和运用能力。
|
3月前
|
JavaScript 前端开发 安全
JavaScript函数详解
JavaScript函数的详细解析,包括函数的定义和调用方式(如一般格式、匿名函数、构造函数、自调用函数、箭头函数和严格模式)、函数参数(arguments对象、可变参数、默认参数值)、闭包的概念和应用实例。
JavaScript函数详解
|
2月前
|
移动开发 JavaScript 前端开发
原生js如何获取dom元素的自定义属性
原生js如何获取dom元素的自定义属性
87 4
|
2月前
|
JavaScript 前端开发
js教程——函数
js教程——函数
52 4
|
2月前
|
存储 JavaScript 前端开发
js中函数、方法、对象的区别
js中函数、方法、对象的区别
23 2
|
2月前
|
JavaScript 前端开发 Java
【javaScript数组,函数】的基础知识点
【javaScript数组,函数】的基础知识点
32 5
|
2月前
|
JavaScript 前端开发
Node.js 函数
10月更文挑战第5天
26 3