一:简介

QWeb是一个基于xml的模板引擎,用于生成HTML片段和页面,模板指令是写在xml标签中的以t-开头的属性,比如t-if
如果要让一个标签不被渲染,可以采用t来包裹,这样会执行它里面的命令但是不产生任何输出。【从这一点看,类似于jsp。】

template

创建一个QWeb视图,只需要一个arch元素并包含以下的属性:

  • id -- 视图的id
  • name, inherit_id, priority 与ir.ui.view的一致
  • primary -- 设置为True并与inherit_id一起使用时,设置为主视图
  • groups -- 以逗号分隔的分组id
  • page -- 设置为True时,该页面为网页
  • optional -- enabled 或 disabled,在用户界面中是否可以被禁用,默认是可以禁用

二:XML标签

1:输出内容

  1. <p><t t-esc="要显示的内容"/></p>

2:条件语句:t-if属性值为True时,输出t标签包含内容

  1. <div>
  2. <t t-if="condition">
  3. <p>ok</p>
  4. </t>
  5. </div>
  6.  
  7. #当condition是true的时候解析成:
  8. <div>
  9. <p>ok</p>
  10. </div>
  11.  
  12. #condition为false的时候解析成
  13. <div>
  14. </div>

还有t-elif/t-else:

  1. <div>
  2. <p t-if="user.birthday == today()">Happy bithday!</p>
  3. <p t-elif="user.login == 'root'">Welcome master!</p>
  4. <p t-else="">Welcome!</p>
  5. </div>

3:循环

t-foreach用来指定需要循环处理的数据,t-as提供的是在后面用于代表当前项目的变量名。

  1. <t t-foreach="[1, 2, 3]" t-as="i">
  2. <p><t t-esc="i"/></p>
  3. </t>
  4. #上述语句输出:
  5. <p>1</p>
  6. <p>2</p>
  7. <p>3</p>

4:属性

qweb可以对属性进行实时计算并在输出时设置,通过t-attr来实现,有三种形式:

1)t-att-属性名 可以根据属性名创建一个属性:

  1. <div t-att-a="42"/> //创建属性a,属性值为42
  2. #输出
  3. <div a="42"></div>

属性值也可以为一个 格式化字符串,可以在运行期间确定具体值,作为属性值

  1. <li t-attf-class="row {{ item_parity }}">//item_parity在运行时确定值

2)t-att=mapping 如果参数是映射表,每个键值对会生成一个属性:

  1. <div t-att="{'a': 1, 'b': 2}"/>
  2. #输出
  3. <div a="1" b="2"></div>

3)t-att=pair 如果参数是元组或2个元素的数组,那么第一个项就作为属性名,第二个作为属性值:

  1. <div t-att="['a', 'b']"/>
  2. #输出
  3. <div a="b"></div>

5:设置变量

使用t-set属性来实现变量声明,它的值就是设置的变量名。然后用t-value属性的属性值作为新变量的值。

  1. <t t-set="foo" t-value="2 + 1"/>
  2. <t t-esc="foo"/>
  3. #输出3

6:调用子模板

  1. <t t-call="other-template"/>会调用指定名字的模板

三:Python专用指令

1:格式化纪录

  • t-field只能用于格式化记录字段(从browe函数获取到的),可以根据字段类型自动匹配格式
  • t-options只能用于自定义字段,最常用的是widget,其他的选项都是field-xxwidget-xx

2:在controller中渲染模版

  1. response = http.request.render('my-template', {
  2. 'context_value': 42
  3. })
  4. #会直接从controller里返回一个响应对象

3:在视图中渲染模版

ir.ui.view:中的render方法:

  • render(cr, uid, id[, values][, engine='ir.qweb][, context])
    通过view的数据库id来渲染一个qweb视图模板,模板在ir.ui.view记录会自动加载,它会为渲染环境设置一系列默认值

    • request - 当前WebRequest对象
    • debug - 当前请求是否是debug模式
    • quote_plus - 是否进行url encode转义
    • json - 相关的标准库
    • time - 相关的标准库
    • datetime - 相关的标准库
    • relativedelta - model的时间处理属性
    • keep_query - 一个keep_query函数,参数1:values-传递给qweb的上下文环境,参数2:engine (str) 用于qweb渲染的odoo模型名

四:JS专用指令

1:定义模板

  1. <templates>
  2. <t t-name="template-name">
  3. <!-- template code -->
  4. </t>
  5. </templates>

2:继承模板

模板继承是用来修改已存在的模板,即给在其他模块定义的模板添加内容。

通过t-extend来表示,它的值是被继承的模板名,通过t-jquery来进行修改。

  1. <t t-extend="base.template">
  2. <t t-jquery="ul" t-operation="append">
  3. <li>new element</li>
  4. </t>
  5. </t>

t-jquery是一个css选择器,用于选择需要改变的节点,并通过t-operation指定需要进行的操作

    • append - 新节点的内容添加到原节点的后面(最后一个子节点后)
    • prepend - 新节点内容添加到原节点前面(第一个子节点前)
    • before - 新节点内容添加到原节点前
    • after - 新节点内容添加到原节点后
    • inner - 新节点内容替换原节点的子节点replace - 新节点内容直接替换原节点
    • 如果没有指定operation,那么模板内容会被解析成javascript节点,并将context节点设置为this

五:调试指令

1:t-log

  1. <t t-log="打印信息"/>

2:断点调试t-debug

  1. <t t-if="condition">
  2. <t t-debug="">
  3. </t>

3:t-js

该节点内容里的javascript代码会在渲染时执行,接收一个context参数,将当前的环境传给js,从而可以使用context.XX调用上下文中的内容。

  1. <t t-js="ctx">
  2. console.log("var is", ctx.var);
  3. </t>

odoo开发教程八:qweb引擎的更多相关文章

  1. XAF应用开发教程(八) 汉化与多国语言支持

    使用了XAF开发时,汉化是一个比较常的问题. 要实现汉化很简单: 1.在这里下载汉化资源文件.这里演示的版本是15.1.X的 2.文件下载后将:文件解压到目录    <你的项目>\BIN\ ...

  2. odoo 开发入门教程系列-QWeb简史

    QWeb简史 到目前为止,我们的房地产模块的界面设计相当有限.构建列表视图很简单,因为只需要字段列表.表单视图也是如此:尽管使用了一些标记,如<group>或<page>,但在 ...

  3. Senparc.Weixin.MP SDK 微信公众平台开发教程(十八):Web代理功能

    在Senparc.Weixin.dll v4.5.7版本开始,我们提供了Web代理功能,以方便在受限制的局域网内的应用可以顺利调用接口. 有关的修改都在Senparc.Weixin/Utilities ...

  4. Senparc.Weixin.MP SDK 微信公众平台开发教程(八):通用接口说明

    一.基础说明 这里说的“通用接口(CommonAPIs)”是使用微信公众账号一系列高级功能的必备验证功能(应用于开发模式). 我们通过微信后台唯一的凭证,向通用接口发出请求,得到访问令牌(Access ...

  5. 微信公众平台开发教程(八)Session处理

    微信公众平台开发教程(八)Session处理 在微信窗口,输入的信息有限,我们需要将一些信息分多次请求. 比如:在进行用户绑定时,我们需要输入用户的相关信息,比如:用户名.密码,或者姓名.电话号码,服 ...

  6. 《ArcGIS Engine+C#实例开发教程》第八讲 属性数据表的查询显示

    原文:<ArcGIS Engine+C#实例开发教程>第八讲 属性数据表的查询显示 第一讲 桌面GIS应用程序框架的建立 第二讲 菜单的添加及其实现 第三讲 MapControl与Page ...

  7. iOS 11开发教程(十八)iOS11应用视图之使用代码添加按钮

    iOS 11开发教程(十八)iOS11应用视图之使用代码添加按钮 由于使用编辑界面添加视图的方式比较简单,所以不在介绍.这里,直接讲解代码中如何添加.使用代码为主视图添加一个按钮的方式和在1.3.3节 ...

  8. iOS 11开发教程(八)定制iOS11应用程序图标

    iOS 11开发教程(八)定制iOS11应用程序图标 在图1.9中可以看到应用程序的图标是网状白色图像,它是iOS模拟器上的应用程序默认的图标.这个图标是可以进行改变的.以下就来实现在iOS模拟器上将 ...

  9. odoo开发安装插件教程小技巧

    安装Odoo插件时而可能很繁琐且易于出现未知错误.当Odoo出现错误提示时.您需要深层次查询内核模块,安装其它依赖插件,下载全部插件,将它们放到恰当的部位,点安装,随后处理错误,然后再次测试,直至凡事 ...

  10. Cocos2d-x开发教程——《萝莉快跑》

    更好的阅读体验请前往<萝莉快跑>开发教程. 配置:win7+Cocos2d-x.2.0.3+VS2012 目标读者:已经了解图形显示.动作.回调函数.定时器的用法. 一.基本知识点 1.动 ...

随机推荐

  1. 设计一款可扩展和基于windows系统的一键处理表格小工具思路

    原创总结/朱季谦 设计一款可扩展和基于windows系统的一键处理表格小工具思路 日常开发当中,业务人员经常会遇到一些重复性整理表格的事情,这时候,就可以通过一些方式进行自动化程序处理,提高工作(摸鱼 ...

  2. scrcpy软件的使用

    一.scrcpy软件介绍: scrcpy是通过adb调试的方式来将手机屏幕投到电脑上,并可以通过电脑控制您的Android设备.它可以通过USB连接,也可以通过Wifi连接(类似于隔空投屏),而且不需 ...

  3. Three.js 进阶之旅:物理效果-3D乒乓球小游戏 🏓

    声明:本文涉及图文和模型素材仅用于个人学习.研究和欣赏,请勿二次修改.非法传播.转载.出版.商用.及进行其他获利行为. 摘要 本文在专栏上一篇内容<Three.js 进阶之旅:物理效果-碰撞和声 ...

  4. Laf v1.0 发布:函数计算只有两种,30s 放弃的和 30s 上线的

    一般情况下,开发一个系统都需要前端和后端,仅靠一个人几乎无法胜任,需要考虑的特性和功能非常多,比如: 需要一个数据库来存放数据: 需要一个文件存储来存放各种文件,比如图片文件: 后端需要提供接口供前端 ...

  5. keyclaok~keycloak存到cookie中的值和session_state

    keycloak存到cookie中的值 AUTH_SESSION_ID KEYCLOAK_IDENTITY KEYCLOAK_SESSION AUTH_SESSION_ID 用户的当前session_ ...

  6. 逍遥自在学C语言 | 算数运算符

    前言 一.人物简介 第一位闪亮登场,有请今后会一直教我们C语言的老师 -- 自在. 第二位上场的是和我们一起学习的小白程序猿 -- 逍遥. 二.算数运算符简介 C语言的算数运算符,是用来完成基本的算术 ...

  7. 【性能优化】优雅地优化慢查询:缓存+SQL修改组合拳

    问题描述 单例数据库模式中,后端高并发请求多(读多写少),导致数据库压力过大,关键接口响应变慢,严重影响体验. 需求 减少接口的响应时间. 寻找解决方案 由于问题主要处在数据库压力过大的情况,采用两种 ...

  8. 【入门排坑】Windows之间使用OpenSSH的ssh免密登录,排坑

    安装 安装OpenSSH 需要安装OpenSSH客户端和服务器,win10自带客户端,我们安装服务器即可. 设置 -- 应用 -- 可选功能 -- 添加 -- 添加 OpenSSH 服务器 配置 公钥 ...

  9. Mybatis中批量插入和一些问题的解决

    批量插入有三个问题,第一是执行效率,第二数据冲突,第三数据重跑更新操作. 一般对于这样的问题有以下操作方法. 第一是执行效率:mybatis支持两种高效插入. 1.mybtis的foreach标签,f ...

  10. AI时代下普通小程序员的想法

    在我接触了一系列AI技术后,不禁产生了许多思考.我先后尝试了AI编程.AI写论文.AI写小说.AI绘画等,最近看到了一些关于AI构建虚拟世界以及Auto-GPT的AI类新闻.在这个过程中,我心头涌现出 ...