欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Scratch3.0 页面初始化同时加载sb3文件的操作代码

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

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页面初始化内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!