宜兴通达竭诚为您服务。

通达科技 - 宜兴电脑维护及IT服务外包服务商

第15章:QWeb简史
  • 上传者: Administrator
  • 上传时间:2023年12月04日 23时44分53秒
摘要:
到目前为止,我们的房地产模块的界面设计相当有限。构建列表视图很简单,因为只需要字段列表。对于表单视图也是如此:尽管使用了一些标签,如  <group>  或  <page>  ,但在设计方面几乎没有什么可做的。 然而,如果我们想要为我们的应用程序提供独特的外观,那么需要更进一步,能够设计新的视图。此 ......
正文 相关文章 请喝咖啡

    到目前为止,我们的房地产模块的界面设计相当有限。构建列表视图很简单,因为只需要字段列表。对于表单视图也是如此:尽管使用了一些标签,如 <group> 或 <page> ,但在设计方面几乎没有什么可做的。

    然而,如果我们想要为我们的应用程序提供独特的外观,那么需要更进一步,能够设计新的视图。此外,其他功能,如PDF报告或网站页面,需要使用更灵活的工具来创建:模板引擎。

    你可能已经熟悉了一些现有的模板引擎,比如Jinja(Python)、ERB(Ruby)或Twig(PHP)。Odoo自带了自己的内置引擎: QWeb模板 。QWeb是Odoo使用的主要模板引擎。它是一个XML模板引擎,主要用于生成HTML片段和页面。

    你可能已经在Odoo中遇到过 看板 _,其中记录以类似卡片的结构显示。我们将为我们的房地产模块构建这样的视图。

    具体示例:看板视图

    参考: 有关此主题的文档可以在 看板 中找到。

     注解

    目标:在本节结束时,应该创建一个属性的看板视图:

    看板视图

    在我们的房地产应用中,我们想要添加一个看板视图来显示我们的属性。看板视图是标准的Odoo视图(就像表单和列表视图一样),但它们的结构更加灵活。实际上,每个卡片的结构是表单元素(包括基本的HTML)和QWeb的混合。看板视图的定义类似于列表和表单视图的定义,只是它们的根元素是 <kanban> 。在最简单的形式下,看板视图如下所示:

    <kanban>
        <templates>
            <t t-name="kanban-box">
                <div class="oe_kanban_global_click">
                    <field name="name"/>
                </div>
            </t>
        </templates>
    </kanban>
    

    让我们分解这个例子:

    • <templates>:定义了一个 QWeb模板 模板列表。看板视图 必须 定义至少一个根模板 kanban-box,每个记录将渲染一次。

    • <t t-name="kanban-box"><t> 是 QWeb 指令的占位符元素。在这个例子中,它用于将模板的 name 设置为 kanban-box

    • <div class="oe_kanban_global_click">oe_kanban_global_click 使 <div> 可点击以打开记录。

    • <field name="name"/>:这将在视图中添加``name``字段。

     Exercise

    创建一个最小化看板视图。

    使用提供的简单示例,为属性创建一个最小的看板视图。唯一要显示的字段是 name

    提示:您必须在相应的 ir.actions.act_window 的 view_mode 中添加 kanban 。

    一旦看板视图正常工作,我们可以开始改进它。如果我们想要有条件地显示一个元素,我们可以使用 t-if 指令(参见 条件语句)。

    <kanban>
        <field name="state"/>
        <templates>
            <t t-name="kanban-box">
                <div class="oe_kanban_global_click">
                    <field name="name"/>
                </div>
                <div t-if="record.state.raw_value == 'new'">
                    This is new!
                </div>
            </t>
        </templates>
    </kanban>
    

    我们添加了一些内容:

    • t-if:如果条件为真,则渲染``<div>``元素。

    • record:一个具有所有请求字段作为其属性的对象。每个字段都有两个属性``value``和``raw_value``。前者根据当前用户参数进行格式化,而后者是来自于:meth:`~odoo.models.Model.read`的直接值。

    在上面的例子中,字段 name 被添加在 <templates> 元素中,但是 state 在其外部。当我们需要一个字段的值,但不想在视图中显示它时,可以将其添加到 <templates> 元素之外。

     Exercise

    改进看板视图。

    将以下字段添加到看板视图中:期望价格、最佳价格、销售价格和标签。请注意:只有在收到报价时才会显示最佳价格,而只有在接受报价时才会显示销售价格。

    请参考本节的 目标 以获取视觉示例。

    让我们给我们的视图添加最后的修饰:属性默认情况下必须按类型分组。您可能想查看 看板 中描述的各种选项。

     Exercise

    添加默认分组。

    使用适当的属性默认按类型分组属性。您还必须防止拖放。

    请参考本节的 目标 以获取视觉示例。

    看板视图是一个典型的例子,说明从现有视图开始微调而不是从头开始总是一个好主意。有许多选项和类可用,所以…阅读并学习!

    本文章从网上收集,如有侵权请联系tderp@tderp.com删除
  • 微信扫一扫,一分也是爱:
  • 微信

服务原则及地区范围

宜兴通达网络科技有限公司,地处中国宜兴环科园内,是一家高新技术企业。公司在企业网络维护和企业信息化建设与咨询方面,有10多年经验。

我公司愿与客户一道,力求彻底解决客户问题!
我们不是在给企业提供“头痛医头、脚痛医脚”的暂时解决方案,而是在部署根本性安全与稳定服务!!
我们愿携手客户,建立企业IT规划;杜绝随意安装系统、软件等操作;力求共同维护有序、安全、稳定的网络办公环境!!!
IT服务,服务是根本,客户是上帝;我们提供快速响应、快速上门、快速排查,提供优质高效的服务!!!!

通达科技提供全国范围内的服务,服务形式包括远程协助、电话咨询、电子邮件咨询、传真咨询、问答平台的问题解决等。

宜兴地区提供上门服务:

  • 市区服务:宜城街道、城北街道(屺亭街道)、新街街道、新庄街道、环科园、渚桥开发区
  • 市郊服务:张渚镇、西渚镇、太华镇、徐舍镇、官林镇、杨巷镇、新建镇、和桥镇、高塍镇、万石镇、周铁镇、芳桥镇、丁蜀镇、湖父镇。
  • 联系电话:189-21-343434
  • 在线沟通: