上一篇内容:如何快速在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. SVG 2 & SVG & getPointAtLength & getPathSegAtLength

    SVG 2 & SVG & getPointAtLength & getPathSegAtLength getPointAtLength SVG 1.x https://dev ...

  2. Techme Inc热心公益事业 积极开展公益活动

    从2015年起,Techme inc(公司编号:20151524696)便通过优质的产品和服务,帮助顾客实现营养与健康的目标.与此同时,Techme inc(公司编号:20151524696)多年来始 ...

  3. 【Azure 应用服务】App Service与APIM同时集成到同一个虚拟网络后,如何通过内网访问内部VNET的APIM呢?

    问题描述 App Service访问的APIM已配置内部虚拟网络(Internal VNet)并拥有内网IP地址.App Service与APIM都在相同的虚拟网络(VNET)中.App Servic ...

  4. 翻译:《实用的Python编程》02_05_Collections

    目录 | 上一节 (2.4 序列) | 下一节 (2.6 列表推导式) 2.5 collections 模块 collections 模块为数据处理提供了许多有用的对象.本部分简要介绍其中的一些特性. ...

  5. 一文吃透如何部署kubernetes高可用集群

    使用 k8s 官方提供的部署工具 kubeadm 自动安装,需要在 master 和 node 节点上安装 docker 等组件,然后初始化,把管理端的控制服务和 node 上的服务都以 pod 的方 ...

  6. apiAutoTest:支持自定义函数,用例中可调用

    0. 前言 apiAutoTest从去年8月以来开源至今,也更新了不少内容,一起来看看吧 第一个版本 - 2020/08/08 增加实际响应存储数据的方法,并在字典可以处理依赖见tools/svae_ ...

  7. Python插入排序

    升序 import random l = [] for i in range(8): l.append(random.randint(0,9)) print(l) for cur in range(1 ...

  8. 微信小程序自定义Tabber,附详细源码

    目录 1,前言 2,说明 3,核心代码 1,前言 分享一个完整的微信小程序自定义Tabber,tabber按钮可以设置为跳转页面,也可以设置为功能按钮.懒得看文字的可以直接去底部,博主分享了小程序代码 ...

  9. 初识Java多线程

    一.多线程概述 1.1.程序.进程.线程概念 1)程序 是为完成特定任务,用某种语言编写的一组指令的集合,即指一段静态的代码,静态对象. 2)进程 是指一个内存中运行的应用程序,每个进程都有一个独立的 ...

  10. ZooKeeper 的选举机制,你了解多少?

    本文作者:HelloGitHub-老荀 Hi,这里是 HelloGitHub 推出的 HelloZooKeeper 系列,免费开源.有趣.入门级的 ZooKeeper 教程,面向有编程基础的新手. 项 ...