Salesforce的Apex语言作为Java的高度豪华定制版。不仅提供了很多Java原生就有的很好的方法与语法。同时也对Java进行了纷纷总总的简化。
比如Apex的String.format方法。
Apex的format方法提供了一个简单的方式可以对字符串模板进行关键字替换。
下面是官方文档的例子。
String template = '{0} was last updated {1}'; List<Object> parameters = new List<Object> {'Universal Containers', DateTime.newInstance(2018, 11, 15) }; String formatted = String.format(template, parameters); System.debug ('Newly formatted string is:' + formatted);
如此一来,我们在custom label里做好带{x}字样的字符串模板,就可以随心所欲的动态生成内容了。
但是,随着进入Lightning时代,在Lightning Component前端承担的业务和内容越来越多,随之而来的就是出现了在前端直接获取字符串模板并动态生成内容的需求。
而Aura库和原生Javascript都没有提供类似与Apex的String.format方法。
俗话说,自己动手丰衣足食。那就自己写一个吧。
首先在Helper.js里面添加如下format方法。
}, //.......... Other Helper Method format: function(label, args) { for (var k in args) { label = label.replace("{" + k + "}", args[k]); } return label; }, // .......... Other Helper Method
然后在Controller.js中使用的时候,如同Apex版,第一个参数传入模板,第二个参数为按模板参数顺序传入的字符串数组。
let template = "{0} was last updated {1}"; let myLabel = helper.format(template , ["Universal Containers", "2018/11/15"]);