《仔仔细细分析Ext》 Ext对String类的扩展

2024-01-09 14:10

本文主要是介绍《仔仔细细分析Ext》 Ext对String类的扩展,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原生 String 类:

         一个 length 属性、一个静态方法 String.fromCharCode() 17 个实例方法。(这里的称呼都是方便理解的方式,不是严格意义上 OO 的意思。)

         17 个实例方法简表:

1、  charAt()  

2、  charCodeAt() :返回字符串中指定位置处的字符编码( Unicode 码值)。

3、  concat() :把一个或多个值连接到字符串上

4、  indexOf()

5、  lastIndexOf()  

6、  localeCompare() :用本地化的顺序比较字符串

7、  match(): 用正则表达式进行模式匹配

8、  replace()  

9、  search() :检索字符串中与正则表达式匹配的子串

10、 slice(): 返回字符串的一个子串

11、 split()

12、 substr()

13、 substring()  

14、 toLowerCase()

15、 toString()

16、  toUpperCase()

17、 valueOf()

 

Ext String 的扩展

         Ext.js 中对 String 类扩展了三个静态方法: escape() leftPad() format()

两个实例方法: toggle() trim()

String 类的扩展程序比较简洁,不对废话,仅仅把 Ext 的源码注释和示例翻译一下:


 

Js代码 复制代码
  1. <SPAN style="FONT-SIZE: medium">/**  
  2.  
  3.  * @String类  
  4.  
  5.  * 这些方法是对JavaScript中String类静态方法的扩展  
  6.  
  7.  */  
  8.   
  9. Ext.applyIf(String, {   
  10.   
  11.     /**  
  12.  
  13.      *将传进来的String中的’和\过滤掉  
  14.  
  15.      * @参数 {String} string 需要进行过滤的字符串  
  16.  
  17.      * @返回值 {String} 过滤好的字符串  
  18.  
  19.      * @静态方法  
  20.  
  21.      */  
  22.   
  23.     escape : function(string) {   
  24.   
  25.         return string.replace(/('|\\)/g, "\\$1");   
  26.   
  27.     },   
  28.   
  29.     
  30.   
  31.     /**  
  32.  
  33.      * 用指定的字符填充一个字符串的左侧。对于格式化数字或者日期字符串,这  
  34.  
  35. *一个非常有用的方法。用法示例:  
  36.  
  37.      * <pre><code>  
  38.  
  39. var s = String.leftPad('123', 5, '0');  
  40.  
  41. // s now contains the string: '00123'  
  42.  
  43. </code></pre>  
  44.  
  45.      * @参数1 {String} string 原来的字符串  
  46.  
  47.      * @参数2 {Number} size 返回字符串的总长度  
  48.  
  49.      * @参数3 {String} char (optional) 填充的字符串 (默认用" "填充)  
  50.  
  51.      * @返回值 {String} 填充好的字符串  
  52.  
  53.      * @静态方法  
  54.  
  55.      */  
  56.   
  57.     leftPad : function (val, size, ch) {   
  58.   
  59.         var result = new String(val);   
  60.   
  61.         if(!ch) {   
  62.   
  63.             ch = " ";   
  64.   
  65.         }   
  66.   
  67.         while (result.length < size) {   
  68.   
  69.             result = ch + result;   
  70.   
  71.         }   
  72.   
  73.         return result.toString();   
  74.   
  75.     },   
  76.   
  77.     
  78.   
  79. /*允许你自定义含有占位符的字符串,并且传递任意数量的参数去替代这些占位符。*每一个占位符必须是唯一的,并且以{0}、{1}…这种格式递增。  
  80.  
  81.          *用法示例:  
  82.  
  83.     * <pre><code>  
  84.  
  85. var cls = 'my-class', text = 'Some text';  
  86.  
  87. var s = String.format('&lt;div class="{0}">{1}&lt;/div>', cls, text);  
  88.  
  89. // s now contains the string: '&lt;div class="my-class">Some text&lt;/div>'  
  90.  
  91. </code></pre>  
  92.  
  93.      * @参数1 {String} string 含有占位符,需要格式化的字符串  
  94.  
  95.      * @参数2 {String} value1 替代占位符 {0}的字符串  
  96.  
  97.      * @参数3 {String} value2  替代占位符{1}的字符串,以此类推  
  98.  
  99.      * @返回值 {String} 格式化好的字符串  
  100.  
  101.      * @静态方法  
  102.  
  103.      */  
  104.   
  105.     format : function(format){   
  106.   
  107.         var args = Array.prototype.slice.call(arguments, 1);   
  108.   
  109.         return format.replace(/\{(\d+)\}/g, function(m, i){   
  110.   
  111.             return args[i];   
  112.   
  113.         });   
  114.   
  115.     }   
  116.   
  117. });   
  118.   
  119. /*工具方法,帮助你轻松地在两个字符串之间轮换取值。  
  120.  
  121. *传入的第一个参数值会与当前字符串进行比较,如果它们相等,则把当前字符串赋值*为传入的第二个参数。否则,保持当前值不变。  
  122.  
  123. *注意,该方法会返回一个新的字符串,而不是去改变当前字符串。  
  124.  
  125.  * <pre><code>  
  126.  
  127. // alternate sort directions  
  128.  
  129. sort = sort.toggle('ASC', 'DESC');  
  130.  
  131.    
  132.  
  133. // instead of conditional logic:  
  134.  
  135. sort = (sort == 'ASC' ? 'DESC' : 'ASC');  
  136.  
  137. </code></pre>  
  138.  
  139.  * @参数1 {String} value 需要与当前值进行比较的字符串  
  140.  
  141.  * @参数2 {String} other 如当前字符串与第一个传入的参数相等,赋值给当前字符串的新值。  
  142.  
  143.  * @返回值 {String} 新的字符串  
  144.  
  145.  */  
  146.   
  147. String.prototype.toggle = function(value, other){   
  148.   
  149.     return this == value ? other : value;   
  150.   
  151. };   
  152.   
  153.     
  154.   
  155. /**  
  156.  
  157.  * 去掉字符串两端的空格,保持中间的空格不变。示例:  
  158.  
  159.  * <pre><code>  
  160.  
  161. var s = '  foo bar  ';  
  162.  
  163. alert('-' + s + '-');         //alerts "- foo bar -"  
  164.  
  165. alert('-' + s.trim() + '-');  //alerts "-foo bar-"  
  166.  
  167. </code></pre>  
  168.  
  169.  * @返回值 {String} 去掉两端空格后的字符串  
  170.  
  171.  */  
  172.   
  173. String.prototype.trim = function(){   
  174.   
  175.     var re = /^\s+|\s+$/g;   
  176.   
  177.     return function(){ return this.replace(re, ""); };   
  178.   
  179. }();</SPAN>  
/*** @String类* 这些方法是对JavaScript中String类静态方法的扩展*/Ext.applyIf(String, {/***将传进来的String中的’和\过滤掉* @参数 {String} string 需要进行过滤的字符串* @返回值 {String} 过滤好的字符串* @静态方法*/escape : function(string) {return string.replace(/('|\\)/g, "\\$1");},/*** 用指定的字符填充一个字符串的左侧。对于格式化数字或者日期字符串,这*一个非常有用的方法。用法示例:* <pre><code>var s = String.leftPad('123', 5, '0');// s now contains the string: '00123'</code></pre>* @参数1 {String} string 原来的字符串* @参数2 {Number} size 返回字符串的总长度* @参数3 {String} char (optional) 填充的字符串 (默认用" "填充)* @返回值 {String} 填充好的字符串* @静态方法*/leftPad : function (val, size, ch) {var result = new String(val);if(!ch) {ch = " ";}while (result.length < size) {result = ch + result;}return result.toString();},/*允许你自定义含有占位符的字符串,并且传递任意数量的参数去替代这些占位符。*每一个占位符必须是唯一的,并且以{0}、{1}…这种格式递增。*用法示例:* <pre><code>var cls = 'my-class', text = 'Some text';var s = String.format('&lt;div class="{0}">{1}&lt;/div>', cls, text);// s now contains the string: '&lt;div class="my-class">Some text&lt;/div>'</code></pre>* @参数1 {String} string 含有占位符,需要格式化的字符串* @参数2 {String} value1 替代占位符 {0}的字符串* @参数3 {String} value2  替代占位符{1}的字符串,以此类推* @返回值 {String} 格式化好的字符串* @静态方法*/format : function(format){var args = Array.prototype.slice.call(arguments, 1);return format.replace(/\{(\d+)\}/g, function(m, i){return args[i];});}});/*工具方法,帮助你轻松地在两个字符串之间轮换取值。*传入的第一个参数值会与当前字符串进行比较,如果它们相等,则把当前字符串赋值*为传入的第二个参数。否则,保持当前值不变。*注意,该方法会返回一个新的字符串,而不是去改变当前字符串。* <pre><code>// alternate sort directionssort = sort.toggle('ASC', 'DESC');// instead of conditional logic:sort = (sort == 'ASC' ? 'DESC' : 'ASC');</code></pre>* @参数1 {String} value 需要与当前值进行比较的字符串* @参数2 {String} other 如当前字符串与第一个传入的参数相等,赋值给当前字符串的新值。* @返回值 {String} 新的字符串*/String.prototype.toggle = function(value, other){return this == value ? other : value;};/*** 去掉字符串两端的空格,保持中间的空格不变。示例:* <pre><code>var s = '  foo bar  ';alert('-' + s + '-');         //alerts "- foo bar -"alert('-' + s.trim() + '-');  //alerts "-foo bar-"</code></pre>* @返回值 {String} 去掉两端空格后的字符串*/String.prototype.trim = function(){var re = /^\s+|\s+$/g;return function(){ return this.replace(re, ""); };}();

 

format() 方法的工作机制:

String 的扩展代码比较清晰,也很好理解,里面这个 format() 方法倒是有点味道,笔者思虑半天没有明白它的机制,知道的高手请指点,万谢!

这篇关于《仔仔细细分析Ext》 Ext对String类的扩展的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/587388

相关文章

Nginx分布式部署流程分析

《Nginx分布式部署流程分析》文章介绍Nginx在分布式部署中的反向代理和负载均衡作用,用于分发请求、减轻服务器压力及解决session共享问题,涵盖配置方法、策略及Java项目应用,并提及分布式事... 目录分布式部署NginxJava中的代理代理分为正向代理和反向代理正向代理反向代理Nginx应用场景

Redis中的有序集合zset从使用到原理分析

《Redis中的有序集合zset从使用到原理分析》Redis有序集合(zset)是字符串与分值的有序映射,通过跳跃表和哈希表结合实现高效有序性管理,适用于排行榜、延迟队列等场景,其时间复杂度低,内存占... 目录开篇:排行榜背后的秘密一、zset的基本使用1.1 常用命令1.2 Java客户端示例二、zse

Redis中的AOF原理及分析

《Redis中的AOF原理及分析》Redis的AOF通过记录所有写操作命令实现持久化,支持always/everysec/no三种同步策略,重写机制优化文件体积,与RDB结合可平衡数据安全与恢复效率... 目录开篇:从日记本到AOF一、AOF的基本执行流程1. 命令执行与记录2. AOF重写机制二、AOF的

MyBatis Plus大数据量查询慢原因分析及解决

《MyBatisPlus大数据量查询慢原因分析及解决》大数据量查询慢常因全表扫描、分页不当、索引缺失、内存占用高及ORM开销,优化措施包括分页查询、流式读取、SQL优化、批处理、多数据源、结果集二次... 目录大数据量查询慢的常见原因优化方案高级方案配置调优监控与诊断总结大数据量查询慢的常见原因MyBAT

分析 Java Stream 的 peek使用实践与副作用处理方案

《分析JavaStream的peek使用实践与副作用处理方案》StreamAPI的peek操作是中间操作,用于观察元素但不终止流,其副作用风险包括线程安全、顺序混乱及性能问题,合理使用场景有限... 目录一、peek 操作的本质:有状态的中间操作二、副作用的定义与风险场景1. 并行流下的线程安全问题2. 顺

MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决

《MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决》MyBatis默认开启一级缓存,同一事务中循环调用查询方法时会重复使用缓存数据,导致获取的序列主键值均为1,... 目录问题原因解决办法如果是存储过程总结问题myBATis有如下代码获取序列作为主键IdMappe

C++中处理文本数据char与string的终极对比指南

《C++中处理文本数据char与string的终极对比指南》在C++编程中char和string是两种用于处理字符数据的类型,但它们在使用方式和功能上有显著的不同,:本文主要介绍C++中处理文本数... 目录1. 基本定义与本质2. 内存管理3. 操作与功能4. 性能特点5. 使用场景6. 相互转换核心区别

Java中最全最基础的IO流概述和简介案例分析

《Java中最全最基础的IO流概述和简介案例分析》JavaIO流用于程序与外部设备的数据交互,分为字节流(InputStream/OutputStream)和字符流(Reader/Writer),处理... 目录IO流简介IO是什么应用场景IO流的分类流的超类类型字节文件流应用简介核心API文件输出流应用文

C++ STL-string类底层实现过程

《C++STL-string类底层实现过程》本文实现了一个简易的string类,涵盖动态数组存储、深拷贝机制、迭代器支持、容量调整、字符串修改、运算符重载等功能,模拟标准string核心特性,重点强... 目录实现框架一、默认成员函数1.默认构造函数2.构造函数3.拷贝构造函数(重点)4.赋值运算符重载函数

redis数据结构之String详解

《redis数据结构之String详解》Redis以String为基础类型,因C字符串效率低、非二进制安全等问题,采用SDS动态字符串实现高效存储,通过RedisObject封装,支持多种编码方式(如... 目录一、为什么Redis选String作为基础类型?二、SDS底层数据结构三、RedisObject