zoukankan      html  css  js  c++  java
  • Javascript字符串模板处理

    /**
     * 字符串模版替换
     * 
     * @param this 需要替换的字符串
     * @param data 替换的数据。json格式的数据或者数组。 
     * 			eg: 
     * 			  str:我是{{key1}}替换的字符串{{key2}}。 data:{key1:"替换",key2:"替换2"}
     * 			  str:我是{{key.subkey}}替换的字符串{{key.subkey2}}。 data:{key{subkey:"替换",subkey2:"替换2"}}
     * 			  str:我是{{0}}替换的字符串{{1}}。 data:["替换","替换2"]
     * @returns
     */
    String.prototype.template = function(data) {
    	var str = this;
    	if(data && data.sort){
    		for(var i=0; i<data.length; i++) {
    			str = str.replace(new RegExp("{\{"+i+"}}", "gm"), data[i]);
    		}
    		return str;
    	}
    	
    	var placeholder = str.match(new RegExp("{{.+?}}", 'ig'));
    	if (data && placeholder) {
    		for ( var i = 0; i < placeholder.length; i++) {
    			var key = placeholder[i];
    			var value = proxy.call(data, key.replace(new RegExp("[{,}]", "gm"), ""));
    			key = key.replace(new RegExp("\.", "gm"), "\.").replace("{{","{\{");
    			if (value == null)
    				value = " ";
    			str = str.replace(new RegExp(key, "gm"), value);
    		}
    	}
    	return str;
    	
    	function proxy(key) {
    		try {
    			return eval('this.' + key);
    		} catch (e) {
    			return "";
    		}
    	}
    };
    

      

  • 相关阅读:
    83. Remove Duplicates from Sorted List
    141. Linked List Cycle
    hdu1028 划分数
    XDU1019 阶乘因子的个数
    poj2773 容斥原理
    poj1091 容斥原理的应用
    poj1173 多重集组合数
    HDU 1465 错排问题
    poj 1496
    复习之求一个数的约束之积模一个质数
  • 原文地址:https://www.cnblogs.com/liujufu/p/5289345.html
Copyright © 2011-2022 走看看