上一篇内容:如何快速在odoo中创建自己的菜单

前言

上面的内容我们已经学会了如何去创建odoo的菜单,下面我们要学习的是odoo的基础视图tree视图,我们的目标是实现型号管理的列表页面

创建model

之前我们已经学了简单的创建了一个菜单,我们也知道了视图的渲染是离不开model的支持的,我们现在的目标是在型号管理中创建tree视图,那么我们就要先创建型号管理对应的model

电商中都有SPU和SKU的概念,这里我们就以手机为举例,那么一个手机型号就是一个简单的SPU,对应手机的不同的颜色和对应的内存大小等不同的参数所产生的商品那么就是SKU(SKU是物理上不可分割的最小存货单元

  • SPU:iphoneXs
  • Sku:32G, 金色
  • 品牌:苹果

那么我们就可以创建一个简单的model(写在model.py中)

class GoodsSpu(models.Model):
"""
型号表
"""
_name = "fandx.goods.spu" name = fields.Char("商品名称")
code = fields.Char("商品编号")
brand_id = fields.Many2one("fandx.brands", "品牌") create_date = fields.Datetime("创建时间", default=datetime.now())

odoo的orm方法会在以后的教程中进行讲解,现在我们可以理解为创建了一个数据表

  • 表名:fandx_goods_spu

  • name字段:varChar类型

  • code字段:varChar类型

  • brand_id字段:外键字段,所以这里是int类型

  • create_date字段:datetime类型

创建act_window和menu

在我们创建了model下面的目标就是在页面中去渲染上面的几个字段的数据

既然要渲染数据库,odoo中不管什么视图,都要去创建基础的act_windows视图和menu菜单

  • 在views文件夹中创建goods.xml文件

    <odoo>
    <record id="goods_spu_action" model="ir.actions.act_window">
    <field name="name">型号管理</field>
    <field name="type">ir.actions.act_window</field>
    <field name="res_model">fandx.goods.spu</field>
    <field name="view_mode">tree</field>
    </record>
    </odoo>
  • 注意:

    • res_model要写刚才创建的model的名称
    • view_mode要写上tree视图
  • 修改menuitem菜单中action

    <odoo>
    <menuitem name="FANDX仓库" id="fandx_stock.menu_root"/>
    <menuitem name="品牌管理" id="fandx_stock.menu_1" parent="fandx_stock.menu_root" action="brand_action"/>
    <menuitem name="型号管理" id="fandx_stock.menu_2" parent="fandx_stock.menu_root" action="goods_spu_action"/>
    <menuitem name="SKU管理" id="fandx_stock.menu_3" parent="fandx_stock.menu_root" action="brand_action"/>
    </odoo>

创建tree视图代码

下面就是我们这次的重头戏了创建tree视图代码

  • 继续在goods.xml中在act_window上面添加代码

    <record id="goods_spu_view_tree" model="ir.ui.view">
    <field name="name">型号管理列表</field>
    <field name="model">fandx.goods.spu</field>
    <field name="arch" type="xml">
    <tree>
    <field name="name"/>
    <field name="brand_id" />
    <field name="code" />
    <field name="create_date" />
    </tree>
    </field>
    </record>
    <record id="goods_spu_action" model="ir.actions.act_window">
    <field name="name">型号管理</field>
    <field name="type">ir.actions.act_window</field>
    <field name="res_model">fandx.goods.spu</field>
    <field name="view_mode">tree,form</field>
    </record>
  • 非常简单,在record中大部分都是固定写法,在tree标签中写上对应的字段名称即可

  • 注意点

    • <field name="model">模型名称</field> 模型名称一定要一致并且不能写错,因为odoo会根据Model的对应到对应的view视图
    • tree标签,这是tree视图的标志,不可以少
    • tree标签中的field,name等于值和数据库的字段名要一致才能正确渲染

修改security权限

上面的工作做完,有的小伙伴可以尝试的更新了自己的模块,发现自己的菜单还不见了,odoo中的所有模型在分配之后都会基于权限进行页面渲染,所以这里需要给fandx_goods_spu赋予权限

  • 在security文件夹下的ir.model.access.csv文件添加内容

    ......
    access_fandx_goods_spu,fandx_stock.fandx_goods_spu,model_fandx_goods_spu,base.group_user,1,1,1,1

大功告成

去应用中找到自己的模块升级一下看看是否显示正常

odoo视图入门学习- tree视图的使用的更多相关文章

  1. odoo开发笔记--from视图隐藏顶部&tree视图保留

    场景描述: 开发过程中,有时候我们需要去除odoo自带的一些样式, 比如,form视图,要集成自定义的界面时,就希望把顶部的服务动作 和 分页按钮 隐藏掉. 处理方式: 分两种情况: 1. 保留顶部区 ...

  2. Odoo 二次开发教程(三)-第一个Model及Form、Tree视图

    创建完我们的模块,接下来我们就要为我们的模块添加一些对象.今天我们将要创建一个学生对象(tech.student)和一些基本的属性,并将用form和tree视图将其展示出来: 一. 创建tech.st ...

  3. 第15.18节 PyQt(Python+Qt)入门学习:Model/View架构中视图Item Views父类详解

    老猿Python博文目录 老猿Python博客地址 一.概述 在PyQt图形界面中,支持采用Model/View架构实现数据和界面逻辑分离,其中Model用于处理数据存储,View用于界面数据展现,当 ...

  4. openerp学习笔记 视图(tree\form)中隐藏按钮( 创建、编辑、删除 ),tree视图中启用编辑

    视图(tree\form)中隐藏按钮( 创建.编辑.删除 )create="false" edit="false" delete="false&quo ...

  5. 【转】MYSQL入门学习之十:视图的基本操作

    转载地址:http://www.2cto.com/database/201212/176775.html 一.视图的基本介绍  www.2cto.com           视图是虚拟的表.与包含数据 ...

  6. odoo开发笔记 -- tree视图按指定字段group_by分组显示

    注意点: view视图文件中的搜索视图要放在action视图的前边. 在action视图中,要写search_view_id, 还有context, search_default_group_by_字 ...

  7. 06 数据库入门学习-视图、sql注入、事务、存储过程

    一.视图 1.什么是视图 视图本质是一张虚拟的表 2.为什么要用 为了原表的安全 只要有两大功能 1.隐藏部分数据,开放指定数据 2.视图可以将查询结果保存,减少sql语句的次数 特点: 1.视图使用 ...

  8. 第十章 Odoo 12开发之后台视图 - 设计用户界面

    本文将学习如何为用户创建图形化界面来与图书应用交互.我们将了解不同视图类型和小组件(widgets)之间的差别,以及如何使用它们来提供更优的用户体验. 本文主要内容有: 菜单项 窗口操作(Window ...

  9. 第十一章 Odoo 12开发之看板视图和用户端 QWeb

    QWeb 是 Odoo 使用的模板引擎,它基于 XML 来生成 HTML 片断和页面.通过 QWeb可生成内容丰富的看板(Kankan)视图.报表和 CMS 网页.本文中我们将学习QWeb 语法以及如 ...

随机推荐

  1. 华盛顿邮报专访:SPC能否再掀起币圈新浪潮?

    近日,美国知名媒体华盛顿邮报对话NGK灵石团队技术副总裁Daphne Patel女士,对话主题为"SPC能否再掀起币圈新浪潮".此次对话以问答的形式展开,将SPC的最新情况呈现在你 ...

  2. 【Python】set 与 list ——如何对列表进行去重?

    在Python中,形如 {1,2,3,4,5} 这样的数据类型叫做"集合",外形酷似列表list [1,2,3,4,5] 但是集合与列表有很多区别,具体表现在以下几方面: List ...

  3. Python算法_三种斐波那契数列算法

    斐波那契数列(Fibonacci sequence),又称黄金分割数列.因数学家列昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入,故又称为"兔子数列&qu ...

  4. iframe页面刷新

    //方法1 document.getElementById('FrameID').contentWindow.location.reload(true); //方法2 document.getElem ...

  5. Guava - LoadingCache实现Java本地缓存

    前言 Guava是Google开源出来的一套工具库.其中提供的cache模块非常方便,是一种与ConcurrentMap相似的缓存Map. 官方地址:https://github.com/google ...

  6. wxWidgets源码分析(8) - MVC架构

    目录 MVC架构 wxDocManager文档管理器 模板类创建文档对象 视图对象的创建 创建顺序 框架菜单命令的执行过程 wxDocParentFrame菜单入口 wxDocManager类的处理 ...

  7. 力扣496. 下一个更大元素 I

    原题 1 class Solution: 2 def nextGreaterElement(self, nums1: List[int], nums2: List[int]) -> List[i ...

  8. Spring MVC 配置记录

    目录 1.从pom.xml配置Maven文件开始 2.web.xml 3.springmvc-config.xml 4.controller 使用 idea 编辑器 + Maven + spring ...

  9. 【Arduino学习笔记02】第一个Arduino项目——点亮LED Blink.ino程序解读 Arduino程序基本结构 pinMode() digitalWrite() delay()

    /* Blink Turns an LED on for one second, then off for one second, repeatedly. */// define variables ...

  10. add_header被覆盖 -配置错误

    Nginx的配置文件分为Server.Location.If等一些配置块,并且存在包含关系,和编程语言比较类似.如果在外层配置的一些选项,是可以被继承到内层的. 但这里的继承也有一些特性,比如add_ ...