婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > Scratch3.0初始化加載七牛云上的sbs文件的方法

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

熱門標(biāo)簽:400電話申請到底哪家好 地圖標(biāo)注項目幾個月 400電話辦理費用低 外呼系統(tǒng)怎么群發(fā)短信 谷歌地圖標(biāo)注日期 鶴壁高頻外呼系統(tǒng)多少錢一個月 宿遷怎么辦理400電話 蘇州呼叫中心外呼系統(tǒng)哪家強 聯(lián)通外呼系統(tǒng)電腦app軟件

下面通過代碼介紹下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后,瀏覽器默認(rèn)打開的是編程的頁面。如下圖:

那么我們希望開發(fā)一個功能,就是打開的時候默認(rèn)加入某一個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(`遠(yuǎn)程加載文件錯誤!${error}`)
        })

文件加載完畢

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

我們需要將上面的第一行

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>

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

您可能感興趣的文章:
  • scratch3.0二次開發(fā)之用blocks生成python代碼
  • scratch-www 在Win10下的環(huán)境搭建詳細(xì)教程
  • Scratch3.0二次開發(fā)之windows環(huán)境下打包成exe的流程
  • scratch3.0二次開發(fā)之scratch-blocks的免編譯修改方法

標(biāo)簽:雙鴨山 襄陽 丹東 鄂爾多斯 哈爾濱 遵義 錫林郭勒盟 莆田

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《Scratch3.0初始化加載七牛云上的sbs文件的方法》,本文關(guān)鍵詞  Scratch3.0,初始化,加載,七牛,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《Scratch3.0初始化加載七牛云上的sbs文件的方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于Scratch3.0初始化加載七牛云上的sbs文件的方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    综合久久一区二区三区| 欧美国产日韩在线观看| 韩国女主播一区| 亚洲h精品动漫在线观看| 2020国产成人综合网| 91精品国产综合久久久久久漫画| 国产成人亚洲综合a∨婷婷图片| 欧美一区二区国产| 性欧美大战久久久久久久久| 久久久久久久精| 日韩欧美一区二区视频| 在线免费观看不卡av| 成人av网址在线观看| 国产精品一区二区不卡| 蜜臀av性久久久久av蜜臀妖精| av一区二区久久| 成人免费视频app| 国产suv精品一区二区三区| 激情小说亚洲一区| 国产精品 欧美精品| 国产高清精品在线| 成人午夜免费av| 视频在线观看国产精品| 欧美一二区视频| 久久久久久久久97黄色工厂| 国产精品嫩草久久久久| 亚洲人吸女人奶水| 欧美aaa在线| 久久99精品久久久久久国产越南| 国产欧美一二三区| 色综合天天天天做夜夜夜夜做| 丁香六月久久综合狠狠色| 91亚洲国产成人精品一区二区三 | 国产精品美女久久福利网站| 91在线视频免费观看| 色婷婷av久久久久久久| 91精品国产91热久久久做人人| 日韩三级视频在线看| 国产欧美日韩久久| 亚洲mv在线观看| 成人教育av在线| 555www色欧美视频| 国产精品视频麻豆| 视频一区二区国产| 不卡一区中文字幕| 日韩亚洲欧美综合| 亚洲狼人国产精品| 国产一区二区在线看| 欧美日韩精品是欧美日韩精品| 久久天天做天天爱综合色| 亚洲伦在线观看| 国产在线播放一区| 91精品视频网| 亚洲在线观看免费视频| 不卡一区二区在线| 精品国产一区a| 日本免费在线视频不卡一不卡二| 91欧美激情一区二区三区成人| 国产激情视频一区二区三区欧美 | 国产精品白丝jk黑袜喷水| 欧美亚一区二区| 国产精品久久久久永久免费观看 | 久久99久久99精品免视看婷婷 | 欧美一区二区日韩| 亚洲无线码一区二区三区| 成人av在线观| 亚洲国产精品黑人久久久| 日本午夜精品视频在线观看 | 久久亚洲捆绑美女| 日韩电影在线免费| 亚洲精品一区二区三区影院| 久久黄色级2电影| 欧美成人精品1314www| 美国一区二区三区在线播放| 日韩女优电影在线观看| 久久精品国产一区二区三 | 欧美变态口味重另类| 国产裸体歌舞团一区二区| 久久久国际精品| 99国产麻豆精品| 亚洲综合视频网| 日韩欧美亚洲国产另类| 国产一区二区三区在线观看免费视频 | 欧美日本精品一区二区三区| 日本不卡一二三区黄网| 久久精品一区蜜桃臀影院| 粉嫩高潮美女一区二区三区 | 久久99蜜桃精品| 国产精品乱人伦一区二区| 色综合久久久久久久久| 日本欧美一区二区| 成人欧美一区二区三区黑人麻豆 | 丁香五精品蜜臀久久久久99网站 | 蜜桃免费网站一区二区三区 | 国产精品一区二区男女羞羞无遮挡| 国产精品色婷婷| 91精品国产综合久久久久久漫画 | 91精品国产一区二区人妖| 成人在线一区二区三区| 亚洲综合激情小说| 久久久久久久综合色一本| 91在线国内视频| 国产成人av自拍| 国内外精品视频| 久久福利视频一区二区| 一区二区三区四区五区视频在线观看| 久久久久久麻豆| 精品国产免费久久| 日韩一区二区在线看| 欧美系列一区二区| 一本色道久久综合亚洲91| 国产不卡高清在线观看视频| 久久精品国产99国产| 亚洲高清免费观看| 亚洲欧洲色图综合| 国产日产欧产精品推荐色| 欧美一区2区视频在线观看| 欧美日韩精品一区二区三区四区| 一本久久精品一区二区| 成人激情小说网站| 国产精品一卡二卡| 久草中文综合在线| 国产一区免费电影| 国产aⅴ综合色| 东方aⅴ免费观看久久av| jiyouzz国产精品久久| 成人h动漫精品| 91麻豆福利精品推荐| 色婷婷综合五月| 日韩午夜精品电影| 国产三级欧美三级日产三级99| 久久精品人人做人人综合| 欧美国产亚洲另类动漫| 亚洲人成电影网站色mp4| 亚洲丰满少妇videoshd| 首页欧美精品中文字幕| 欧美久久高跟鞋激| 精品成人一区二区三区四区| 亚洲国产成人一区二区三区| 亚洲乱码国产乱码精品精98午夜 | 成人动漫一区二区在线| 在线观看网站黄不卡| 欧美mv和日韩mv国产网站| 国产精品网友自拍| 亚洲国产一区二区视频| 国产呦精品一区二区三区网站| 99久久99久久精品免费观看| 石原莉奈在线亚洲二区| 国产91露脸合集magnet| 欧美日韩www| 国产精品情趣视频| 中文字幕精品一区二区三区精品| 亚洲最大色网站| 国产成人夜色高潮福利影视| 欧美午夜在线观看| 亚洲色图视频免费播放| 极品美女销魂一区二区三区| 91高清视频在线| 国产精品国产三级国产a| 国产乱国产乱300精品| 欧美一区二区播放| 亚洲国产成人va在线观看天堂| 成人avav影音| 国产精品久久久久久久久免费桃花| 久久精品国产第一区二区三区| 777午夜精品免费视频| 亚洲最大成人网4388xx| 91小宝寻花一区二区三区| 国产精品水嫩水嫩| 99精品偷自拍| 欧美日韩黄视频| 男男成人高潮片免费网站| 日韩三级中文字幕| 狠狠色丁香婷综合久久| 久久日一线二线三线suv| 另类调教123区| 欧美videossexotv100| 国产成人三级在线观看| 欧美韩日一区二区三区四区| 成熟亚洲日本毛茸茸凸凹| 国产精品视频看| 日韩专区中文字幕一区二区| 久久国产精品露脸对白| 精品国产亚洲在线| 色综合久久中文综合久久牛| 一区二区三区自拍| 欧美高清你懂得| 精品一区二区三区免费播放| 久久精品人人做| 色欧美片视频在线观看在线视频| 亚洲chinese男男1069| 国产精品入口麻豆原神| 久久精品国产久精国产| 99精品视频一区| 日韩影院在线观看| 国产精品久久久久aaaa樱花| 91精品国产91热久久久做人人| 国产电影一区在线| 香蕉久久一区二区不卡无毒影院| 中文字幕av一区二区三区高|