Blockly的Mutators(变异器)是一种更高级别的定义块的方法。Mutators允许您使用相同的块设置创建具有不同输入和功能的其他块。
Mutators就如同块的编辑器,您可以使用它来自定义一个块,让用户输入块的参数,然后根据这些参数生成不同的代码。Mutators使我们能够轻松地用一个块来匹配多个上下文,并为各种不同的块提供协作。
例如,假设您有一个名称为“Set Value”的块,该块具有两个字段,一个是名称,一个是值。您可以创建一个Mutator,使用户可以选择要显示在块上的哪个字段。这样,您就可以使用一个块来创建任意数量的变量。下面是一个示例Mutator定义:
Blockly.defineMutation("field_select",
function() {
var dropdown = new Blockly.FieldDropdown([
["name", "NAME"],
["value", "VALUE"]
]);
this.appendDummyInput()
.appendField("show:")
.appendField(dropdown, "FIELD");
this.setColour(160);
this.setOutput(true, "FIELD_OPTS");
this.setTooltip("");
});
适用于“Set Value”的块的定义可以是这样的:
Blockly.Blocks['mutation_block'] = {
init: function() {
this.appendDummyInput()
.appendField("Set value");
this.appendValueInput("NAME")
.setCheck("String")
.appendField("name");
this.appendValueInput("VALUE")
.setCheck("Number")
.appendField("value");
this.setColour(290);
this.setInputsInline(true);
this.setOutput(true, "mutation_block");
this.setTooltip("");
this.setMutator(new Blockly.Mutator(['field_select']));
// Default to showing the name field.
this.selectedField_ = 'NAME';
this.setFieldValue('NAME', 'FIELD');
},
mutationToDom: function() {