javascript - Blockly 的自定义语言生成器

标签 javascript json blockly

我知道我可以用

Blockly.JavaScript['my_code'] = function() {  ... }

但是我怎样才能添加另一种语言支持,比如 JSON? 我试过了..

Blockly.Json['my_code'] = function() {  ... }

恢复失败

Blockly.Json.workspaceToCode(this.workspace)

workspaceToCode 不是函数。

我需要向 Blockly 添加新语言

I will not display this new language (JSON), it will just be used to send instructions to the robots.


我努力

Blockly.Json = new Blockly.Generator('Json');
Blockly.Json['my_code'] = function() {  ... }

但是在

中出现错误
Blockly.Json.workspaceToCode(this.workspace)

错误..

Uncaught TypeError: this.init is not a function
    at js.ou3v.module.exports.Blockly.Generator.workspaceToCode

最佳答案

为 Blockly 创建一个新的语言生成器是一项相当大的任务,考虑到这一点,文档似乎并没有提供太多创建语言生成器的帮助。

根据我的经验,构建生成器的最佳方法是查看 generators/ 中的现有生成器。 , 我用过 JavaScript生成器作为我的项目的模板,我想在其中生成 C++ 代码。

还值得注意的是 Block Factory生成 JSON 以用于其他 Blockly 应用程序,但是当我查看 code 时因为没有为它定义一个实际的生成器。

我认为你得到的错误是因为 Blockly.Json 没有 init 函数引起的。这是在现有生成器文件中定义的内容,例如,来自 JavaScript 生成器:

/**
* Initialise the database of variable names.
* @param {!Blockly.Workspace} workspace Workspace to generate code from.
*/
Blockly.JavaScript.init = function(workspace) {
  ....
};

考虑到这一点,您的函数将如下所示:

/**
* Initialise the database of variable names.
* @param {!Blockly.Workspace} workspace Workspace to generate code from.
*/
Blockly.Json.init = function(workspace) {
 .....
};

生成器文件还包含其他函数,但查看现有代码并根据您的需要调整它应该对您有所帮助。

关于javascript - Blockly 的自定义语言生成器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44895551/

相关文章:

javascript - 使用 jquery 切换多个元素类

javascript - JQuery 输入表单不起作用

javascript - 在异步请求中使用 post 请求打开一个新窗口

python - simplejson:加载西类牙字符——utf-8

javascript - 如何在 Blockly 中隐藏/删除字段?

javascript - block 式 domToWorkspace 重置节点 ID

javascript - GET 后 Vue.js 组件数据未更新

java - com.fasterxml.jackson.databind.JsonMappingException : Numeric value (1557587751202) out of range of int

java - 使用 GSON 的 JSON 反序列化会跳过 HashMap 内的 HashMap 中的数据成员

javascript - 在 WPF WebBrowser 中使用 Blockly