ODOO12图书项目原模型继承

学习项目-继承图书馆应用
在前面我们创建了一个图书应用的初始模块,可供查看图书目录。现在我们要创建一个library_member模块,来对图书应用进行扩展以让图书会员可以借书。它继承 Book 模型,并添加一个图书是否可借的标记。该信息将在图书表单和图书目录页显示。
应添加图书会员主数据模型Member,类似 Partner 来存储个人数据,如姓名、地址和 email,还有一些特殊字段,如图书会员卡号。最有效的方案是代理继承,自动创建图书会员记录并包含关联 Partner 记录。该方案使得所有的Partner 字段在 Member 中可用,没有任何数据结构上的重复。
我们还要在借书表单中为会员提供消息和社交功能,包括计划活动组件来实现更好地协作。我们还要添加会员从图书馆中借书的功能,但暂不涉及。以下是当前所要修改内容的总结:

  1. 图书
    添加一个Is Available? 字段。现在通过手动管理,以后会自动化
    扩展 ISBN 验证逻辑来同时支持10位数的ISBN
    扩展图书目录页来分辨不可借阅图书并允许用户过滤出可借图书
  2. 会员
    添加一个新模型来存储姓名、卡号和 Email、地址一类的联系信息添加社交讨论和计划活动功能

首先在library_app同级目录创建一个library_member目录来作为扩展模块,并在其中添加两个文件,一个__init__.py空文件和一个包含如下内容的__manifest__.py文件:

{
'name': 'Library Members',
'description': 'Manage people who will be able to borrow books.',
'author': 'Daniel Reis',
'depends': ['library_app'],
'application': False,
}

ODOO12图书项目原模型继承
第一步我们来为Book模型添加is_available布尔型字段。这里使用经典的 in-place 模型继承。该字段值可通过图书借出和归还记录自动计算,但现在我们先使用普通字段。要继承已有模型,需要在 Python 类中添加一个_inherit 属性来标明所继承的模型。新类继承父 Odoo 模型的所有功能,仅需在其中声明要做的修改。在任何地方使用该模型修改都可用,可以认为这类继承是对已有模型的引用并在原处做了一些修改。
为模型添加字段
通过 Python 类来新建模型,继承模型同样是通过 Python 以及 Odoo 自有的继承机制,即_inherit 类属性。该属性标明所继承的模型。新的类继承父 Odoo 模型的所有功能,仅需声明要做修改的部分。编码指南推荐为每个模型创建一个 Python 文件,因此我们添加library_member/models/library_book.py文件来继承原模型,首先创建__init__.py文件来导入该文件:

1、添加library_member/init.py文件来导入 models 子文件夹

from . import models

2、添加library_member/models/init.py文件子文件夹中的代码文件:

from . import library_book

3、创建library_member/models/library_book.py文件来继承library.book模型:

from odoo import fields, models


class Book(models.Model):
    _inherit = 'library.book'
    is_available = fields.Boolean('Is Available?')

使用_inherit类属性来声明所继承模型。注意我们并没有使用到其它类属性,甚至是_name 也没使用。除非想要做出修改,否则不需要使用这些属性。
可以把这个想成是对模型定义的一个引用,在原处做了一个修改。可以添加字段、修改已有字段、修改模型类属性甚至是包含业务逻辑的方法。要在数据表中添加新的模型字段需要安装该模块。
刷新本地模块后,即可找到我们刚创建的模块,然后点击安装
在这里插入图片描述
如果一切顺利,通过设置>技术>数据库结构>模型菜单查看library.book模型即可看到该字段。
在这里插入图片描述
修改已有字段
通过上面部分可以看到向已有模型添加新字段非常简单。有时还要对已有字段进行修改,也非常简单。在继承模型时,可对已有字段叠加修改,也就是说仅需定义要增加或修改的字段属性。
我们将对原来创建的library_app模块的 Book模型做两处简单修改:

  • 为isbn字段添加一条提示,说明同时支持10位数的 ISBN(稍后会实现该功能)
  • 为publisher_id字段添加数据库索引,以提升搜索效率

编辑library_member/models/library_book.py文件,并在library.book 模型中添加如下代码:

isbn = fields.Char(help="Use a valid ISBN-13 or ISBN-10.")
publisher_id = fields.Many2one(index=True)

这会对字段进行指定属性修改,未涉及的属性不会被修改。升级模块,进入图书表单,将鼠标悬停在 ISBN 字段上,就可以看到所添加的提示信息了。
在这里插入图片描述
index=True这一修改不太容易发现,通过设置>技术>数据结构>模型菜单下的字段定义中可进行查看。
在这里插入图片描述
视频演示:
http://www.tderp.com/download/details/odoo12-860
http://ctdrive.tderp.com/file/13502532-467429166

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

r_nznf

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值