如何在 Blockly 自定义块的“onchange”事件中获取值?
How do I get a value in the `onchange` event of a Blockly custom block?
我正在为 Blockly 制作自定义块,需要验证输入。在 onchange
事件中,如果用户输入的输入值无效,我想警告他们。
这是我的街区:
Blockly.Blocks['motor'] = {
init: function() {
this.setHelpUrl('http://www.example.com/');
this.setColour(65);
this.appendDummyInput()
.appendField("motor( ");
this.appendValueInput("port_number")
.setCheck("Number");
this.appendDummyInput()
.appendField(");");
this.setInputsInline(true);
this.setPreviousStatement(true);
this.setNextStatement(true);
this.setTooltip('');
},
onchange: function(ev) {
if (this.getFieldValue('port_number') > '3') {
this.setWarningText('Port must be 0 - 3.');
} else {
this.setWarningText(null);
}
}
};
在Blockly Developers Page上,它有一个获取输入值的基本例子。但是,每次 onchange
触发时,我都会返回 undefined
。
如何处理这些输入的验证?我不想为输入创建下拉列表,因为我需要能够从变量、int 块等输入。
不确定这是否是处理此问题的最佳方法,但它对我有用。我只是使用 valueToCode
方法访问输入值。然后我可以验证输入值。
Note: The context of the onchange
handler is the block, so passing
this
as the first argument to Blockly.C.valueToCode
will get the
value from the correct block.
Blockly.Blocks['motor'] = {
init: function() {
this.setHelpUrl('http://www.example.com/');
this.setColour(65);
this.appendDummyInput()
.appendField("motor( ");
this.appendValueInput("port_number")
.setCheck("Number");
this.appendDummyInput()
.appendField(");");
this.setInputsInline(true);
this.setPreviousStatement(true);
this.setNextStatement(true);
this.setTooltip('');
},
onchange: function(ev) {
var port_number = Blockly.C.valueToCode(this, 'port_number', Blockly.C.ORDER_ATOMIC);
var valid = VALIDATE.motor_port_number(port_number);
if (!valid)
alert("WARNING: The value for the motor port must be 0, 1, 2 or 3.");
}
}
};
试试这个:
this.getInputTargetBlock('port_number').toString()
或者:
this.getInputTargetBlock('port_number').getFieldValue(/*field_name*/)
示例:
Blockly.Blocks['stop_actions'] = {
init: function() {
var actions_descriptors = [
['HOLD', 'hold'],
['COAST', 'coast']
];
this.appendDummyInput()
.appendField(new Blockly.FieldDropdown(actions_descriptors), 'action')
.setAlign(Blockly.ALIGN_RIGHT);
this.setOutput(true, 'String');
this.setColour(60);
this.setTooltip('Select the stop action');
}
};
Blockly.Blocks['motor'] = {
init: function() {
this.appendValueInput('arg_stop_action')
.appendField('Stop action')
.setAlign(Blockly.ALIGN_RIGHT);
},
onchange: function(e) {
this.getInputTargetBlock('arg_stop_action').getFieldValue('action')
}
};
我正在为 Blockly 制作自定义块,需要验证输入。在 onchange
事件中,如果用户输入的输入值无效,我想警告他们。
这是我的街区:
Blockly.Blocks['motor'] = {
init: function() {
this.setHelpUrl('http://www.example.com/');
this.setColour(65);
this.appendDummyInput()
.appendField("motor( ");
this.appendValueInput("port_number")
.setCheck("Number");
this.appendDummyInput()
.appendField(");");
this.setInputsInline(true);
this.setPreviousStatement(true);
this.setNextStatement(true);
this.setTooltip('');
},
onchange: function(ev) {
if (this.getFieldValue('port_number') > '3') {
this.setWarningText('Port must be 0 - 3.');
} else {
this.setWarningText(null);
}
}
};
在Blockly Developers Page上,它有一个获取输入值的基本例子。但是,每次 onchange
触发时,我都会返回 undefined
。
如何处理这些输入的验证?我不想为输入创建下拉列表,因为我需要能够从变量、int 块等输入。
不确定这是否是处理此问题的最佳方法,但它对我有用。我只是使用 valueToCode
方法访问输入值。然后我可以验证输入值。
Note: The context of the
onchange
handler is the block, so passingthis
as the first argument toBlockly.C.valueToCode
will get the value from the correct block.
Blockly.Blocks['motor'] = {
init: function() {
this.setHelpUrl('http://www.example.com/');
this.setColour(65);
this.appendDummyInput()
.appendField("motor( ");
this.appendValueInput("port_number")
.setCheck("Number");
this.appendDummyInput()
.appendField(");");
this.setInputsInline(true);
this.setPreviousStatement(true);
this.setNextStatement(true);
this.setTooltip('');
},
onchange: function(ev) {
var port_number = Blockly.C.valueToCode(this, 'port_number', Blockly.C.ORDER_ATOMIC);
var valid = VALIDATE.motor_port_number(port_number);
if (!valid)
alert("WARNING: The value for the motor port must be 0, 1, 2 or 3.");
}
}
};
试试这个:
this.getInputTargetBlock('port_number').toString()
或者:
this.getInputTargetBlock('port_number').getFieldValue(/*field_name*/)
示例:
Blockly.Blocks['stop_actions'] = {
init: function() {
var actions_descriptors = [
['HOLD', 'hold'],
['COAST', 'coast']
];
this.appendDummyInput()
.appendField(new Blockly.FieldDropdown(actions_descriptors), 'action')
.setAlign(Blockly.ALIGN_RIGHT);
this.setOutput(true, 'String');
this.setColour(60);
this.setTooltip('Select the stop action');
}
};
Blockly.Blocks['motor'] = {
init: function() {
this.appendValueInput('arg_stop_action')
.appendField('Stop action')
.setAlign(Blockly.ALIGN_RIGHT);
},
onchange: function(e) {
this.getInputTargetBlock('arg_stop_action').getFieldValue('action')
}
};