js中的string.format函数代码


Posted in Javascript onAugust 11, 2020

源于C#中的string.Format()

String.prototype.format = function(args) {
  if (arguments.length > 0) {
    var result = this;
    if (arguments.length == 1 && typeof(args) == "object") {
      for (var key in args) {
        var reg = new RegExp("({" + key + "})", "g");
        result = result.replace(reg, args[key]);
      }
    } else {
      for (var i = 0; i < arguments.length; i++) {
        if (arguments[i] == undefined) {
          return "";
        } else {
          var reg = new RegExp("({[" + i + "]})", "g");
          result = result.replace(reg, arguments[i]);
        }
      }
    }
    return result;
  } else {
    return this;
  }
}

例:

//两种调用方式
var template1="我是{0},今年{1}了";
var template2="我是{name},今年{age}了";
var result1=template1.format("loogn",22);
var result2=template1.format({name:"loogn",age:22});
//两个结果都是"我是loogn,今年22了"

下面分享一个作为字符串扩展的写法

String.format = function() {
  for (var a = arguments[0], b = 1; b < arguments.length; b++) a = a.replace(RegExp("\\{" + (b - 1) + "\\}", "ig"), arguments[b]);
  return a
};

以上就是js中的string.format函数代码的详细内容,更多关于js中的string.format的资料请关注三水点靠木其它相关文章!

Javascript 相关文章推荐
jQuery 性能优化指南(3)
May 21 Javascript
cnblogs中在闪存中屏蔽某人的实现代码
Nov 14 Javascript
jQuery提交多个表单的小例子
Jun 30 Javascript
浅谈jQuery中setInterval()方法
Jul 07 Javascript
jQuery xml字符串的解析、读取及查找方法
Mar 01 Javascript
Vuex之理解Getters的用法实例
Apr 19 Javascript
详解如何在 vue 项目里正确地引用 jquery 和 jquery-ui的插件
Jun 01 jQuery
探讨Vue.js的组件和模板
Oct 27 Javascript
vue实现前进刷新后退不刷新效果
Jan 26 Javascript
JavaScript设计模式之装饰者模式实例详解
Jan 17 Javascript
微信小程序表单验证插件WxValidate的二次封装功能(终极版)
Sep 03 Javascript
JavaScript设计模式之门面模式原理与实现方法分析
Mar 09 Javascript
关于html+ashx开发中几个问题的解决方法
Jul 18 #Javascript
TreeView 用法(有代码)(asp.net)
Jul 15 #Javascript
基于jquery实现的鼠标滑过按钮改变背景图片
Jul 15 #Javascript
jquery 结合C#后台的数组对文章的关键字自动添加链接的代码
Jul 15 #Javascript
js实现addClass,removeClass,hasClass的函数代码
Jul 13 #Javascript
js下将字符串当函数执行的方法
Jul 13 #Javascript
JS高级笔记
Jul 13 #Javascript
You might like
PHP_MySQL教程-第一天
2007/03/18 PHP
PHP生成月历代码
2007/06/14 PHP
10个对初学者非常有用的PHP技巧
2016/04/06 PHP
PHP中$GLOBALS['HTTP_RAW_POST_DATA']和$_POST的区别分析
2017/07/03 PHP
JsDom 编程小结
2011/08/09 Javascript
javascript实现的HashMap类代码
2014/06/27 Javascript
浅谈JavaScript中的String对象常用方法
2015/02/25 Javascript
举例详解AngularJS中ngShow和ngHide的使用方法
2015/06/19 Javascript
JS 全屏和退出全屏详解及实例代码
2016/11/07 Javascript
Angularjs实现分页和分页算法的示例代码
2016/12/23 Javascript
如何制作幻灯片(代码分享)
2017/01/06 Javascript
解决使用layui的时候form表单中的select等不能渲染的问题
2019/09/18 Javascript
深入了解Vue3模板编译原理
2020/11/19 Vue.js
Python实现的检测web服务器健康状况的小程序
2014/09/17 Python
Python模块搜索概念介绍及模块安装方法介绍
2015/06/03 Python
详解Python import方法引入模块的实例
2017/08/02 Python
Python实现简单的语音识别系统
2017/12/13 Python
78行Python代码实现现微信撤回消息功能
2018/07/26 Python
python requests post多层字典的方法
2018/12/27 Python
自适应线性神经网络Adaline的python实现详解
2019/09/30 Python
浅析python 动态库m.so.1.0错误问题
2020/05/09 Python
解决Keras TensorFlow 混编中 trainable=False设置无效问题
2020/06/28 Python
详解python算法常用技巧与内置库
2020/10/17 Python
去除python中的字符串空格的简单方法
2020/12/22 Python
英国领先的鞋类零售商:Shoe Zone
2018/12/13 全球购物
东南亚排名第一的服务市场:kaodim
2019/03/28 全球购物
白俄罗斯在线大型超市:e-dostavka.by
2019/07/25 全球购物
20岁生日感言
2014/01/13 职场文书
质量提升方案
2014/06/16 职场文书
房屋鉴定委托书范本
2014/09/23 职场文书
2015小学新教师个人工作总结
2015/10/14 职场文书
2016教师国培研修感言
2015/12/08 职场文书
2016年小学党支部创先争优活动总结
2016/04/05 职场文书
如何制定一份可行的计划!
2019/06/21 职场文书
springBoot基于webSocket实现扫码登录
2021/06/22 Java/Android
html form表单基础入门案例讲解
2021/07/15 HTML / CSS