码迷,mamicode.com
首页 > Web开发 > 详细

js 实现 C# 的 format 方法

时间:2014-07-19 09:22:47      阅读:273      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   java   color   数据   

bubuko.com,布布扣

其实我根本不会 C# 只是看到人家写了个这种功能《js实现类似c#中的字符串处理方法format()
我看了下代码,觉得思路繁琐,所以简化思路写一个一样的功能的方法,和大家分享下思路。

先来看下代码吧。

String.prototype.format = function(args) {
    var _dic = typeof args === "object" ? args : arguments;
    return this.replace(/\{([^{}]+)\}/g, function(str, key) {
        return _dic[key] || str;
    });
}

var str = "参数{0}参数{1}参数{3}参数{hehe}参数{{fuck}}参数{ooxx}";
console.log( str.format("001", "002") ); // 参数001参数002参数{3}参数{hehe}参数{{fuck}}参数{ooxx}
console.log( str.format(["001", "002"]) ); // 参数001参数002参数{3}参数{hehe}参数{{fuck}}参数{ooxx}

console.log( str.format({hehe: "呵呵", fuck: "法克"}) ); // 参数{0}参数{1}参数{3}参数呵呵参数{法克}参数{ooxx}
console.log( str.format({"1":"111", hehe: "呵呵", ooxx: "哈哈"}) ); // 参数{0}参数111参数{3}参数呵呵参数{{fuck}}参数哈哈

代码简洁易懂,维护起来也很轻松,而且支持 3 种格式的参数替换。
但是也不是无懈可击的,因为我的思路和原文完全相反。

思路是这样的,利用正则匹配出字符串内所有 {key} 这样的格式字符,然后把 key 当作对象对应的key或者数组对应的下标进行替换。
第一行  var _dic = typeof args === "object" ? args : arguments;  可以接受 3 种格式的数据。
多参数: arguments
数组: []
对象: {}
把这3种数据当作字典保存在 _dic 变量里。

下面正则替换替换函数里,其实就是进行查字典操作。
 return _dic[key] || str; 
如果 _dic[key] 对应数据存在,就替换,否则就返回原始数据。
因为 arguments, [], {} 都可以当作字典来处理,所以就可用最简单方法实现这种效果了。

同时缺陷也非常明确的暴露了,就是如果字符串里 {key} 这种参数非常多,但是替换的数据却很少的时候,性能肯定不如他的方法。
但我觉得一般操作肯定都是参数对应进行替换的,这样性能损耗就不用担心了,因为对应了参数,损耗就是0。
反而比他那个多次正则替换来的快呢。

js 实现 C# 的 format 方法,布布扣,bubuko.com

js 实现 C# 的 format 方法

标签:style   blog   http   java   color   数据   

原文地址:http://www.cnblogs.com/52cik/p/js-string-format.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!