odoo的One2many或者many2many表的字段获取父级表字段作为domain的条件

在Odoo中,直接使用x2many字段的父表字段作为domain筛选条件并不支持。但有两种解决方案:1) 利用`parent`关键字在Python和XML中引用父表字段;2) 在子表中创建计算字段related来引用父表字段,但可能需要为每个字段创建单独的计算字段。这些方法可以帮助你在需要时灵活地使用父表字段。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

x2many的字段的父级表中的字段,不能直接作为domain的筛选条件使用。但是有时候又会遇到需要使用父级表字段的场景。
解决办法一:
利用parent去找父级表的字段,这个用法的好处是前后端都适用,具体使用方式如下:
python:

domain="[('当前表字段', '条件', parent.父表字段)]"

xml:

<field name="父表x2many字段">
                                    <tree>
                                        <field name="子表字段名"  
                                               attrs="{'readonly': [('parent.父表字段名', '!=', 'draft')]}"
                                        />
                                    </tree>
                                </field>

解决办法二:
子表中用计算字段related将父表中的字段值引用到子表,这种方式的缺点是,如果使用到多个字段,子表需要定义多个计算字段

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值