4.14.4.3 复选框

优质
小牛编辑
133浏览
2023-12-01

复选框字段存储一个字符串作为其值,以及一个字符串作为其文本。 其值为“ TRUE”或“ FALSE”,其文本为“ true”或“ false”。

复选框字段

压缩的复选框字段

新建复选框字段

{
  "type": "example_checkbox",
  "message0": "checkbox: %1",
  "args0": [
    {
      "type": "field_checkbox",
      "name": "FIELDNAME",
      "checked": true
    }
  ]
}

复选框构造函数接受一个可选值和一个可选验证器。 可选值应为“ TRUE”,“ FALSE”或布尔值,否则它将默认为false。

可序列化和XML

复选框对应的XML代码如下所示:

<field name="FIELDNAME">TRUE</field>
<field name="FIELDNAME">true</field>

注意: 引号不需要应用于内部文本。

name属性包含一个引用复选框字段的字符串,内部文本是该字段的值。 内部文本值遵循与构造函数值相同的规则。

请注意,在反序列化和重新序列化之后,所有内部文本值都将大写(“ TRUE”或“ FALSE”)。 在区分工作空间时,这有时很重要。

定制化

复选标记字符

Blockly.FieldCheckbox.CHECK_CHAR属性可用于更改选中标记的外观。 该值应该是包含Unicode字符的字符串。

CHECK_CHAR属性默认为'\u2713'或✓。

这是全局属性,因此设置后将修改所有复选框字段。

创建一个复选框验证器

复选框字段的值为“ TRUE”或“ FALSE”,因此验证程序应接受这些值(即字符串),并返回“ TRUE”,“ FALSE”,null或undefined。

错误警告:不应在验证程序内部使用getValueBoolean方法,因为它基于当前值而不是新值返回。

这是一个验证器的示例,该验证器根据是否选中复选框来隐藏或显示文本输入字段:

 validate: function(newValue) {
    var sourceBlock = this.getSourceBlock();
    sourceBlock.showTextField_ = newValue == 'TRUE';
    sourceBlock.updateTextField();

    return newValue;
  },

  updateTextField: function() {
    var input = this.getInput('DUMMY');
    if (this.showTextField_ && !this.getField('TEXT')) {
      input.appendField(new Blockly.FieldTextInput(), 'TEXT');
    } else if (!this.showTextField_ && this.getField('TEXT')) {
      input.removeField('TEXT');
    }
  }