odoo中阻止点击list视图中的一条记录弹出form视图

在odoo中,默认点击tree视图中的一条记录,会打开相应的form视图,如果加了editable="true",

这个行为就阻止了,但是呢,加了editable="true", 但是当所有的字段都是只读的时候,点击记录又会弹出form视图,而且就算不定义form视图,它也会自动生成一个form视图打开。 怎么阻止这一行为呢?

答案其实也很简单, tree标签加一个属性

xml 复制代码
<tree no_open=1>

实现原理在list_renderer.js中

js 复制代码
  async onCellClicked(record, column, ev) {
        if (ev.target.special_click) {
            return;
        }
        debugger
        const recordAfterResequence = async () => {
            const recordIndex = this.props.list.records.indexOf(record);
            await this.resequencePromise;
            // row might have changed record after resequence
            record = this.props.list.records[recordIndex] || record;
        };

        if ((this.props.list.model.multiEdit && record.selected) || this.isInlineEditable(record)) {
            if (record.isInEdition && this.props.list.editedRecord === record) {
                const cell = this.tableRef.el.querySelector(
                    `.o_selected_row td[name='${column.name}']`
                );
                if (cell && containsActiveElement(cell)) {
                    this.lastEditedCell = { column, record };
                    // Cell is already focused.
                    return;
                }
                this.focusCell(column);
                this.cellToFocus = null;
            } else {
                await recordAfterResequence();
                await record.switchMode("edit");
                this.cellToFocus = { column, record };
            }
        } else if (this.props.list.editedRecord && this.props.list.editedRecord !== record) {
            this.props.list.unselectRecord(true);
        } else if (!this.props.archInfo.noOpen) {
            this.props.openRecord(record);
        }
    }

起作用的是最后这句

js 复制代码
else if (!this.props.archInfo.noOpen) {
            this.props.openRecord(record);
        }

有机会list_renderer 一定要仔细研究一下的。

相关推荐
Odoo穆尘4 天前
【零散技术】Odoo PDF 打印问题问题合集
pdf·odoo
黄宏哲4 天前
自定义 CSS 和 t-att-class 的使用
前端·css·odoo
Odoo老杨19 天前
开源免费的工贸一体行业ERP管理系统
odoo·erp·mes·企业信息化·制造管理·外贸管理·mrp
Odoo穆尘19 天前
【零散技术】Odoo17通过Controller下载PDF
odoo
奔跑的蜗牛..2 个月前
如何在 Odoo 16 会计中向发票添加付款二维码
xml·前端·python·制造·odoo
奔跑的蜗牛..2 个月前
如何为 Nextcloud 配置自动数据库备份 - 应用程序
xml·前端·数据库·python·odoo
Odoo老杨2 个月前
生物制药及化工行业ERP解决方案
odoo·erp·企业信息化·生物·化工·制药
_鹿哥2 个月前
form表单按钮根据编辑/只读状态显示和隐藏
odoo·odoo15
多多~益善2 个月前
【odoo17 | Owl】前端js钩子调用列表选择视图
前端·javascript·odoo
多多~益善2 个月前
【odoo17】后端py方法触发右上角提示组件
odoo