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,贴出来仅供参考希望不要再跳这个坑。