odoo中用javascript调用model中定义好的方法,及要注意的坑

odoo中如果前端界面要调用后台model中写好的方法,很简单。使用 do_action 即可,比如要调用改res.users的默认语言后执行的方法

odoo.define('switch_language.SwitchLanguageMenu', function (require) {
    "use strict";

    var Model = require('web.Model');
    var session = require('web.session');
    var UserMenu = require('web.UserMenu');

    UserMenu.include({
        on_menu_lang: function (ev) {
            var self = this;
            var lang = ($(ev).data("lang-id"));
            new Model('res.users').call('write', [[session.uid], {'lang': lang}]).then(function () {
                    self.do_action({
                        type: 'ir.actions.client',
                        res_model: 'res.users',
                        tag: 'reload_context',
                        target: 'current'
                    });
                });
            return false;
        }
    });

});

另外有些坑要注意,主要是列表视图,python中用tree,在js中却用了list

下面这个是在python 中实现按钮点击,跳转action的方法 虽然官方代码里不是这个写的,但是看起来直观,也没错。

  return {
            'type': 'ir.actions.act_window',
            'res_model': 'stock.picking',
            'view_mode': 'tree,form',
            'view_type': 'form',
            'name': u'查看出/入库单',
            'views': [(stock_picking_tree_ids, 'tree'), (view_picking_form_id, 'form')],
            'view_id': stock_picking_tree_ids,
            'domain': "[('so_id','='," + str(ids[0]) + "),('state','not in',['waiting'])]",
        }

但在js中要调用,需要这个样

this.do_action({
                        type: 'ir.actions.act_window',
                        res_model: "crm.phonecall",
                        view_mode: 'tree',
                        view_type: 'tree,form',
                        views: [[false, 'list'],[false, 'form']],
                        domain:'[("previous_contact_id","=",'+id+')]',
                        target: 'current',
                        context:"{'default_previous_contact_id':"+id+"}",
                    }, {
                        on_reverse_breadcrumb: function () {
                            self.reload();
                        }
                    });

这是经过一番源码的大量搜索找到的写法。

细心的朋友会发现,其实没啥大的区别,只是

views:[[false,'list'],[false,'form']],views':[(stock_picking_tree_ids,'tree'),(view_picking_form_id,'form')],

这里面的类型不一样在python中用了tree而在js中却用了list,贴出来仅供参考希望不要再跳这个坑。

 欧度智能: Odoo成功100%
Odoo专业开发实施,原广州尚鹏
  • Odoo项目100%海内外成功交付
  • Odoo官网下载第一,服务上千企业
  • Odoo官网销量第一的中国公司
  • 钉钉、企业微信认证服务商
  • 微软中国ChatGPT服务商,Ai中心
  • 百度千帆、阿里通义千问服务商
  • 十年专注Odoo,服务智能制造
  • Odoo中文应用商店,海量模块 
odoo中用javascript调用model中定义好的方法,及要注意的坑
odooAi广州欧度, 欧度超管
2017年8月12日
2024年12月3日
7,213
评论:
0
标签
存档
登录 留下评论
Odoo web 机制浅析