odoo自定义视图

为了让教程更易懂,我们将使用一个简化的例子:创建一个“员工生日列表”视图。这个例子将帮助初学者理解如何在Odoo中创建自定义视图,展示每个员工的姓名和生日。

假设我们有一个employee模块,里面有一个employee模型,包含name(姓名)和birthday(生日)字段。

目标是创建一个新视图,展示所有员工的姓名和生日,并能够按月份对生日进行分组展示。

1. 定义新视图类型

首先,我们需要在ir.ui.view中添加一个新的视图类型birthday_list

class View(models.Model):
    _inherit = 'ir.ui.view'
    
    type = fields.Selection(selection_add=[('birthday_list', 'Birthday List')])
2. 新增视图模式

然后,在ir.actions.act_window.view中新增一个视图模式,以便我们可以在动作窗口中使用这个新的视图类型:

class ActWindowView(models.Model):
    _inherit = 'ir.actions.act_window.view'
    
    view_mode = fields.Selection(selection_add=[('birthday_list', 'Birthday list')],
                                 ondelete={'birthday_list': 'cascade'})
3. 实现数据获取逻辑

我们需要一种方式来组织数据,使其能够按员工的生日月份分组展示:

class Employee(models.Model):
    _inherit = 'employee'
    
    @api.model
    def get_birthday_data(self):
        employees = self.search([])
        result_dict = {}
        for emp in employees:
            month = emp.birthday.month if emp.birthday else 'Unknown'
            if month not in result_dict:
                result_dict[month] = []
            result_dict[month].append({
                'name': emp.name,
                'birthday': emp.birthday,
            })
        return result_dict
4. 实现前端JavaScript代码

为了能够在前端展示这些分组数据,我们需要创建几个JavaScript文件来处理模型、视图、控制器、渲染逻辑。

model.js:

odoo.define('employee.BirthdayListModel', function (require) {
    'use strict';
    
    var AbstractModel = require('web.AbstractModel');
    
    var BirthdayListModel = AbstractModel.extend({
        // Model implementation
    });
    
    return BirthdayListModel;
});

controller.js, renderer.js, 和 view.js 文件类似地实现对应的功能,处理用户交互和数据的渲染。

5. 创建QWeb模板

创建一个QWeb模板来定义视图的HTML结构:

<t t-name="BirthdayListView">
    <div class="o_birthday_list_view">
        <!-- 这里定义视图的HTML结构和数据绑定 -->
    </div>
</t>
6. 注册和使用新视图

最后,在模块的XML文件中注册新的视图,并为employee模型添加这个新视图:

<record id="employee_birthday_list_view" model="ir.ui.view">
    <field name="name">Employee Birthday List</field>
    <field name="model">employee</field>
    <field name="arch" type="xml">
        <birthday_list>
            <!-- 视图配置 -->
        </birthday_list>
    </field>
</record>

在动作中添加birthday_list视图模式,以便用户可以通过UI访问它:

<field name="view_mode">list,birthday_list,form</field>
  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在Odoo中新建自定义视图,需要进行以下操作: 1. 在odoopython代码中增加新视图类型与视图模式。这可以通过在ir_actions_act_window.py和ir_ui_view.py文件中添加相关代码来实现。例如,在ir_actions_act_window.py文件中,我们可以增加以下代码来定义新的视图模式: ``` # -*- coding: utf-8 -*- from odoo import fields, models class ActWindowView(models.Model): _inherit = 'ir.actions.act_window.view' view_mode = fields.Selection(selection_add=[('eview', 'echart views')]) ``` 在ir_ui_view.py文件中,我们可以添加以下代码来定义新的视图类型: ``` # -*- coding: utf-8 -*- from odoo import fields, models class View(models.Model): _inherit = 'ir.ui.view' type = fields.Selection(selection_add=[('eview', 'echart views')]) ``` 这样,Odoo就可以识别我们新定义的视图类型。 2. 定义js相关文件和模板代码。通过编写相应的javascript文件和模板代码,我们可以实现对自定义视图的布局和行为的控制。这些文件需要与新定义的视图类型相关联,并与视图模板文件进行交互。具体的实现方法可以根据项目需求和技术要求来确定。 这样,在执行以上操作之后,就可以在Odoo中创建自定义视图了。自定义视图可以根据具体需求来设计和实现,包括自定义的布局、交互和样式等方面 。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Odoo自定义视图教程](https://blog.csdn.net/u012739578/article/details/121670077)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值