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

前言

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

创建model

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

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

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

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

  1. class GoodsSpu(models.Model):
  2. """
  3. 型号表
  4. """
  5. _name = "fandx.goods.spu"
  6. name = fields.Char("商品名称")
  7. code = fields.Char("商品编号")
  8. brand_id = fields.Many2one("fandx.brands", "品牌")
  9. 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文件

    1. <odoo>
    2. <record id="goods_spu_action" model="ir.actions.act_window">
    3. <field name="name">型号管理</field>
    4. <field name="type">ir.actions.act_window</field>
    5. <field name="res_model">fandx.goods.spu</field>
    6. <field name="view_mode">tree</field>
    7. </record>
    8. </odoo>
  • 注意:

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

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

创建tree视图代码

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

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

    1. <record id="goods_spu_view_tree" model="ir.ui.view">
    2. <field name="name">型号管理列表</field>
    3. <field name="model">fandx.goods.spu</field>
    4. <field name="arch" type="xml">
    5. <tree>
    6. <field name="name"/>
    7. <field name="brand_id" />
    8. <field name="code" />
    9. <field name="create_date" />
    10. </tree>
    11. </field>
    12. </record>
    13. <record id="goods_spu_action" model="ir.actions.act_window">
    14. <field name="name">型号管理</field>
    15. <field name="type">ir.actions.act_window</field>
    16. <field name="res_model">fandx.goods.spu</field>
    17. <field name="view_mode">tree,form</field>
    18. </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文件添加内容

    1. ......
    2. 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. 10_MySQL数据表的基本查询

    为了更好的练习数据表的操作,我们需要有些数据来供我们练习,这里给大家分享一份数据,大家可以拿去自己练习使用. 文件地址:https://files.cnblogs.com/files/waterr/d ...

  2. vscode 配置表

    { "git.ignoreMissingGitWarning": true, "editor.multiCursorModifier": "ctrlC ...

  3. 五分钟学会generator函数

    什么是generator函数? 常规函数只会返回一个单一值(或者不返回任何值). 而 Generator 可以按需一个接一个地返回("yield")多个值.它们可与 iterabl ...

  4. JSON的stringify和parse方法

    一.JSON.parse() 方法用于将一个 JSON 字符串转换为对象. 以下代码为将字符串解析为对象,然后再赋值给对象 //页面初始化完成加载,option是传递的参数 onLoad: funct ...

  5. Python镜像源集合——镜像源更改方法

    python在线安装库时会较慢,那是因为python的默认镜像源在国外,因此会慢:而国内有很多可以用的python镜像源,将python镜像源更改为国内的,则可以大大加快python库的安装速度. 1 ...

  6. WPF -- DataTemplate与ControlTemplate结合使用

    如深入浅出WPF中的描述,DataTemplate为数据的外衣,ControlTemplate为控件的外衣.ControlTemplate控制控件的样式,DataTemplate控制数据显示的样式,D ...

  7. CentOS7 下Docker最新入门教程 超级详细 (安装以及简单的使用)

    转载https://blog.csdn.net/wzsy_ll/article/details/82866627 1.为什么使用Docker(本人) 最近总是频繁的在新服务器发布项目, 每次发布都需要 ...

  8. 一个页面中多个window.onload = function(){}冲突问题解决思路

    转: 一个页面中多个window.onload = function(){}冲突问题解决思路 一个页面中多个window.onload = function(){}冲突问题解决思路 参考文章: (1) ...

  9. 10万级etl调度软件Taskctl-web版免费授权及产品功能特性

    转: 10万级etl调度软件Taskctl-web版免费授权及产品功能特性 初识Taskctl-Web版 Taskctl Free应用版原型是在原有商用版Taskctl 6.0衍生扩展开发出的专门为批 ...

  10. Linux Kernel 0.12 启动简介,调试记录(Ubuntu1804, Bochs, gdb)

    PS:要转载请注明出处,本人版权所有. PS: 这个只是基于<我自己>的理解, 如果和你的原则及想法相冲突,请谅解,勿喷. 前置说明   本文作为本人csdn blog的主站的备份.(Bl ...