用Scriban进行模版解析
前言
有些时候,我们需要根据模版去展示一些内容,通常会借助模版引擎来处理。
举个简单的例子,发短信。
短信肯定是有模版的,不同的场景对应不同的模版。
注册的,
【xxx】恭喜您成功注册yyy平台,您的帐号是zzz
支付的,
【xxx】您已成功支付,订单号为yyy,支付金额为zzz
还有很多其他。。。
如果存到数据库中,那么模版可能就会是
【{0}】您已成功支付,订单号为{1},支付金额为{2}
为的就是在代码中去格式化这个。
var tpl = "【{0}】您已成功支付,订单号为{1},支付金额为{2}";
var str = string.Format(tpl, "短信", "Order_123456", "200");
下面来看看用Scriban来处理。
Scriban
Scriban是一种快速,强大,安全和轻量级文本模板化语言和引擎。作者是Unity-Technologies的Alexandre Mutel
它支持两种模版,一种是自己的scriban模版,一种是liquid模版。
语法都差不多,不过最基本的文本替换应该能满足80%的需求了。
下面来看个例子就差不多了。
using Scriban;
using System;
using System.Collections.Generic;
class ScribanDemo
{
public void RenderSimpleText()
{
string text = "Hello, {{name}} ";
// 先解析
var tpl = Template.Parse(text);
// 后渲染
var res1 = tpl.Render(new { name = "catcher wong" });
Console.WriteLine(res1);
var res2 = tpl.Render(new { Name = "Catcher Wong" });
Console.WriteLine(res2);
}
public void RenderObject()
{
string text = @"Hello {{model.name}}, your orders' information are as follow,
you have {{model.orders | array.size }} orders
{{ for order in model.orders }}
{{order.id}}-{{order.amount}}
{{ end }}
";
var tpl = Template.Parse(text);
var res1 = tpl.Render(new
{
model = new ObjModel
{
Name = "Catcher Wong",
Orders = new List<ObjModel.Order>
{
new ObjModel.Order { Id = 1, Amount = 100 },
new ObjModel.Order { Id = 2, Amount = 300 }
}
}
});
Console.WriteLine(res1);
}
}
结果大概如下
Hello, catcher wong
Hello, Catcher Wong
Hello Catcher Wong, your orders' information are as follow,
you have 2 orders
1-100
2-300
总结
再来看看下面两个模版
【{0}】您已成功支付,订单号为{1},支付金额为{2}
【{{name}}】您已成功支付,订单号为{{orderno}},支付金额为{{amount}}
可能会发现,第二个明显比第一个清晰易懂。
第一个如果把几个数字的顺序搞错了,那个输出的结果可能就牛头不对马嘴了。
除了Scriban,还有Fluid也是挺不错的,不过就使用感觉上,个人还是偏向Scriban。
用Scriban进行模版解析的更多相关文章
- js模版解析
function JzRender(tpl, data) { // 模版解析 data是对象则返回字符串,是数组则返回字符串数组 if (data instanceof Array) { var s ...
- 自己用的框架写了一个PHP模版解析类
<?php if(!defined('IS_HEARTPHP')) exit('Access Denied'); /** * template.class.php 模板解析类 * * @copy ...
- 使用localstorage及js模版引擎 开发 m站设想
目前 m站开发的方式,依然请求完整的html,这样造成的问题就是每次请求的数据量过大过多,在没有wifi的情况下,导致页面打开的速度很慢,耗费的流量也较多:访问m站的多是移动端设备,其浏览器的版本都较 ...
- sqler sql 转rest api 源码解析(一)应用的启动入口
sqler sql 转rest api 的源码还是比较简单的,没有比较复杂的设计,大部分都是基于开源 模块实现的. 说明: 当前的版本为2.0,代码使用go mod 进行包管理,如果本地运行注意gol ...
- 深入浅出 Vue.js 第九章 解析器---学习笔记
本文结合 Vue 源码进行学习 学习时,根据 github 上 Vue 项目的 package.json 文件,可知版本为 2.6.10 解析器 一.解析器的作用 解析器的作用就是将模版解析成 AST ...
- django 模版标签笔记
一.模板变量笔记:1.在模版中使用变量,需要将变量放到‘{{}}’中.'{{ 变量 }}'2.如果想访问对象的属性,可以通过'对象.属性名'的方式访问3.如果想要访问一个字典的key对应的value, ...
- Spring MVC工作原理及源码解析(四) ViewResolver实现原理及源码解析
0.ViewResolver原理介绍 根据视图的名称将其解析为 View 类型的视图,如通过 ModelAndView 中的视图名称将其解析成 View,View 是用来渲染页面的,也就是将 Mode ...
- Vue 源码解读(8)—— 编译器 之 解析(上)
特殊说明 由于文章篇幅限制,所以将 Vue 源码解读(8)-- 编译器 之 解析 拆成了上下两篇,所以在阅读本篇文章时请同时打开 Vue 源码解读(8)-- 编译器 之 解析(下)一起阅读. 前言 V ...
- Vue 源码解读(8)—— 编译器 之 解析(下)
特殊说明 由于文章篇幅限制,所以将 Vue 源码解读(8)-- 编译器 之 解析 拆成了两篇文章,本篇是对 Vue 源码解读(8)-- 编译器 之 解析(上) 的一个补充,所以在阅读时请同时打开 Vu ...
随机推荐
- docker Dockerfile里使用的命令说明
一,dockerfile格式 注释# 指令 参数 指令不区分大小写,但是推荐全部大写指令. 指令从上到下顺序被执行 第一个指令必须是[FROM],指示出要使用的基础镜像. 执行docker file时 ...
- 27.t分布随机近邻嵌入t-SNE
t分布随机近邻嵌入(t-distributed Stohastic Neighbor Embedding) 基本思路:为高维特征空间在二维平面(或三维超平面,不过基本上总是使用二维空间)上寻找一个投影 ...
- js中获取当前url路径
可以使用 window.location 获取当前页面url.以下是一些简单应用. <script> $(function(){ // 返回 web 主机的域名,如:http://127. ...
- 1025 PAT Ranking 双重排序
Programming Ability Test (PAT) is organized by the College of Computer Science and Technology of Zhe ...
- 使用 Polly 实现复杂策略(超时重试)
一.背景 第一次接触 Polly 还是在做某个微服务系统的时候,那时只会使用单一的超时策略与重试策略,更加高级的特性就没有再进行学习了.最近开为某个客户开发 PC 端的上位机的时候,客户有个需求,在发 ...
- C#-Excel导入工资条群发邮箱
第一次写随笔,一名在实习的程序猿,做的一个小应用,需要的朋友可以参考参考, 使用WinForm实现了一个导入Excel,群发工资条的功能.功能已经实现,还不够完善,. 大致运用了OleDbConnec ...
- 松软科技带你学开发:SQL--FIRST() 函数
FIRST() 函数(原文链接 松软科技:www.sysoft.net.cn/Article.aspx?ID=3731) FIRST() 函数返回指定的字段中第一个记录的值. 提示:可使用 ORDER ...
- vue-cli3构建ts项目
1.构建项目 vue create xxx 上面的第一条,也就是 aaa 这一个选项在你第一次创建项目的时候是并不会出现的,只有你第一次创建完成项目后回提示你保存为默认配置模板,下次新建项目的时候就可 ...
- 微信小程序新服务消息推送 —— 订阅消息
微信团队前不久公测了「订阅消息」,原有的小程序模板消息接口将于 2020 年 1 月 10 日下线,届时将无法发送模板消息.「订阅消息」将完全替代「模板消息」,这两天得空测试了一波. 1.下发权限机制 ...
- ES6变量的解构赋值(一)数组的解构赋值
let[a,...arr]=[1,2,3,4];//a==>1 arr==>[2,3,4] let [x, y, ...z] = ['a'];//a==>'a' y==>und ...