宜兴通达竭诚为您服务。

通达科技 - 宜兴电脑维护及IT服务外包服务商

自定义字段
  • 上传者: Administrator
  • 上传时间:2023年12月06日 07时27分58秒
摘要:
子类化现有字段组件 None [1] ** 让我们举一个例子,我们想要扩展  BooleanField  来创建一个布尔字段,每当复选框被选中时,显示红色的 “Late!”。 创建一个扩展所需字段组件的新小部件组件。 late_order_boolean_field.js None [2] / ......
正文 相关文章 请喝咖啡

    子类化现有字段组件

    让我们举一个例子,我们想要扩展 BooleanField 来创建一个布尔字段,每当复选框被选中时,显示红色的 “Late!”。

    1. 创建一个扩展所需字段组件的新小部件组件。

      late_order_boolean_field.js
      /** @odoo-module */
      
      import { registry } from "@web/core/registry";
      import { BooleanField } from "@web/views/fields/boolean/boolean_field";
      import { Component, xml } from "@odoo/owl";
      
      class LateOrderBooleanField extends BooleanField {}
      LateOrderBooleanField.template = "my_module.LateOrderBooleanField";
      
    2. 创建字段模板。

      该组件使用一个名为 my_module.LateOrderBooleanField 的新模板。通过继承 BooleanField 的当前模板来创建它。

      late_order_boolean_field.xml
      <?xml version="1.0" encoding="UTF-8" ?>
      <templates xml:space="preserve">
          <t t-name="my_module.LateOrderBooleanField" t-inherit="web.BooleanField" owl="1">
              <xpath expr="//CheckBox" position="after">
                    <span t-if="props.value" class="text-danger"> Late! </span>
              </xpath>
          </t>
      </templates>
      
    3. 将组件注册到字段注册表中。

      late_order_boolean_field.js
      registry.category("fields").add("late_boolean", LateOrderBooleanField);
      
    4. 将小部件添加到视图arch中,作为字段的属性。

      <field name="somefield" widget="late_boolean"/>
      

    创建一个新的字段组件

    假设我们想要创建一个以红色显示简单文本的字段。

    1. 创建一个新的Owl组件,代表我们的新字段

      my_text_field.js
      /** @odoo-module */
      
      import { standardFieldProps } from "@web/views/fields/standard_field_props";
      import { Component, xml } from "@odoo/owl";
      import { registry } from "@web/core/registry";
      
      export class MyTextField extends Component {
      
          /**
          * @param {boolean} newValue
          */
          onChange(newValue) {
              this.props.update(newValue);
          }
      }
      
      MyTextField.template = xml`
          <input t-att-id="props.id" class="text-danger" t-att-value="props.value" onChange.bind="onChange" />
      `;
      MyTextField.props = {
          ...standardFieldProps,
      };
      MyTextField.supportedTypes = ["char"];
      

      导入的 standardFieldProps 包含了由 View 传递的标准属性,例如 update 函数用于更新值,模型中字段的 type , readonly 布尔值等等。

    2. 在同一个文件中,将组件注册到字段注册表中。

      my_text_field.js
      registry.category("fields").add("my_text_field", MyTextField);
      

      这将arch中的小部件名称映射到其实际组件。

    3. 将小部件添加到视图arch中,作为字段的属性。

      <field name="somefield" widget="my_text_field"/>
    本文章从网上收集,如有侵权请联系tderp@tderp.com删除
  • 微信扫一扫,一分也是爱:
  • 微信

服务原则及地区范围

宜兴通达网络科技有限公司,地处中国宜兴环科园内,是一家高新技术企业。公司在企业网络维护和企业信息化建设与咨询方面,有10多年经验。

我公司愿与客户一道,力求彻底解决客户问题!
我们不是在给企业提供“头痛医头、脚痛医脚”的暂时解决方案,而是在部署根本性安全与稳定服务!!
我们愿携手客户,建立企业IT规划;杜绝随意安装系统、软件等操作;力求共同维护有序、安全、稳定的网络办公环境!!!
IT服务,服务是根本,客户是上帝;我们提供快速响应、快速上门、快速排查,提供优质高效的服务!!!!

通达科技提供全国范围内的服务,服务形式包括远程协助、电话咨询、电子邮件咨询、传真咨询、问答平台的问题解决等。

宜兴地区提供上门服务:

  • 市区服务:宜城街道、城北街道(屺亭街道)、新街街道、新庄街道、环科园、渚桥开发区
  • 市郊服务:张渚镇、西渚镇、太华镇、徐舍镇、官林镇、杨巷镇、新建镇、和桥镇、高塍镇、万石镇、周铁镇、芳桥镇、丁蜀镇、湖父镇。
  • 联系电话:189-21-343434
  • 在线沟通: