(42) Aeroo 模板实战
用writer设计一个采购单的模板
我用的是libreoffice 5.2.x

对于这个表格是通过工具栏上的插入指定的表格行和列完成,然后排版
对于单号po00001 这这样插入的



这样就完成一个订单号的插入
这里针对一个订单,就直接用o ,若是针对多个选中的订单就要用 objects 做循环
下面看一下不同单元插入的输入字段



<for each="line in o.order_line">
对于内循环的就不是用o了。就用line,主要根据<for> 里面自己定义的,我是用line


这样就完成一个循环要定义的字段

这时可能有些同学会问,这些字段是哪里来的。下面就告诉大家



当鼠标放上对,就可以显示对应的字段,你就可以拿这些字段名用在报表模板中
对于订单明细,那要单击进去查

是不是很简单,就这样把模板设计完了。
然后新建报表

测试一下效果


我只有一个采购单,那就写1那个序号

这就看到效果,
测试的可以,就把这个报表通过按扭添加到采购订单那里

这里可以到采购订单列表那里看

可以看到添加按钮成功,这样就可以通过点这个按钮进行打印
对于图片,在odt模板是采用插入框架来实现字段定义
用于实际的报表,你们可以结合前一节的教程和这节的实操去完成。
image: asimage(product.product_image) 这个放图片
<for each="o in objects"></for> 对所选项做循环
下面用calc来设计销售订单的模版

分析一下:
针对图片,是插入一个图做为占位符,然后设定它的name属性的值


若是用calc 来设计模板是插入超链接
不用<> 而是用python:// 开头

红色箭头那里是设定对应内容的超链接
后面我用了格式化日期,从而在开头设了 setLang


下面是产品明细:

上面的index,主要用于下面的NO. 对应的编号


在第一次选择对应的内容设置超链接时会相对简单,当要再次修改对应文字的超链接要有一定的小技巧
如:

要再次改变红框字对应的超链接的值
跟我来一起操作
第一步
对着它右击:

第二步:
移到内容上单击:

这时弹出框会消失
第三步:
对着内容双击:

这样就选中了
第四步:
接着单点工具栏的超级链接按钮


修改红框的值,然后保存就可以了
配合上章的函数,可以格式报表的数据,小心操作,就可以设计出自己要用的模板
${(object.name or '').replace('/','_')}_${object.state == 'draft' and 'draft' or ''}.pdf 自定义输出报表文件名
结合report_custom_filename 模块
(42) Aeroo 模板实战的更多相关文章
- (41) Aeroo 模板设计基础教程
1. 理论基础 注:我采用libreoffice5.2设计讲解 1.1. 定义模板指令 模板指令的语法和Genshi 模板语言相兼容,可以用Libreoffice( Write, Ca ...
- velocity模板实战
场景:json配置报文转换遇到的问题:1.json报文转换成map,多节点如何处理?数组如何处理? 2.velocity模板处理数组 3.应用之间rabbitmq通讯map反序列化,数组报错?知识点: ...
- C++模板实战6:迭代器
1 迭代器的类型: 输入迭代器 .前向迭代器.双向迭代器.跳转迭代器以及输出迭代器.这五种迭代器的限制条件从左至右越来越强. 2 输入迭代器需满足的条件: X u(a); X可复制构造 u=a; 可赋 ...
- Android学习系列(42)--Android Studio实战技巧
使用android studio开发项目的一些问题,功能和技巧. 1. 环境 Mac OSX 10.9.5 + Android Studio 0.8.9 2. gradle项目加载超慢 这是因为gra ...
- [js高手之路]Node.js模板引擎教程-jade速学与实战1
环境准备: 全局安装jade: npm install jade -g 初始化项目package.json: npm init --yes 安装完成之后,可以使用 jade --help 查看jade ...
- [js高手之路]Node.js模板引擎教程-jade速学与实战1-基本用法
环境准备: 全局安装jade: npm install jade -g 初始化项目package.json: npm init --yes 安装完成之后,可以使用 jade --help 查看jade ...
- [转]C++ template —— 模板基础(一)
<C++ Template>对Template各个方面进行了较为深度详细的解析,故而本系列博客按书本的各章顺序编排,并只作为简单的读书笔记,详细讲解请购买原版书籍(绝对物超所值).---- ...
- Python Flask打造一个视频网站实战视频教程
下载链接:https://www.yinxiangit.com/607.html 目录: 本套课程从零基础讲解flask开发网站.涉及到的知识点包括:Python和pycharm的安装.urls和视图 ...
- C++ template —— 模板基础(一)
<C++ Template>对Template各个方面进行了较为深度详细的解析,故而本系列博客按书本的各章顺序编排,并只作为简单的读书笔记,详细讲解请购买原版书籍(绝对物超所值).---- ...
随机推荐
- Hdu 5493 合肥网络赛 1010 Queue
在线求第k大,第一次用二分+树状数组写...比赛的时候分治啊,splay啊,主席树啊换来换去,然而以前为什么不知道可以这么写... #include <iostream> #include ...
- CF 484E - Sign on Fence
E. Sign on Fence time limit per test 4 seconds memory limit per test 256 megabytes input standard in ...
- squid-nginx 基本配置
#本地绑定的IP端口 http_port 192.168.1.253:801 vhost visible_hostname test-squid cache_dir ufs c:/squid/cach ...
- False 等效值
False 等效值 下面这些值将被计算出 false (also known as Falsy values): false undefined null 0 NaN 空字符串 ("&quo ...
- JavaScript高级程序设计 读书笔记 第二章
<script>元素 直接在页面中嵌入JavaSript代码或包含外部JavaSript文件. 在代码中任何地方不能出现</script>,可通过转义字符'\'解决. 在XHT ...
- java 入门学习
想要学习java,首先你要明白java是干嘛的,它有什么吸引之处,懂程序的都应该知道,java是很多计算机语言的根本,无论在什么时代,科技如何更新,java都不会落后,现在的我在学习初级java,下面 ...
- angular 后台交换实例
<!DOCTYPE html><html lang="en" ng-app="myApp"><head> <meta ...
- 关于freemaker的一点使用技巧
在做国泰君安2016年中秋送电影票活动中,需要做这样一个手机页面,展示所有中奖用户的中奖信息.如下图: 要求对用户的后记号码中间5位做隐藏处理.最开始的处理方法是在对用户实体的get()方法做处理 / ...
- Dom中的继承关系
首先声明,一些内容基于个人猜测,如果哪里有错误,请立即联系在下! 我们用js操作Dom时,会经常用到一些个方法比如基于获取到的元素选择其子元素: <!DOCTYPE html> <h ...
- 迈出第一步:自适应高度的ImageView(AutoHeightImageView)
这个博客注册很久了,可是一直都没有勇气来写一点东西.今天解决了一个让我纠结很久的问题,于是,我决定开始我的博客生涯,希望我能坚持下去. 不知道是不是只有我遇到了这个问题,在ListView中显示图片, ...