为了账号安全,请及时绑定邮箱和手机立即绑定

Odoo:当many2one字段发生变化时如何清除many2many字段?

Odoo:当many2one字段发生变化时如何清除many2many字段?

胡说叔叔 2024-01-27 15:00:07
我是 odoo 的新手。我使用的是odoo 13,我有一个many2one字段和一个many2many字段,其中域位于many2one字段上。我需要的是,如果用户更改 Many2one 字段,则 Many2Many 会变空并准备好选择。但我不知道如何在函数上编写代码,所以我尝试了一些变体,但它就是不适合我。如果我使用这个,当我第一次选择“工业”字段时,我就会收到一个错误class Partner(models.Model):    _inherit = 'res.partner'    industria = fields.Many2one('industria_model', string="Industria")    marca = fields.Many2many('marca_model',                             domain="[('industria_id', '=', industria)]", string="Marca")    @api.onchange('industria')    def get_price(self):        self.marca = [(5)]        # if self.marca:        #     self.marca = [(5, 0, 0)]
查看完整描述

4 回答

?
繁星点点滴滴

TA贡献1803条经验 获得超3个赞

为了擦除或重置 odoo 中的 Many2one 字段,我们可以使用一个简单的 onchange 函数并将 false 传递给字段,如 my_many2one_field = False 例如:


shop_product_id = fields.Many2one('product.product')

my_many2one_field = fields.Many2one('res.company')

@api.onchange('shop_product_id')

def reset_my_many2one(self):

   self.my_many2one_field = False

   #return something

每次 shop_product_id 更改时,my_many2one 都会从之前的选择中重置。


查看完整回答
反对 回复 2024-01-27
?
MMTTMM

TA贡献1869条经验 获得超4个赞

最后我用了这个

@api.onchange('industria')
    def change_brand(self):
        self.marca = [(6, 0, [])]

我已经测试过它,但我必须重新启动 odoo 才能看到更改,仅更新模块不起作用


查看完整回答
反对 回复 2024-01-27
?
绝地无双

TA贡献1946条经验 获得超4个赞

您可以通过以下 3 种方式删除您的 Many2many 记录:


@api.onchange('industria')

def change_brand(self):

    for rec in self.marca:

        self.marca = [(3, rec.id, 0)] # only delete this record from m2m field

        # self.marca = [2,rec.id,0] 

        # self.marca = [5,0,0] 

[(3,rec.id,0)]表示该记录仅从表单视图中删除,但在用户单击保存或创建按钮之前它一直在相关表中,[2,rec.id,0]表示该记录从表和视图中,[5,0,0] 删除表和表单视图中的所有多对多记录。我使用了所有这些并且它们起作用了。希望它有用:)


查看完整回答
反对 回复 2024-01-27
?
慕少森

TA贡献2019条经验 获得超9个赞

[(5)]将被评估,[5]然后 Odoo 将尝试返回尚未创建的相应记录(第一次),您应该看到以下错误:

Record does not exist or has been deleted. (Record: marca_model(5,),

您只需使用[(5,)]清空该marca字段即可。

如果数据库中存在 id 5 的记录,您将得到与使用相同的结果[(4, 5)]


查看完整回答
反对 回复 2024-01-27
  • 4 回答
  • 0 关注
  • 198 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信