String 的扩展方法

简介: String的扩展方法String.prototype.方法名=function(){...}基础知识字符串操作和正则表达式的应用一、合并多个空白为一个空白String.prototype.

String的扩展方法
String.prototype.方法名=function(){...}
基础知识字符串操作和正则表达式的应用
一、合并多个空白为一个空白
String.prototype.resetBlank = function () {
    return this.replace(/\s+/g, " ");
}
二、过滤空白
String.prototype.filterBlank = function () {
    return this.replace(/\s+/g, "");
}
三、除去左边空白
String.prototype.LTrim = function () {
    return this.replace(/^\s+/, "");
}
四、除去右边空白
String.prototype.RTrim = function () {
    return this.replace(/\s+$/g, "");
}
五、保留数字
String.prototype.getNum = function () {
    return this.replace(/[^\d]/g, "");
}
六、保留字母
String.prototype.getEn = function () {
    return this.replace(/[^A-Za-z]/g, "");
}
七、保留中文
String.prototype.getCn = function () {
   return this.replace(/[^\u4e00-\u9fa5\uf900-\ufa2d]/g, "")
}
八、得到字节长度
String.prototype.getRealLength = function () {
   return this.replace(/[^\x00-\xff]/g, "--").length;
}
九、从左截取指定长度的字串
String.prototype.leftSlice = function (n) {
   return this.slice(0, n);
}
十、从右截取指定长度的字串
String.prototype.rightSlice = function (n) {
    return this.slice(this.length - n);
}

<!DOCTYPE> <html> <head> <title>字符串扩展方法---www.cnblogs.com/kuikui</title> <script type="text/javascript"> //合并多个空白为一个空白 String.prototype.resetBlank = function () { return this.replace(/\s+/g, " "); } //过滤空白 String.prototype.filterBlank = function () { return this.replace(/\s+/g, ""); } //除去左边空白 String.prototype.LTrim = function () { return this.replace(/^\s+/, ""); } //除去右边空白 String.prototype.RTrim = function () { return this.replace(/\s+$/g, ""); } //保留数字 String.prototype.getNum = function () { return this.replace(/[^\d]/g, ""); } //保留字母 String.prototype.getEn = function () { return this.replace(/[^A-Za-z]/g, ""); } //保留中文 String.prototype.getCn = function () { return this.replace(/[^\u4e00-\u9fa5\uf900-\ufa2d]/g, "") } //得到字节长度 String.prototype.getRealLength = function () { return this.replace(/[^\x00-\xff]/g, "--").length; } //从左截取指定长度的字串 String.prototype.leftSlice = function (n) { return this.slice(0, n); } //从右截取指定长度的字串 String.prototype.rightSlice = function (n) { return this.slice(this.length - n); } </script> </head> <body> <script type="text/javascript"> var str1 = " 测试 Test 123456 ... "; var str2 = "abcdef"; var str3 = "<html>"; document.write("一、合并多个空格为一个空格<br/>"); document.write("<input style='background:#ff9999; width:100%; border-style:none' readonly='readonly' value='" + "|" + str1.resetBlank() + "|' /><br/>"); document.write("二、过滤空白<br/>"); document.write("<input style='background:#ff9999; width:100%; border=0px; border-style:none' readonly='readonly' value='" + "|" + str1.filterBlank() + "|' /><br/>"); document.write("三、除去左边的空白<br/>"); document.write("<input style='background:#ff9999; width:100%; border=0px; border-style:none' readonly='readonly' value='" + "|" + str1.LTrim() + "|' /><br/>"); document.write("四、除去右边的空白<br/>"); document.write("<input style='background:#ff9999; width:100%; border=0px; border-style:none' readonly='readonly' value='" + "|" + str1.RTrim() + "|' /><br/>"); document.write("五、保留数字<br/>"); document.write("<input style='background:#ff9999; width:100%; border=0px; border-style:none' readonly='readonly' value='" + "|" + str1.getNum() + "|' /><br/>"); document.write("六、保留字母<br/>"); document.write("<input style='background:#ff9999; width:100%; border=0px; border-style:none' readonly='readonly' value='" + "|" + str1.getEn() + "|' /><br/>"); document.write("七、保留中文<br/>"); document.write("<input style='background:#ff9999; width:100%; border=0px; border-style:none' readonly='readonly' value='" + "|" + str1.getCn() + "|' /><br/>"); document.write("八、得到字节长度,一个汉字为两个字节<br/>"); document.write("<input style='background:#ff9999; width:100%; border=0px; border-style:none' readonly='readonly' value='" + "|" + str1.getRealLength() + "|' /><br/>"); document.write("九、从左截取n个字符<br/>"); document.write("<input style='background:#ff9999; width:100%; border=0px; border-style:none' readonly='readonly' value='" + "|" + str2.leftSlice(3) + "|' /><br/>"); document.write("十、从左截取n个字符<br/>"); document.write("<input style='background:#ff9999; width:100%; border=0px; border-style:none' readonly='readonly' value='" + "|" + str2.rightSlice(3) + "|' /><br/>"); </script> </body> </html>

目录
相关文章
|
JavaScript 前端开发
ES6——String 的扩展方法
String 的扩展方法
177 0
|
索引
ES6中Array对象的方法和扩展、string的扩展方法、数组的遍历。(含例题)
学习ES6中Array对象的方法和扩展、string的扩展方法、数组的遍历。
259 0
|
1月前
|
编解码 Java 开发者
Java String类的关键方法总结
以上总结了Java `String` 类最常见和重要功能性方法。每种操作都对应着日常编程任务,并且理解每种操作如何影响及处理 `Strings` 对于任何使用 Java 的开发者来说都至关重要。
269 5
|
5月前
|
存储 编译器 C语言
关于string的‘\0‘与string,vector构造特点,反迭代器与迭代器类等的讨论
你真的了解string的'\0'么?你知道创建一个string a("abcddddddddddddddddddddddddd", 16);这样的string对象要创建多少个对象么?你知道string与vector进行扩容时进行了怎么的操作么?你知道怎么求Vector 最大 最小值 索引 位置么?
147 0
|
8月前
|
缓存 安全 Java
《从头开始学java,一天一个知识点》之:字符串处理:String类的核心API
🌱 **《字符串处理:String类的核心API》一分钟速通!** 本文快速介绍Java中String类的3个高频API:`substring`、`indexOf`和`split`,并通过代码示例展示其用法。重点提示:`substring`的结束索引不包含该位置,`split`支持正则表达式。进一步探讨了String不可变性的高效设计原理及企业级编码规范,如避免使用`new String()`、拼接时使用`StringBuilder`等。最后通过互动解密游戏帮助读者巩固知识。 (上一篇:《多维数组与常见操作》 | 下一篇预告:《输入与输出:Scanner与System类》)
238 11
|
8月前
|
Java
课时14:Java数据类型划分(初见String类)
课时14介绍Java数据类型,重点初见String类。通过三个范例讲解:观察String型变量、&quot;+&quot;操作符的使用问题及转义字符的应用。String不是基本数据类型而是引用类型,但使用方式类似基本类型。课程涵盖字符串连接、数学运算与字符串混合使用时的注意事项以及常用转义字符的用法。
258 9
|
8月前
|
存储 JavaScript Java
课时44:String类对象两种实例化方式比较
本次课程的主要讨论了两种处理模式在Java程序中的应用,直接赋值和构造方法实例化。此外,还讨论了字符串池的概念,指出在Java程序的底层,DOM提供了专门的字符串池,用于存储和查找字符串。 1.直接赋值的对象化模式 2.字符串池的概念 3.构造方法实例化
160 1
|
Java
【编程基础知识】(讲解+示例实战)方法参数的传递机制(值传递及地址传递)以及String类的对象的不可变性
本文深入探讨了Java中方法参数的传递机制,包括值传递和引用传递的区别,以及String类对象的不可变性。通过详细讲解和示例代码,帮助读者理解参数传递的内部原理,并掌握在实际编程中正确处理参数传递的方法。关键词:Java, 方法参数传递, 值传递, 引用传递, String不可变性。
277 1
【编程基础知识】(讲解+示例实战)方法参数的传递机制(值传递及地址传递)以及String类的对象的不可变性