depends()装饰器
计算字段的值通常取决于计算记录中其他字段的值。ORM希望开发人员使用装饰器depends()在计算方法中指定这些依赖关系。给定的依赖关系由ORM使用来触发字段的重新计算,只要其中一些依赖关系已被修改:
from odoo import api, fields, models
class TestComputed(models.Model):
_name = "test.computed"
total = fields.Float(compute="_compute_total")
amount = fields.Float()
@api.depends("amount")
def _compute_total(self):
for record in self:
record.total = 2.0 * record.amount
当字段amout发生改变时,执行_compute_total函数,total的值会随之变化。
反函数
计算字段默认情况下是只读的。这是预期的,因为用户不应该设置值。在某些情况下,直接设置值仍然很有用。为了支持这一点,Odoo 提供了使用inverse函数。
class TestComputed(models.Model):
_name = "test.computed"
total = fields.Float(compute="_compute_total", inverse="_inverse_total")
amount = fields.Float()
@api.depends("amount")
def _compute_total(self):
for record in self:
record.total = 2.0 * record.amount
def _inverse_total(self):
for record in self:
record.amount = record.total / 2.0
onchage()触发器
‘onchange’ 机制提供了一种方法,使得客户端界面在用户填写字段值时,无需将任何内容保存到数据库即可更新表单。为了实现这一点,我们定义一个方法,其中self表示表单视图中的记录,并使用onchage()进行修饰,以指定触发它的字段。您对self进行的任何更改都将反映在表单上:
from odoo import api, fields, models
class TestOnchange(models.Model):
_name = "test.onchange"
name = fields.Char(string="Name")
description = fields.Char(string="Description")
partner_id = fields.Many2one("res.partner", string="Partner")
@api.onchange("partner_id")
def _onchange_partner_id(self):
self.name = "Document for %s" % (self.partner_id.name)
self.description = "Default description for %s" % (self.partner_id.name)
在这个例子中,改变合作伙伴也会改变名称和描述的值。用户可以选择是否在之后改变名称和描述的值。还要注意的是,我们不会在self上循环,因为该方法只在表单视图中触发,而self始终是单个记录。
欢迎加群一起讨论DTCloud 4实施开发。
群号:557402829