根据NVeloDocx Word模板引擎生成Word(一)

devtools/2024/9/24 8:24:56/

自从我们基于免费开放的E6开发平台,实现了根据Word模版生成Word文档的模版引擎后,也实实在在帮助到了一些有需要的朋友。但是由于制作Word模版的过程对于很多人会是一个很头疼的事情,虽然提供了详细的文档,但是我们也经常接到他们的咨询,所以很有必要对怎么基于NVeloDocx怎么制作Word模版做详细说明。

下面所有的关于制作Word模版的表述都是基于NVeloDocx的。

我们这篇先介绍最基础的用法,实现最基础的功能。首先要知道最基本取数方法,由于NVeloDocx基于NVelocity,所以取数标签的用法完全采用NVelocity语法,比如要将客户资料生成Word,且客户名称对应的数据库字段是“__Name__”,那么我们就可以通过如下的标签取到客户的姓名了:

${data.GetValue("__Name__")}

1、 ${...} 是NVelocity语法,很容易记忆,我们只需要记得所有要取数的地方都这么写就行。

2、data 表示传入模版的客户数据;

3、data.GetValue("__Name__") 表示取客户数据中的Name字段的值;

要取客户资料的其他字段方法一样,只不过用不同的字段名。

再比如,客户表单上一般都会有“业务员”字段,所以都会引用员工表单上的员工姓名字段(数据库字段也叫__Name__),假设员工表单编号是Employee,那么取数方法是:

${data.GetValue("Employee\\__Name__")}

那如果还需要员工所属部门名称呢(假设部门表单编号是Department,部门名称字段也是__Name__),那么就用?

${data.GetValue("Employee\\Department\\__Name__")}

注意:由于斜杠“\”在大多数开发语言中都有特殊意义,所以遇到斜杠“\”的地方一定要使用双斜杠“\\”才行。

这样的语法应该每个人都可以看懂了吧?

了解了最基础的取数方法后,我们就可以制作自己的Word模版了,先制作好模板,再在需要的地方使用上面的取数标签替换就行。特别是在表格中填写取数标签的时候,由于取数标签长度很可能超出您预留的宽度,很可能会撑开您的模版,这些都不会影响最终的展示效果的。

假设我们制作了如下模版:

生成的效果图如下:

NVeloDocx非常灵活且目前采用了成熟的模版引擎(NVelocity),但是理论上来说NVeloDocx的实现方法、实现原理可以很容易地支持其他的任何模版引擎。


http://www.ppmy.cn/devtools/108674.html

相关文章

美食|基于SpringBoot+vue的美食网站(源码+数据库+文档)

美食网站 基于SSMvue的美食网站 一、前言 二、系统设计 三、系统功能设计 系统功能实现 后台模块实现 管理员模块实现 用户模块实现 餐厅模块实现 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源码获取: 博主介绍&…

Elasticsearch文档值

在Elasticsearch中,文档值(Doc Values)是用于高效存储和检索数据的一种数据结构,特别是在处理聚合、排序和过滤操作时。文档值是Elasticsearch为每个字段生成的预先计算的格式化数据,目的是改善性能和降低内存使用。 …

QT作业1

1> 手写unique_ptr指针指针 代码&#xff1a; #include <iostream>using namespace std;// 自定义的unique_ptr类模板 template <typename T> class unique_ptr { public:// 构造函数&#xff0c;接收一个指针explicit unique_ptr(T* ptr nullptr) noexcept …

git cz 规范化 git commit 格式

git cz 规范化 git commit 格式 npm install git-cz --save-devnpm install commitizen --save-devnpm install cz-customizable --save-dev // 这是package.json自动生成的 "config": {"commitizen": {"path": "./node_modules/cz-custo…

【ruby java】登陆功能/邮件发送模版240903

Rails 风格登录系统添加全面而详细的注释&#xff0c;解释每个部分的功能和用途。​​​​​​​​​ 详细注释&#xff0c;解释了每个文件和代码块的功能。以下是一些关键点的总结&#xff1a; 1. 控制器&#xff08;Controllers&#xff09;: - ApplicationController: …

DrissionPage设置启动浏览器为edge

1.查看浏览器启动路径 在浏览器地址栏输入下面地址&#xff0c;拿到可执行文件的路径 。 edge://version/ 2.替换路径 打开DrissionPage._configs. chromium_options.py文件&#xff0c;找到def browser_path(self)这个函数&#xff0c;将返回内容替换为edge的启动路径&#x…

从零开始,认识游戏设计师(4)体验源于设计师②

认真并仔细地揣摩你的想法 了解自己的感受并不是一件简单的事情&#xff0c;作为设计师&#xff0c;我觉得比了解玩家总体感觉的技能更重要的是你能清楚知道描述自己感受。 试想一下&#xff0c;你是否能准确描述你喜欢什么&#xff0c;你讨厌什么&#xff0c;以及为什么这样…

PHP一站式解决方案高级房产系统小程序源码

一站式解决方案&#xff0c;高级房产系统让房产管理更轻松 &#x1f3e0;【开篇&#xff1a;告别繁琐&#xff0c;迎接高效房产管理新时代】&#x1f3e0; 你是否还在为房产管理的繁琐流程而头疼&#xff1f;从房源录入、客户咨询到合同签订、售后服务&#xff0c;每一个环节…