当前位置: 首页 > wzjs >正文

滕州个人兼职做网站管理咨询网站建设

滕州个人兼职做网站,管理咨询网站建设,style wordpress 主题,文汇网站建设Odoo 18 配置机制详解:res.config.settings 与 ir.config_parameter 原理与实战指南 在现代企业信息化系统中,灵活且可维护的系统参数配置是模块开发的核心能力之一。Odoo 作为一款高度模块化的企业管理软件,其参数配置机制主要依赖于两个关…

Odoo 18 配置机制详解:res.config.settingsir.config_parameter 原理与实战指南

在现代企业信息化系统中,灵活且可维护的系统参数配置是模块开发的核心能力之一。Odoo 作为一款高度模块化的企业管理软件,其参数配置机制主要依赖于两个关键模型:res.config.settingsir.config_parameter

本文将系统梳理这两个模型的设计原理、典型应用场景及开发实践,并通过完整案例演示如何从 Python 到 XML 快速实现系统设置项,助力开发者高效构建可配置的 Odoo 模块。


一、核心模型原理

1. ir.config_parameter —— 系统参数存储模型

  • 作用:作为底层的键值对存储模型,负责持久化保存系统全局配置参数。

  • 模型名称ir.config_parameter

  • 表结构(简化)

    字段名类型描述
    keychar设置项唯一键
    valuetext设置项值,统一为字符串类型
  • 读写方式

# 读取配置值(如布尔型需自行判断)
value = self.env['ir.config_parameter'].sudo().get_param('my_module.my_setting') == 'True'# 设置配置值
self.env['ir.config_parameter'].sudo().set_param('my_module.my_setting', 'True')

2. res.config.settings —— 系统设置表单模型

  • 作用:为管理员提供 UI 表单接口,便于读取和设置 ir.config_parameter
  • 模型名称res.config.settings(TransientModel,临时模型,数据不持久化)
  • 关键特性
    • 字段通过 config_parameter 属性与 ir.config_parameter.key 关联
    • 支持多种字段类型(Boolean、Char、Integer、Selection 等)
    • 设置项可直接在 Odoo 后台"设置"界面进行配置

二、典型应用场景

应用场景说明
功能开关启用/禁用模块功能(如"启用审批流程")
默认参数设定默认值(如"默认抄送邮箱"“默认负责人”)
第三方集成存储 API Key、Webhook URL 等外部对接参数
系统行为设置配置"数据保留天数""通知频率"等系统行为

三、开发流程实战

以"启用高级功能"为例,演示从字段定义到前端配置的完整开发流程。

1. 模块结构示例

my_module/
├── __init__.py
├── __manifest__.py
├── models/
│   ├── __init__.py
│   ├── res_config_settings.py
│   └── my_model.py
└── views/└── res_config_settings_views.xml

2. manifest 文件

my_module/__manifest__.py

{'name': 'My Module','version': '1.0','category': 'Tools','summary': '演示 Odoo 配置机制','depends': ['base'],'data': ['views/res_config_settings_views.xml',],'installable': True,'application': False,
}

3. Python 字段定义

models/res_config_settings.py 中定义设置字段,并通过 config_parameter 绑定系统参数:

from odoo import models, fieldsclass ResConfigSettings(models.TransientModel):_inherit = 'res.config.settings'enable_advanced_feature = fields.Boolean(string="Enable Advanced Feature",help="启用后,将激活本模块的高级功能。",config_parameter='my_module.enable_advanced_feature')default_manager = fields.Many2one('res.users',string="Default Manager",help="新建任务时的默认负责人。",config_parameter='my_module.default_manager_id')

4. XML 视图定义

views/res_config_settings_views.xml 中扩展设置页面,使字段在前端可见:

<?xml version="1.0" encoding="UTF-8"?>
<odoo><record id="res_config_settings_view_form_my_module" model="ir.ui.view"><field name="name">res.config.settings.view.form.my.module</field><field name="model">res.config.settings</field><field name="inherit_id" ref="base.res_config_settings_view_form"/><field name="arch" type="xml"><xpath expr="//div[@id='settings']" position="inside"><div class="app_settings_block" data-string="My Module Settings" string="My Module Settings"><h2>My Module</h2><field name="enable_advanced_feature"/><field name="default_manager"/></div></xpath></field></record>
</odoo>

5. 业务代码中读取配置

my_module/models/my_model.py

from odoo import modelsclass MyModel(models.Model):_name = 'my.model'def do_something(self):enable = self.env['ir.config_parameter'].sudo().get_param('my_module.enable_advanced_feature')if enable == 'True':self._do_advanced()else:self._do_basic()def _do_advanced(self):# 高级功能实现passdef _do_basic(self):# 基础功能实现pass

四、进阶技巧与实用建议

1. 多公司参数隔离

Odoo 默认的 ir.config_parameter 参数是全局共享的。如需为每个公司单独配置参数,可通过拼接公司 ID 实现隔离:

company_id = self.env.company.id
param_key = f"my_module.feature_enabled_company_{company_id}"
self.env['ir.config_parameter'].sudo().set_param(param_key, 'True')

2. 类型转换建议

所有参数值均以字符串存储,读取时需根据实际类型转换:

# 读取整数类型参数
retry_count = int(self.env['ir.config_parameter'].sudo().get_param('my_module.retry_count') or 0)

五、常见问题与排查建议

问题解决方法
设置值后保存无效检查字段是否正确添加 config_parameter 属性
设置页面不显示字段检查 XML 是否正确继承并挂载到 res.config.settings
报错找不到字段重启 Odoo 并升级模块,清理缓存
多公司参数混乱使用公司 ID 拼接参数 key 或扩展公司字段

六、模型对比与总结

项目res.config.settingsir.config_parameter
模型类型TransientModelRegular Model
主要作用提供设置表单 UI 接口持久化存储配置值
是否持久化是(持久存储)
字段控制通过 config_parameter代码直接 set/get
典型用途用户界面参数配置业务逻辑读取系统参数

七、常用模板片段(可直接复用)

Python 字段定义

my_option = fields.Boolean(string="My Option",config_parameter='my_module.my_option'
)

XML 视图片段

<xpath expr="//div[@id='settings']" position="inside"><div class="app_settings_block" string="My Module"><field name="my_option"/></div>
</xpath>


八、结语

通过合理利用 res.config.settingsir.config_parameter,Odoo 开发者能够为模块快速添加灵活的系统配置项,实现功能开关、参数定制和第三方集成等多样化需求。这不仅提升了模块的通用性和可维护性,也为企业系统的持续演进提供了坚实基础。


文章转载自:

http://sz5Q8gat.mcfjq.cn
http://vgMKZlBo.mcfjq.cn
http://uaCCwMRB.mcfjq.cn
http://RJcwldDH.mcfjq.cn
http://mCmigBri.mcfjq.cn
http://n2P9sVrQ.mcfjq.cn
http://fCtNHSqP.mcfjq.cn
http://2Z1jnlEQ.mcfjq.cn
http://kzxt5L7V.mcfjq.cn
http://kFnT6Bk3.mcfjq.cn
http://FHzk6lNq.mcfjq.cn
http://gjArifej.mcfjq.cn
http://iRspbOp8.mcfjq.cn
http://AxPgEurk.mcfjq.cn
http://RRFwixnR.mcfjq.cn
http://FFbf7sBx.mcfjq.cn
http://ilJW1CIM.mcfjq.cn
http://UC7tT1Si.mcfjq.cn
http://3qDB3iaC.mcfjq.cn
http://Lbz0pZyr.mcfjq.cn
http://kUIPB5qv.mcfjq.cn
http://aqOTmgme.mcfjq.cn
http://yoYw1leQ.mcfjq.cn
http://J2JJeHED.mcfjq.cn
http://shP14pYy.mcfjq.cn
http://KtJjqDvq.mcfjq.cn
http://tdBFeUEe.mcfjq.cn
http://wPecOuEp.mcfjq.cn
http://2Kyxzwm0.mcfjq.cn
http://jNZ8VlJ9.mcfjq.cn
http://www.dtcms.com/wzjs/620441.html

相关文章:

  • 天河建设网站公司网上注册公司的章程怎么下载出来
  • 有做学历在网站能查的到的网站建设平台官网要点有哪些
  • 保定哪家做网站公司好wordpress删除版权信息
  • 正规的app网站开发成都旅游学院简介
  • 如何撤销网站备案青岛seo排名公司
  • seo网站推广怎样深圳网站设计公司行业
  • 哪个网站建网页比较好备案查询工信部
  • 五寨网站建设安徽省建设工程信息网网
  • 怎么做视频解析网站吗河南省村镇建设处网站
  • 网页界面设计一般使用的分辨率东莞百度seo找哪里
  • discuz网站搬家教程网站建设的特征
  • 贵阳讯玛网站建设wordpress 图片墙
  • win7 网站系统怎么做友情链接购买
  • 刷单类网站开发wordpress zhong
  • 天津市津南区教育网站建设招标揭阳企业网页制作公司
  • 想自己做网站苏州专业做优化公司
  • 网站建设 腾云网络推广的方法
  • 网站横幅怎做西青网站文化建设
  • 河南网站建设37518企业网站改版方案
  • 网站制作哪些类型推广公司如何找客户
  • 夫妻性做受视频什么网站一站式服务平台登录
  • 网站建设 焦作照片展示网站模板
  • 软件开发流程管理系统长春seo公司长春网站设计
  • 怎么通过数据库做网站的登录免费的网站搭建
  • 苏州设置网站建设太原首页推广
  • 河南企业网站排名优化价格长春市建设技工学校网站
  • 网站建设管理制度九不准医疗网站项目策划
  • 网站建设去哪网页设计师证书报名官网
  • 机械厂网站模板英文网站做百度权重有意义吗
  • 微信crm系统seo是什么意思为什么要做seo