自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Google可視化編程工具Blockly入門

開發(fā) 開發(fā)工具
Blockly是google發(fā)布的可視化編程工具,是一個(gè)基于web技術(shù)構(gòu)建的庫(kù);blockly的目的是幫助客戶創(chuàng)建app,使得用戶(app的使用者)編程就像搭積木一樣的有趣、容易上手,大名鼎鼎的scratch就是一款使用類似技術(shù)的少兒編程工具。

什么是blockly?

blockly是google發(fā)布的可視化編程工具,是一個(gè)基于web技術(shù)構(gòu)建的庫(kù);blockly的目的是幫助客戶創(chuàng)建app,使得用戶(app的使用者)編程就像搭積木一樣的有趣、容易上手,大名鼎鼎的scratch就是一款使用類似技術(shù)的少兒編程工具。blockly有幾個(gè)特點(diǎn):

  1. 它是純粹的javascript庫(kù)。
  2. 它是100%面對(duì)客戶端的,沒有任何服務(wù)端的依賴。
  3. 支持各種主流的瀏覽器:Chrome, Firefox, Safari, Opera, and IE。
  4. 高度可定制和可擴(kuò)展。

如果把blockly看作一個(gè)黑盒,它的輸入就是用戶拖放的代碼塊的組合,輸出就是翻譯出的JavaScript/python/PHP/Lua/Dart代碼。

blockly能做什么?

近期工作的主要任務(wù)是針對(duì)公司的自動(dòng)化測(cè)試框架進(jìn)行改造,目前我司自動(dòng)化測(cè)試就是使用python+selenium的方式進(jìn)行自動(dòng)化測(cè)試,測(cè)試人員需要使用原生的python代碼進(jìn)行測(cè)試用例的編寫,對(duì)編程技能要求較高,我希望通過引入blockly為測(cè)試人員提供一個(gè)可視化的、搭建積木式的編寫測(cè)試用例的GUI接口,降低自動(dòng)化測(cè)試的上手門檻。

blockly上手示例

前提條件:需要對(duì)HTML、CSS、JavaScript有基本的了解

google官方提供的上手示例教程,這個(gè)示例是通過blockly創(chuàng)建一個(gè)簡(jiǎn)單的創(chuàng)造音樂的app,首先下載如下示例代碼:

  1. git clone https://github.com/google/blockly-samples.git 

本示例代碼路徑如下:

 

 

getting-started-codelab

 

  • starter-code:為示例的初始代碼;
  • complete-code:為示例完成后的代碼,如果自己編寫期間遇到卡殼的地方,可以和官方提供的完成代碼進(jìn)行對(duì)照。

每個(gè)目錄都包含同樣的目錄和文件:

  • scripts/main.js - app的主邏輯代碼
  • music_maker.js - 一個(gè)小型的用來播放聲音的庫(kù)
  • sounds/ - 聲音文件
  • styles/ - CSS樣式文件
  • index.html - 首頁

瀏覽器打開starter-code/index.html,顯示如下界面(如果首次打開不能完整顯示,可能是網(wǎng)絡(luò)原因,嘗試刷新瀏覽器試試)

 

starter-code首頁

 

編輯模式:

點(diǎn)擊edit進(jìn)行編輯模式,按照提示點(diǎn)擊下方的任意數(shù)字進(jìn)行代碼編輯

 

編輯模式

 

點(diǎn)擊任意一個(gè)數(shù)字之后,將顯示一篇空白區(qū)域,這里就是我們需要使用blockly進(jìn)行編碼的地方

 

點(diǎn)擊數(shù)字進(jìn)行代碼編輯

 

編輯index.html,在如下兩行script代碼之前增加一行代碼,引入blockly庫(kù),

  1. <script src="https://unpkg.com/blockly"></script>   <!-- 這一行是增加的代碼 --> 
  2. <script src="scripts/music_maker.js"></script> 
  3. <script src="scripts/main.js"></script> 

 

 

 

blockly將引入四個(gè)模塊:

  • Blockly core: 主要的核心代碼,主要定義了block UI及邏輯
  • Built-in block definitions: 常用的積木塊定義如循環(huán), 邏輯, 數(shù)據(jù), 和字符串操作
  • The JavaScript generator: 將積木塊生成JavaScript代碼
  • English language files: 積木塊的提示語言使用英語

創(chuàng)建blockly工作區(qū):

工作區(qū)包括代碼塊編輯區(qū)和工具箱兩部分

 

blocky工作區(qū)

 

編輯index.html在id="blocklyDiv"的div元素中增加如下xml結(jié)構(gòu):

  1. <xml id="toolbox" style="display: none"
  2.   <block type="controls_repeat_ext"
  3.   <value name="TIMES"
  4.     <shadow type="math_number"
  5.     <field name="NUM">5</field> 
  6.     </shadow> 
  7.   </value> 
  8.   </block> 
  9. </xml> 

編輯scripts/main.js,在代碼的最后添加如下代碼

 

  1. Blockly.inject('blocklyDiv', { 
  2.     toolbox: document.getElementById('toolbox'), 
  3.     scrollbars: false 
  4.   }); 

現(xiàn)在刷新瀏覽器,點(diǎn)擊edit進(jìn)入編輯模式,點(diǎn)擊任意數(shù)字,可以發(fā)現(xiàn)顯示了blockly工具去,工具箱有一個(gè)代碼塊

 

toolbox工具箱有一個(gè)代碼塊

 

創(chuàng)建定制的代碼塊

本示例是一個(gè)創(chuàng)建音樂的app,我們需要?jiǎng)?chuàng)建一個(gè)能夠播放聲音的代碼塊,通過下拉菜單的方式選擇不同的聲音文件。

scripts目錄下創(chuàng)建一個(gè)js文件,命名為sound_blocks.js,并在index.html首頁中引入該js文件

  1. <script src="https://unpkg.com/blockly"></script> 
  2. <script src="scripts/music_maker.js"></script> 
  3. <script src="scripts/sound_blocks.js"></script>   <!--這是增加的代碼行--> 
  4. <script src="scripts/main.js"></script> 

 

 

 

 

然后在sound_blocks.js中添加如下代碼

 

  1. Blockly.defineBlocksWithJsonArray([ 
  2.     { 
  3.         "type""play_sound"
  4.         "message0""Play %1"
  5.         "args0": [ 
  6.         { 
  7.             "type""field_dropdown"
  8.             "name""VALUE"
  9.             "options": [ 
  10.             ["C4""sounds/c4.m4a"], 
  11.             ["D4""sounds/d4.m4a"], 
  12.             ["E4""sounds/e4.m4a"], 
  13.             ["F4""sounds/f4.m4a"], 
  14.             ["G4""sounds/g4.m4a"], 
  15.             ["A5""sounds/a5.m4a"], 
  16.             ["B5""sounds/b5.m4a"], 
  17.             ["C5""sounds/c5.m4a"
  18.             ] 
  19.         } 
  20.         ], 
  21.         "previousStatement"null
  22.         "nextStatement"null
  23.         "colour": 355 
  24.     } 
  25. ]); 

以上js代碼定義了類型為play_sound的代碼塊,還需要把它加入到html頁面中才能顯示

  1. <div id="blocklyDiv" style="height: 480px; width: 400px;"
  2.     <xml id="toolbox" style="display: none"
  3.       <block type="controls_repeat_ext"
  4.         <value name="TIMES"
  5.           <shadow type="math_number"
  6.             <field name="NUM">5</field> 
  7.                 </shadow> 
  8.             </value> 
  9.         </block> 
  10.         <block type="play_sound"></block>   <!-- 這是新增加的代碼行 --> 
  11.     </xml> 
  12.   </div> 

 

 

 

 

再次刷新瀏覽器,打開工具箱發(fā)現(xiàn)多了一個(gè)紅色的代碼塊,該代碼塊可以用來播放sounds目錄的聲音文件

 

play_sound代碼塊

 

保存/加載工作區(qū)

現(xiàn)在構(gòu)建好了需要的代碼塊,已經(jīng)可以在代碼編輯區(qū)進(jìn)行編寫了,接下來需要做的是保存和加載功能。

編輯scripts/main.js,save方法中增加如下代碼,改代碼實(shí)現(xiàn)用戶點(diǎn)擊保存是將工作區(qū)的代碼塊保存為xml格式

 

  1. function save(button) { 
  2.     // 增加的代碼行 
  3.     button.blocklyXml = Blockly.Xml.workspaceToDom(Blockly.getMainWorkspace()); 
  4.   } 

保存成功后,下次進(jìn)入點(diǎn)擊數(shù)字進(jìn)入工作區(qū)還需要將工作區(qū)的代碼塊加載出來,繼續(xù)編輯main.js,增加如下方法

 

  1. // 增加的代碼 --- start 
  2. function loadWorkspace(button) { 
  3.     let workspace = Blockly.getMainWorkspace(); 
  4.     workspace.clear(); 
  5.     if (button.blocklyXml) { 
  6.       Blockly.Xml.domToWorkspace(button.blocklyXml, workspace); 
  7.     } 
  8.   } 
  9. // 增加的代碼 --- end 
  10.  
  11. function enableBlocklyMode(e) { 
  12.     document.body.setAttribute('mode''blockly'); 
  13.     currentButton = e.target; 
  14.     loadWorkspace(currentButton);   // 這一行是增加的代碼 
  15.   } 

現(xiàn)在嘗試刷新瀏覽器,點(diǎn)擊edit進(jìn)入編輯模式,點(diǎn)擊指定數(shù)字進(jìn)行代碼塊編輯后點(diǎn)擊save保存,然后再次返回后工作區(qū)仍然保留了上次編輯的代碼塊。

 

保存工作區(qū)

 

生成JavaScript代碼

編輯scripts/sound_blocks.js,增加如下代碼

 

  1. Blockly.JavaScript['play_sound'] = function(block) { 
  2.   let value = '\'' + block.getFieldValue('VALUE') + '\''
  3.   return 'MusicMaker.queueSound(' + value + ');\n'
  4. }; 

這段代碼的會(huì)將play_sound代碼塊生成如下js代碼"MusicMaker.queueSound('Sounds/c4.m4a');"(注:這里展示的代碼以C4選項(xiàng)為例)。

運(yùn)行生成的JavaScript代碼

編輯scripts/main.js,handlePlay方法中增加如下代碼

 

  1. function handlePlay(event) { 
  2.   // 增加的代碼 -- start 
  3.   loadWorkspace(event.target); 
  4.   let code = Blockly.JavaScript.workspaceToCode(Blockly.getMainWorkspace()); 
  5.   code += 'MusicMaker.play();'
  6.   try { 
  7.     eval(code); 
  8.   } catch (error) { 
  9.     console.log(error); 
  10.   } 
  11.   // 增加的代碼 -- end 

現(xiàn)在music maker的app就全部完成,重新刷新瀏覽器,點(diǎn)擊edit進(jìn)入編輯模式,然后點(diǎn)擊不同的數(shù)字進(jìn)行編程,可以根據(jù)代碼塊的提示設(shè)置播放什么聲音,播放的次數(shù),編輯完成后點(diǎn)擊Done就進(jìn)入運(yùn)行模式,此時(shí)點(diǎn)擊相應(yīng)的數(shù)字就會(huì)播放音樂了,還是蠻好玩的,快試試吧。

責(zé)任編輯:未麗燕 來源: 今日頭條
相關(guān)推薦

2012-06-07 10:00:45

Blockly編程語言

2019-03-05 09:20:47

Vim可視化模式命令

2013-05-16 09:11:22

GoogleAndroid Stu

2017-04-19 08:32:50

大數(shù)據(jù)數(shù)據(jù)可視化編程工具

2015-10-14 17:59:53

Google數(shù)據(jù)探索交互開發(fā)

2020-05-26 11:34:46

可視化WordCloud

2020-03-11 14:39:26

數(shù)據(jù)可視化地圖可視化地理信息

2021-02-21 08:11:46

PythonDash工具

2012-09-05 10:18:11

可視化編程工具程序員

2022-03-03 13:02:37

可視化網(wǎng)頁低代碼編程工具

2018-05-31 08:25:13

誤區(qū)工具可視化

2011-06-13 18:54:12

2017-10-14 13:54:26

數(shù)據(jù)可視化數(shù)據(jù)信息可視化

2022-08-26 09:15:58

Python可視化plotly

2009-04-21 14:26:41

可視化監(jiān)控IT管理摩卡

2020-10-12 18:08:19

JVM技能工具

2018-09-26 16:15:31

數(shù)據(jù)可視化大數(shù)據(jù)數(shù)據(jù)分析

2022-04-15 11:32:20

IDE工具鴻蒙操作系統(tǒng)

2025-04-01 08:30:00

Plotly數(shù)據(jù)可視化數(shù)據(jù)分析

2009-10-21 14:49:46

VB入門教程
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)