Odoo表单视图中显示关联字段的其他字段值

霞舞
发布: 2025-08-19 16:08:12
原创
616人浏览过

odoo表单视图中显示关联字段的其他字段值

在Odoo中,默认情况下,关联字段通常显示其关联记录的名称。然而,有时我们需要显示关联记录的其他字段值,例如联系人的电话号码或邮箱地址。直接在表单视图中使用点号表示法 (partner_id.mobile) 并不被支持。本文将详细介绍如何通过创建关联字段来实现这一目标。

使用关联字段

实现显示关联字段的其他字段值的关键在于使用关联字段。关联字段允许你在一个模型中访问另一个模型中的字段。

步骤 1: 继承模型并添加关联字段

首先,你需要继承你想要修改的模型,并添加关联字段。例如,如果你想在销售订单(sale.order)中显示合作伙伴(res.partner)的联系人信息,你可以这样操作:

from odoo import models, fields

class SaleOrder(models.Model):
    _inherit = 'sale.order'

    cp_logistik = fields.Float(related="partner_id.cp_logistik", string="物流负责人")
    cp_finance = fields.Float(related="partner_id.cp_finance", string="财务负责人")
    cp_marketing = fields.Float(related="partner_id.cp_marketing", string="市场负责人")
登录后复制

代码解释:

  • _inherit = 'sale.order':这行代码指定了我们要继承的模型是 sale.order。
  • cp_logistik = fields.Float(related="partner_id.cp_logistik", string="物流负责人"):这行代码创建了一个名为 cp_logistik 的浮点数类型的字段。related="partner_id.cp_logistik" 指定了这个字段的值来源于 partner_id 关联的 res.partner 模型中的 cp_logistik 字段。string="物流负责人" 指定了在用户界面上显示的字段标签。
  • cp_finance 和 cp_marketing 字段的定义类似,分别关联到 partner_id 的 cp_finance 和 cp_marketing 字段。

注意: 你需要根据实际情况修改字段类型(例如 fields.Char, fields.Integer, fields.Boolean 等)以匹配关联字段的类型。string参数用于设置字段在界面上显示的标签。

步骤 2: 修改表单视图

接下来,你需要修改表单视图,将新添加的关联字段添加到视图中。

快转字幕
快转字幕

新一代 AI 字幕工作站,为创作者提供字幕制作、学习资源、会议记录、字幕制作等场景,一键为您的视频生成精准的字幕。

快转字幕 357
查看详情 快转字幕
<?xml version="1.0" encoding="utf-8"?>
<odoo>
    <record id="sale_order_form_inherit" model="ir.ui.view">
        <field name="name">sale.order.form.inherit</field>
        <field name="model">sale.order</field>
        <field name="inherit_id" ref="sale.sale_order_form"/>
        <field name="arch" type="xml">
            <notebook position="inside">
                <page string="BSP Prinsipal" name="bsp_prinsipal_page">
                    <group>
                        <field name="cp_logistik"/>
                        <field name="cp_finance"/>
                        <field name="cp_marketing"/>
                    </group>
                </page>
            </notebook>
        </field>
    </record>
</odoo>
登录后复制

代码解释:

  • <field name="inherit_id" ref="sale.sale_order_form"/>:这行代码指定了我们要继承的视图是 sale.sale_order_form,这是 Odoo 中销售订单的默认表单视图。
  • <field name="cp_logistik"/>:这行代码将我们之前在模型中定义的 cp_logistik 字段添加到表单视图中。由于它是关联字段,它将显示与当前销售订单关联的合作伙伴的 cp_logistik 字段的值。
  • cp_finance 和 cp_marketing 字段的添加方式类似。

重要提示:

  • 确保在 XML 文件中正确引用了要继承的视图 (inherit_id)。
  • 确保在模型中定义的字段名与在视图中使用的字段名一致。
  • 根据实际需求调整字段在视图中的位置和分组。

步骤 3: 更新模块

完成以上步骤后,更新你的 Odoo 模块,以使更改生效。

总结

通过创建关联字段,你可以轻松地在 Odoo 表单视图中显示关联记录的任何字段值。这种方法避免了直接在视图中使用点号表示法,提高了代码的可维护性和可读性。记住,要根据实际情况调整字段类型和视图结构,以满足你的特定需求。这种方法不仅适用于销售订单,也适用于其他任何需要显示关联字段信息的Odoo模块。

以上就是Odoo表单视图中显示关联字段的其他字段值的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号