zoukankan      html  css  js  c++  java
  • 字符串实现变量映射

    方案一:

    字符串变量格式要求: ‘some text {$0}’,{$n}为变量

    扩展数组方法:evaluate

    Array.prototype.evaluate = function(str) {
      this.map(function(item, idx) {
        var reg = new RegExp('{\s*\$' + idx + '\s*}', 'g');
        str = str.replace(reg, item);
      });
      return str;
    }

    使用: arr.evaluate(str)

    测试:

               

    方案二:

    字符串变量格式要求: ‘some text { name}’,{name}为变量

    扩展字符串方法: evaluate 

    String.prototype.evaluate = function(map) {
      var txt = this.toString();
      for (var key in map) {
        if (map.hasOwnProperty(key)) {
          var reg = new RegExp('{\s*' + key + '\s*}', 'g');
          txt = txt.replace(reg, map[key]);
        }
      }
      return txt;
    }

    使用: str.evaluate(map)

    测试:

             

    方案二  --  加强版:

    字符串变量格式要求: ‘some text { name}’,{name}为变量,支持深度属性迭代

    扩展字符串方法: evaluate 

    String.prototype.evaluate = function(map, pKey, ptxt) {
      if (pKey) pKey += '.';
      else pKey = ''
    
      var txt = ptxt ? ptxt : this.toString();
      for (var key in map) {
        if (map.hasOwnProperty(key)) {
          if (typeof map[key] == 'object') {
            txt = this.evaluate(map[key], pKey + key, txt);
          } else {
            var reg = new RegExp('{\s*' + pKey + key + '\s*}', 'g');
    // EL表达式版: new RegExp('\${\s*'+ pKey + '\s*}','g'); txt
    = txt.replace(reg, map[key]); } } }
    if(!ptxt) { // 解析完成后清除没有匹配到的表达式
       var rg = new RegExp('{\s*[a-zA-Z0-9\.]+\s*}','g');
    // EL表达式版: new RegExp('\${\s*[a-zA-Z0-9\.]+\s*','g');
    txt = txt.replace(rg,'');
    }
    return txt; }

  • 相关阅读:
    css文字两端对齐,而且居中
    vue项目做微信分享总结
    js获取url参数
    vue微信支付遇到的坑
    Win7的环境变量下的系统变量path不小心修改了,怎么恢复
    解决ios上滑动不流畅及滚动条隐藏无效问题
    数组更新检测
    列表渲染
    条件渲染
    vue调试工具的安装
  • 原文地址:https://www.cnblogs.com/xtreme/p/10237448.html
Copyright © 2011-2022 走看看