17 如何使用Qweb开发一个页面

odoo 注重敏捷,但是同时也带来的问题我就是不够灵活,如果有一天你的boss让你做一个工作台,将其他模型的数据进行统计,并使用图表的形式进行展示。 这时候该如何做呢?

很明显 odoo 提供的视图时没有办法满足我们的需求的,这个时候 使用qweb注册一个页面就很有必要了。

首先开发之前你需要了解一些知识 【Qweb语法传送】

1 使用Qweb生成一个你想要的html界面(static/src/xml/epidemic_tongji_page.xml)

 

<?xml version="1.0" encoding="UTF-8"?>
<template>
    <t t-name="EpidemicTongjiPage">
    <div>这是一个测试页面</div>
    </t>
</template>

  

2 对AbstractAction模块进行扩展,得到自己的Widget并且使用web.core对我们的Widget进行注册,实现格式如下:(static/src/js/epidemic_tongji_page.js)

 

odoo.define('Epidemic_tongji.tongji_page', function(require) {
"use strict";
var AbstractAction = require('web.AbstractAction');
var core = require('web.core');
// 模块扩展
var TongjiPage = AbstractAction.extend({
    template: 'EpidemicTongjiPage',
    ......
});
// 对TongjiPage进行注册,通过映射绑定动作
core.action_registry.add('tag.tongji.page', TongjiPage);
});

  

 

3 注册完成之后,需要新增一个客户端动作来绑定我们自己的界面实现动作的调整,其中动作的tag属性此时需要设置为新增widget的映射值:(tag属性非常重要,必须和映射值保持一致)(views/epidemic_tongji_page_view.xml)

 

<record id="epidemic_tongji_page_action" model="ir.actions.client">
    <field name="name">TongjiPagee</field>
    <field name="tag">'tag.tongji.page</field> 
</record>

  

4 此时我们新建一个菜单项目,并且其 action属性指定到客户端动作来实现页面跳转(views/menu_views.xml):

<!-- Top menu item -->
    <menuitem name="统计页面"
              id="epidemic_tongji_page_menu_root"
              action="epidemic_tongji_page_action"
              sequence="99"
    />

  

5 现在我们基本实现了自定义的界面开发,最后需要将静态资源进行加载:
js文件我们需要使用资产捆绑(views/templates.xml)

 

<?xml version="1.0" encoding="UTF-8" ?>
<odoo>
    <template id="epidemic_tongji.assets_backend" inherit_id="web.assets_backend" name="epidemic_tongji.assets_backend">
        <xpath expr="." position="inside">
            <script type="text/javascript" src="/epidemic_tongji/static/src/js/epidemic_tongji_page.js"/>
        </xpath>
    </template>
</odoo>

  

清单关联文件中:

'qweb': ['static/src/xml/epidemic_tongji_page']
'data': ['views/epidemic_tongji_page_view.xml', 
           'views/templates.xml',
           'views/menu_views.xml']

  

最后 重启、更新模块,你会发现页面已经加载好了

posted @ 2023-03-06 22:14  CrossPython  阅读(132)  评论(0编辑  收藏  举报