欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Scratch3.0初始化加載七牛云上的sbs文件的方法

 更新時間:2021年08月13日 10:28:02   作者:onightfalls  
今天通過本文給大家介紹Scratch3.0初始化加載七牛云上的sbs文件的實例代碼,代碼簡單易懂,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧

下面通過代碼介紹下Scratch3.0初始化加載七牛云上的sbs文件,代碼如下所示:

編寫組件

import PropTypes from 'prop-types';
import React from 'react';
import {connect} from 'react-redux';
import {injectIntl, intlShape} from 'react-intl';

import analytics from '../lib/analytics';
import log from '../lib/log';
import {LoadingStates, onLoadedProject, onProjectUploadStarted} from '../reducers/project-state';

import {openLoadingProject,closeLoadingProject} from '../reducers/modals';

/** 獲取作品的編號 **/
function getProjectId() {
	if(document.getElementById("projectId")){
		return $("#projectId").val();
	} else {
		alert("sb3-downloader-qiniu.jsx文件提示:頁面不存在id屬性為projectId的對象!");
		return null;
	}
}

/**
 * 從七牛云加載sb3文件
 */
class SB3DownloaderQiniu extends React.Component {
    constructor (props) {
        super(props);
    }
	
	componentDidMount() { 
		var _this = this;
		
		if(getProjectId()==null){
			return;
		}
	  
		// 作品所在存放地址
		var sb3Path = null;
		$.ajax({
			dataType:"json",
			async:false,
			url:"/project/checkProjectByProjectId",
			data: {id: getProjectId()},
			success:function(res){
				if(res.success==true){
					sb3Path = res.sb3Path;
				}
			}
		});
		
		/**
		 * 必須使用 $(window).on("load",function(){});
		 * 否則頁面在未加載完的情況下,有些組件會來不及加載,影響二次文件保存
		 */
		$(window).on("load",function(){
			let reader = new FileReader();
			let request = new XMLHttpRequest();
			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();
		});
	    
	}
   
    render () {
        return this.props.children(this.props.className);
    }
}

SB3DownloaderQiniu.propTypes = {
    children: PropTypes.func,
    className: PropTypes.string,
    intl: intlShape.isRequired,
    loadingState: PropTypes.oneOf(LoadingStates),
    onLoadingFinished: PropTypes.func,
    vm: PropTypes.shape({
        loadProject: PropTypes.func
    })
};

SB3DownloaderQiniu.defaultProps = {
    className: ''
};

const mapStateToProps = state => ({
    loadingState: state.scratchGui.projectState.loadingState,
    vm: state.scratchGui.vm
});

const mapDispatchToProps = (dispatch, ownProps) => ({
    onLoadingFinished: loadingState => {
		console.dir("sb3文件加載完畢!");
        dispatch(onLoadedProject(loadingState, ownProps.canSave));
        dispatch(closeLoadingProject());
    }
});

// Allow incoming props to override redux-provided props. Used to mock in tests.
const mergeProps = (stateProps, dispatchProps, ownProps) => Object.assign(
    {}, stateProps, dispatchProps, ownProps
);

export default connect(
    mapStateToProps,
    mapDispatchToProps,
    mergeProps
)(injectIntl(SB3DownloaderQiniu));

使用組件

<SB3DownloaderQiniu /** 初始化加載文件到項目 **/>
	{(className, loadProject) => (
		<button onClick={loadProject} className={classNames(styles.scratchHide)}></button>
	)}
</SB3DownloaderQiniu>

好了,下面看下如何自動加載scratch3.0的頁面上實現(xiàn)自動加載原有的作品

首先,我們在安裝scratch3。0后,瀏覽器默認打開的是編程的頁面。如下圖:

那么我們希望開發(fā)一個功能,就是打開的時候默認加入某一個SB3的開發(fā)文件

1.首先,我們需要有一個.SB3的開發(fā)文件,建議上傳到STATIC目錄下

2、找到scratch-gui-develop>src>container》gui.jsx文件

找到44行的componentDidMount函數(shù)

  新增以下代碼

const url="/static/123.sb3";
        fetch(url,{
            method: 'GET'
        })
        .then(response=>response.blob())
        .then(blob=>{
            const reader=new FileReader();
            reader.onload=()=>this.props.vm.loadProject(reader.result)
            .then(()=>{
                GoogleAnalytics.event({
                    category:'project',
                    action:'Import Project File',
                    nonInteraction:true
                })
            })
            reader.readAsArrayBuffer(blob)
        })
        .catch(error=>{
            alert(`遠程加載文件錯誤!${error}`)
        })

文件加載完畢

此外,我們例如希望開發(fā)像修改作業(yè)之類的,我們可以需要進行文件的傳遞

我們需要將上面的第一行

consturl="/static/123.sb3";

更改為

consturl=window.projecturl;

然后呢。在首頁,例如paly.html添加上以上代碼,或者自己用參數(shù)來傳遞

<script>

window.projectUrl="https://steam.nosdn.127.net/885318eb-ad83-44c4-afe3-d3bea0a0d2ab.sb3";

</script>

到此這篇關于Scratch3.0初始化加載七牛云上的sbs文件的文章就介紹到這了,更多相關Scratch加載sbs文件內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 詳解Git建立本地倉庫的兩種方法

    詳解Git建立本地倉庫的兩種方法

    這篇文章主要介紹了詳解Git建立本地倉庫的兩種方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-08-08
  • 高性能WEB開發(fā) JS、CSS的合并、壓縮、緩存管理

    高性能WEB開發(fā) JS、CSS的合并、壓縮、緩存管理

    本篇文章主要討論下目前JS,CSS 合并、壓縮、緩存管理存在的一些問題,然后分享下自己項目中用到的1個處理方案,并提供1個實例下載。
    2010-05-05
  • git push 本地項目推送到遠程分支的方法(git命令版)

    git push 本地項目推送到遠程分支的方法(git命令版)

    這篇文章主要介紹了git push 本地項目推送到遠程分支的方法(git命令版),需要的朋友可以參考下
    2020-09-09
  • idea集成Git實現(xiàn)團隊合作分工的原理詳解

    idea集成Git實現(xiàn)團隊合作分工的原理詳解

    這篇文章主要介紹了idea集成Git實現(xiàn)團隊合作分工的原理,本文通過圖文實例相結合給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2020-12-12
  • 微信小程序設置http請求的步驟詳解

    微信小程序設置http請求的步驟詳解

    這篇文章給大家介紹了微信小程序如何進行http請求的詳細步驟,相信對大家學習微信小程序網(wǎng)絡請求會有所幫助,有需要的朋友們下面來一起看看吧。
    2016-09-09
  • HTTP請求首部字段及響應首部字段詳解

    HTTP請求首部字段及響應首部字段詳解

    這篇文章主要介紹了HTTP請求首部字段及響應首部字段,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • Linux/Ubuntu Git從安裝到使用的方法步驟

    Linux/Ubuntu Git從安裝到使用的方法步驟

    這篇文章主要介紹了Linux/Ubuntu Git從安裝到使用的方法步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-04-04
  • Mac如何給應用單獨設置語言

    Mac如何給應用單獨設置語言

    這篇文章主要介紹了Mac如何給應用單獨設置語言,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-10-10
  • git設置忽略文件.gitignore的方法

    git設置忽略文件.gitignore的方法

    這篇文章主要介紹了git設置忽略文件.gitignore的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • VSCode 遠程登錄開發(fā)(帶免密)

    VSCode 遠程登錄開發(fā)(帶免密)

    這篇文章主要介紹了VSCode 遠程登錄開發(fā)(帶免密),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-05-05

最新評論