公告:灿笔网站目录为广大站长提供免费收录网站服务,VIP会员每天提交网站30、文章30免审核,快审服务(10元/站),可自助充值发布。

点击这里在线咨询客服
新站提交
  • 网站:19096
  • 待审:1
  • 小程序:114
  • 文章:58220
  • 会员:5

scratch是一种非常合适的培养自己的编程兴趣的方式。通过拖拽的方式,可以实现一些游戏,小程序的开发,就像搭积木一样,下面给大家介绍Scratch3.0 页面初始化同时加载sb3文件的操作方法,一起看看吧!

目标文件地址:src\containers\sb-file-uploader.jsx

修改 sb-file-uploader.jsx文件, class SBFileUploader中添加componentDidMount(),代码如下

componentDidMount() { 

    var _this = this;
		
	// 作品所在存放地址
	var sb3Path = null;
	
	/**
	 * 必须使用 $(window).on("load",function(){});
	 * 否则页面在未加载完的情况下,有些组件会来不及加载,影响二次文件保存
	 */
	console.log("尚未初始加载Sb3文件");
	$(window).on("load",function(){
		console.log("即将初始加载Sb3文件");
		let reader = new FileReader();
		let request = new XMLHttpRequest();
		console.log("加载的资源路径", sb3Path);
		request.open('GET', sb3Path, true);
		request.responseType = "blob";
		request.onload = function() {
			if(request.status==404){
				alert("未找到sb3类型的资源文件");
				location.href='/scratch';
			}
			let blobs = request.response
			reader.readAsArrayBuffer(blobs);
			reader.onload = () => _this.props.vm.loadProject(reader.result).then(() => {
				analytics.event({
					category: 'project',
					action: 'Import Project File',
					nonInteraction: true
				});
				_this.props.onLoadingFinished(_this.props.loadingState);
			}).catch(error => {
				log.warn(error);
			});
		}
		request.send();
	});
}

目标文件地址:src\components\menu-bar\menu-bar.jsx

修改 menu-bar.jsx文件, class MenuBar 中初始SBFileUploader,代码如下

// 必须加载这个文件
import SBFileUploader from '../../containers/sb-file-uploader.jsx';

class MenuBar extends React.Component {
   
    render () {
    
        return (
            <Box
                className={classNames(
                    this.props.className,
                    styles.menuBar,
                    {[styles.saveInProgress]: this.props.isUpdating}
                )}
            >
				<SBFileUploader onUpdateProjectTitle={PropTypes.func} /** 初始化加载文件到项目 **/>
					{(className, renderFileInput, loadProject) => (
						<button onClick={loadProject} className={classNames(styles.scratchHide)}></button>
					)}
				</SBFileUploader>
            </Box>
        );
    }
}

export default injectIntl(connect(
    mapStateToProps,
    mapDispatchToProps
)(MenuBar));

到此这篇关于Scratch3.0 页面初始化同时加载sb3文件的操作代码的文章就介绍到这了,更多相关Scratch页面初始化内容请搜索灿笔目录以前的文章或继续浏览下面的相关文章希望大家以后多多支持灿笔目录!

您可能感兴趣的文章:
  • 详解scratch3.0二次开发之scratch-blocks中的blocks的类型、定义和使用方法
  • scratch3.0二次开发之用blocks生成python代码
  • Scratch3.0二次开发之windows环境下打包成exe的流程
  • 解析scratch3.0二次开发之scratch-blocks免编译修改问题

分享到:

  kaifamei

注册时间:

网站:0 个   小程序:0 个  文章:0 篇

  • 19096

    网站

  • 114

    小程序

  • 58220

    文章

  • 5

    会员

赶快注册账号,推广您的网站吧!
热门网站
最新入驻小程序

数字化教学平台2020-12-19

数字化教学平台是集教学,教务,考培

体质达标助手2020-12-19

是专门针对学生体测用的小程序,小

配音猫2020-12-19

喵喵喵我是一只永久免费的配音猫

花样百姓+2020-12-19

花样百姓是百姓网旗下“50+银发

口袋字典2020-12-19

口袋在手,汉语不愁!支持汉字、词组

古诗推敲2020-12-19

于字斟句酌中,走进古诗词的诸般意