解析scratch3.0二次开发之scratch-blocks免编译修改问题

 更新时间:2022年03月01日 10:47:09   作者:取个昵称就那么难  
大家在使用scratch-blocks编译时会遇到scratch-gui依赖的scratch-blocks模块在安装的时候编译会报错,针对这个问题我们该怎么解决呢,下面小编给大家带来了scratch3.0二次开发之scratch-blocks免编译修改方法,感兴趣的朋友一起看看吧

scratch-blocks编译的时候会出现的问题:scratch-gui依赖的scratch-blocks模块在安装的时候编译会报错。

原因:scratch-blocks编译时要调用的build.py文件运行时发生错误。windowst系统下,代码压缩的过程是build.py通过一个closure-library的插件处理后,发送到谷歌的服务器进行压缩,返回的结果会生成blocks_compressed.js,blocks_compressed_horizontal.js,blocks_compressed_vertical.js这几个文件。(linux系统下,有网友反映会编译成功的。)build.py运行时,因为window系统在574行处要处理大量的信息流,所以导致错误发生。但即便成功,因为之后要把代码发送到国内经常访问不到的谷歌服务器,所以也会经常编译失败。这种方法每修改一次代码就要编译一次,效率比较低,比较耗时。

有没有种方法不用编译,就能修改scratch-blocks代码,而且能即时生效呢?答案是,有的。

scratch3.0是怎么引进scratch-blocks的呢?在scratch-gui的源文件src\containers\blocks.jsx中,引入了scratch-blocks,

import VMScratchBlocks from '../lib/blocks';

嗯…这是经过修改后的blocks,我们再顺着调用的路径,打开文件src\lib\blocks.js,这文件的作用是修改对应的角色(target)块的菜单项。

第一步,引入scratch-blocks,这是已经编译好的文件

import ScratchBlocks from 'scratch-blocks';

第二步,根据vm的数据修改blocks的菜单项。比如looks_costume块的修改代码如下:

ScratchBlocks.Blocks.looks_costume.init = function () {
        const json = jsonForMenuBlock('COSTUME', costumesMenu, looksColors, []);
        this.jsonInit(json);
    };

在修改之前,looks_costume块的菜单项这样子的:

菜单项是原来在scratch-blocks里定义的,没有变化。

修改后是这样子的:

看到没?菜单项的数据和vm联系起来了。

再举个例子吧,比如修改workspace界面在block上右键弹出菜单项,我要保留’添加注释’,然后把其他两项去掉,修改前,右键弹出菜单是这样子的:

在src\lib下创建scratch-blocks-modify文件夹,文件夹里创建了blocks_svg.js文件,从scratch-blocks的core文件夹中找到blocks_svg.js,把其中需要修改的函数代码复制过来。
修改的blocks_svg.js文件代码如下 :

export default function(Blockly){
    Blockly.BlockSvg.prototype.showContextMenu_ = function(e) {
        if (this.workspace.options.readOnly || !this.contextMenu) {
            return;
        }
        // Save the current block in a variable for use in closures.
        var block = this;
        var menuOptions = [];
        if (this.isDeletable() && this.isMovable() && !block.isInFlyout) {
            //menuOptions.push(
             //   Blockly.ContextMenu.blockDuplicateOption(block, e)); 这是注释掉的代码
            if (this.isEditable() && this.workspace.options.comments) {
                menuOptions.push(Blockly.ContextMenu.blockCommentOption(block));
            }
            //menuOptions.push(Blockly.ContextMenu.blockDeleteOption(block));这是注释掉的代码
        } else if (this.parentBlock_ && this.isShadow_) {
            this.parentBlock_.showContextMenu_(e);
            return;
        }

        // Allow the block to add or modify menuOptions.
        if (this.customContextMenu) {
            this.customContextMenu(menuOptions);
        }
        Blockly.ContextMenu.show(e, menuOptions, this.RTL);
        Blockly.ContextMenu.currentBlock = this;
    };
}

注意:现在可以使用es6来编写代码了。

然后在src\lib\blocks.js文件引入 :

blockSvgModify是导入的函数变量。

最后刷新下界面,修改生效:

方法:知道要修改的scratch-blocks的代码,然后把代码复制到一个js文件中修改,作为一个函数导出来,再把ScratchBlock作为参数传进去,函数返回的就是改过后的scratch-block文件了。

小结:我们可以通过引入scratch-block到一个文件中,在这个文件中修改我们想要修改的scratch-block函数、属性和方法,再导出来,实现我们想要的效果。而且这种方法是热修改。和修改react一样,每次修改会引起gui界面相应的变化,避免反复编译源文件繁琐的过程。

到此这篇关于scratch3.0二次开发之scratch-blocks的免编译修改方法的文章就介绍到这了,更多相关scratch blocks的免编译内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Web 设计与开发者必须知道的 15 个站点

    Web 设计与开发者必须知道的 15 个站点

    今天读到一篇文章,介绍了15个对 Web 设计与开发师极端有用的站点,里面有不少也是我们一直在使用的,也许对很多人都有用,翻译出来以饷同仁。
    2009-08-08
  • 性能测试QPS+TPS+事务基础知识分析

    性能测试QPS+TPS+事务基础知识分析

    本篇文章是性能测试基础篇,主要介绍了性能测试中对QPS+TPS+事务的基础知识分析,有需要的朋友可以借鉴参考下,希望可以对广大读者有所帮助
    2021-09-09
  • 云vscode搭建之使用容器化部署的方法

    云vscode搭建之使用容器化部署的方法

    随着容器化的发展,现在涌现出了很多云IDE,比如腾讯的Cloud Studio,但是其也是基于Code-Server进行开发部署的,用了它的云IDE后,我便产生出了自己部署一个这样的云IDE的想法,这篇文章主要介绍了云vscode搭建使用容器化部署,需要的朋友可以参考下
    2022-09-09
  • 进制转换基础

    进制转换基础

    很多年前大学里学过的进制转换还是挺简单的,没想到多年不用了,都忘了,刚好看到这篇文章,特分享下,方便需要的朋友
    2013-02-02
  • Visual Studio安装git插件的方法步骤

    Visual Studio安装git插件的方法步骤

    这篇文章主要介绍了Visual Studio安装git插件的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • 关于代码阅读问题的小技巧 脚本之家原创(适合所有网站)不定时更新

    关于代码阅读问题的小技巧 脚本之家原创(适合所有网站)不定时更新

    因为很多网站为了网站的安全,特将一些字符替换成中文字符,导致很多情况下,代码无法运行,或复制内容的适合都是一行显示,这里将会为大家整理一些。
    2011-01-01
  • Windows 版本Git命令行的使用详解

    Windows 版本Git命令行的使用详解

    这篇文章主要介绍了Windows 版本Git命令行的使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • Vscode 基础使用教程大全

    Vscode 基础使用教程大全

    本文给大家汇总介绍了一些vscode开始使用的过程中需要用到的基础的操作教程,非常简单实用,希望对大家熟练掌握vscode能够有所帮助
    2020-01-01
  • git clone下来的代码如何放在指定路径

    git clone下来的代码如何放在指定路径

    这篇文章主要介绍了git clone下来的代码如何放在指定路径,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • git rebase -i合并多次提交的实现

    git rebase -i合并多次提交的实现

    这篇文章主要介绍了git rebase -i合并多次提交的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07

最新评论