odoo二次开发教程odoo

【odoo二次开发】ORM框架(二、Model方法及api装饰器

2017-06-25  本文已影响671人  胡传伟1994

介绍

二开时模型创建完毕并配好视图后对于基本的CRUD操作不需要再在代码中实现,框架会自动提供这些功能,但如果我们的开发需求不仅仅是对当前对象的CRUD时,就需要在框架原来方法的基础上扩展出一些自己所需要的操作。
odoo8以前与odoo8以后使用两种不同的model接口形式(odoo8两者都可使用),odoo8以前old api中,记录ids和上下文环境均通过参数传入def old_api (self, cr, uid, ids, context),比较凌乱,不建议使用。以下内容均为new api内容。

api装饰器

@api.model

封装不关联数据记录的Model对象,用于与数据库记录无关的逻辑方法,例如:create方法。

@api.multi

封装关联多个数据记录的Model对象,用于与数据库记录关联的处理方法。

@api.one

封装关联单条数据记录的Model对象,用于与单条数据库记录关联的处理方法。

@api.onchange

页面Fields值变更触发的调用方法,见下文中onchange

@api.constrains

对添加数据自定义约束。

@api.constrains(‘field_name1’,’field_name2’,…) def _check_field(self):
# 校验方法 不符合校验条件抛出异常

model方法

create 创建记录

原型:def create(self, vals)
vals:记录属性值字典

search 查找记录

原型:def search(self, args, offset=0, limit=None, order=None, count=False)
args:domain格式的条件列表;offset:结果忽略条数;limit:最大查询条数

read 读取记录属性值

返回指定ids记录的指定fields字段值,采用列表加字典的数据结构([{},{},…])返回。
原型:def read(self, fields=None, load='_classic_read'):
fields:列表可指定要读取的属性名称

search_read

原型:def search_read(self, domain=None, fields=None, offset=0, limit=None, order=None)
用法即search方法与read方法相结合。

unlink 删除记录

原型:def unlink(self)

write 修改记录

原型:def write(self, vals)
vals:修改属性值字典

onchange 页面变更触发事件

页面Field值发生变更时由前端js框架触发调用,一般用于控制页面元素联动。
原型:def onchange(self, values, field_name, field_onchange)

default_get 设置缺省值

原型:def default_get(self, fields_list)

name_get 设置记录显示名

原型:def name_get(self)

上一篇下一篇

猜你喜欢

热点阅读