TWaver初學實戰——如何在EasyUI中插入TWaver

来源:http://www.cnblogs.com/xiaor2/archive/2016/07/15/5670677.html
-Advertisement-
Play Games

TWaver能否與其他開發工具集成?當然沒有問題!今天就拿一個EasyUI的小例子試刀,小小演示一下如何在其上添加TWaver圖元。原例展示了一個EasyUI的基本佈局,併在其中部面板添加了表格。我們的目標是在其表格上方添加個簡單的TWaver拓撲圖,並將其樹圖顯示在west面板。 ...


TWaver是一款強大的圖形界面開發組件,可以很方便地集成到其他開發工具中。今天就用一個小例子來操練如何結合TWaver和EasyUI進行網頁開發。

準備工作

俗話說他山之玉可以直接拿來,EasyUI的小程式我們直接到其網站上拿一個就好啦,我一眼相中了下圖這個有佈局、有表格的小例子,咱們就來看看怎麼通過添加twaver將其變得圖表結合內容豐滿。

首先下載配置EasyUI相關文件,複製並運行例子源碼————噫?怎麼結果與網站上並不太一樣,表格中的數據沒有了!仔細看看可知數據來源於'datagrid_data1.json',就像離開家的小朋友找不到放到柜子里的零食了。解決這個問題還真不是想象的那麼簡單,僅僅把正確地址給它,或是將文件下載到本地,都無法得到正確結果,據說這是HTML5為了你好我好大家都安全弄成這樣子的。其實對於這樣的小程式,我們直接將數據存放在程式中就好了,比如將代碼$('#tableID').datagrid({data:[json中的對象數據]});添加到<body>的onload()函數中,再運行一下是不是和網站上的效果一模一樣呢?

<html>
<head>
  <meta charset="UTF-8">
  <title>jQuery EasyUI</title>
  <link rel="stylesheet" type="text/css" href="./jquery-easyui/themes/default/easyui.css">
  <link rel="stylesheet" type="text/css" href="./jquery-easyui/themes/icon.css">
  <link rel="stylesheet" type="text/css" href="./jquery-easyui/demo/demo.css">
  <script type="text/javascript" src="./jquery-easyui/jquery.min.js"></script>
  <script type="text/javascript" src="./jquery-easyui/jquery.easyui.min.js"></script>
  <script type="text/javascript">
    function init(){      
      $('#dg').datagrid({
        data:[
        {"productid":"FI-SW-01","productname":"Koi","unitcost":10.00,"status":"P","listprice":36.50,"attr1":"Large","itemid":"EST-1"},
        //...
        ]
      });
    }
  </script>
</head>
<body  onload="init()">
  <div style="margin:20px 0;"></div>
  <div class="easyui-layout" style="width:700px;height:440px;">
    <div data-options="region:'north'" style="height:50px"></div>
    <div data-options="region:'south',split:true" style="height:50px;"></div>
    <div data-options="region:'east',split:true" title="East" style="width:100px;"></div>
    <div data-options="region:'west',split:true" title="West" style="width:120px; position:relative;" ></div>
    <div data-options="region:'center',title:'Main Title',iconCls:'icon-ok'"  style=" position:relative;"  >
      <table class="easyui-datagrid" id ="dg">
      <thead>
        <tr>
          <th data-options="field:'itemid'" width="70">Item ID</th>
          <th data-options="field:'productid'" width="90">Product ID</th>
          <th data-options="field:'listprice',align:'right'" width="70">List Price</th>
          <th data-options="field:'unitcost',align:'right'" width="60">Unit Cost</th>
          <th data-options="field:'attr1'" width="135">Attribute</th>
          <th data-options="field:'status',align:'center'" width="50">Status</th>
        </tr>
      </thead>
    </table>
  </div>
</div>
</body>
</html>

好了,接下來就是TWaver的相關準備工作了。先到TWaver下載頁面獲取TWaver2D系列的HTML5試用產品,將其中的twaver.js文件提取到我們剛纔存放源碼文件的文件夾下,然後在源碼文件的<head>中插入。現在擼擼袖子喝口水,TWaver的正式編程就可以開始了。

搞定div

參照產品網站文檔《開髮指南 – TWaver HTML5 (2D)》,可以知道圖元(Element)、容器(DataBox)和畫布(Network)是TWaver的三大要素,只要設好了容器,綁定到畫布上,再創建圖元扔進容器,一切就OK了!

思路有了,上手開乾!先var出box、network、tree三個變數,再function出initNetwork()、initNode()、initTree()三個函數,分別用以設置畫布、添加節點、建立樹圖,最後再將三個函數放入init()中以便得以執行,這樣程式框架就搭起來了。

TWaver圖形能否在EasyUI中顯示出來,關鍵是network的設置是否正確。其實就是獲取到目標位置的div,然後將Network綁定進去。當然只要祭出我們的getElementById()大法,一切便可迎刃而解,我們要做的,只不過是為要使用到的center和west兩個div分別添加一個id而已。

當然,還不能高興的太早,人家div早已安排妥當,你非要進來插個隊,還想直接排個最佳位置,不客客氣氣的打聲招呼怎麼行?!這個招呼其實也不難打,只要在相應div的style添加代碼”position:relative;”就可以了。重要的事情再說一遍:一定在插入TWaver圖形的div中添加代碼style=”position:relative;”

繼續搞定div

創建節點實在是太容易了,只弄個兩點一線怎麼能過癮,起碼得搞個3層結構吧!我們先創建一個group(就是可以包含子節點的父節點),下麵又有兩個group,其中一個group下還有兩個node。怎麼才能把子節點添加到父節點上呢?其實只需一node.setParent(group)語句就搞掂了。最後再為兩個node加上連接父節點的link,一個簡單的拓撲結構就完成了。

先運行一下試試吧!怎麼,又遇到了新問題?是啊,同在center中的TWaver圖形和EasyUI表格,會出現重疊的情況。解決這個問題當然可以直接把EasyUI表格挪到south面板中去,但更具普遍意義的做法是再嵌套一個基本佈局面板,然後分別將二者添加到其nouth和center中,這樣問題就完美解決了。如果說還有不完美,就是network大小有可能沒有完全適應所在div。其實我們沒有必要費勁調整它的寬高,只需要在network.adjustBounds()中設置{width:centerDiv.clientWidth,height: centerDiv.clientHeight},再看看效果吧!

tree就簡單多了,只要像network一樣用appendChild()將其添加到相應的div,所有的圖元就可以顯示出來了!不過tree中最好僅保留group、node等節點,以便更好地展示其邏輯關係,只要添加語句tree.setVisibleFunction(function (element) {return element instanceof twaver.Node; });,這樣就可以過濾掉非節點元素了。

至此大功告成!怎麼樣,是不是非常簡單?都已經迫不及待的想試一試了吧 ^_^

最後附上完整源碼: 

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <title>TWaver adhibition jQuery EasyUI</title>
  <link rel="stylesheet" type="text/css" href="./jquery-easyui/themes/default/easyui.css">
  <link rel="stylesheet" type="text/css" href="./jquery-easyui/themes/icon.css">
  <link rel="stylesheet" type="text/css" href="./jquery-easyui/demo/demo.css">
  <script type="text/javascript" src="./jquery-easyui/jquery.min.js"></script>
  <script type="text/javascript" src="./jquery-easyui/jquery.easyui.min.js"></script>
  <script src="twaver.js"></script>
  <script type="text/javascript">
    var box = new twaver.ElementBox();
    var network = new twaver.vector.Network(box);
    var tree = new twaver.controls.Tree(box);
    function init(){      
      initNetwork();
      initNode();
      initTree();
      $('#dg').datagrid({
        data:[
        {"productid":"FI-SW-01","productname":"Koi","unitcost":10.00,"status":"P","listprice":36.50,"attr1":"Large","itemid":"EST-1"},
        {"productid":"K9-DL-01","productname":"Dalmation","unitcost":12.00,"status":"P","listprice":18.50,"attr1":"Spotted Adult Female","itemid":"EST-10"},
        {"productid":"RP-SN-01","productname":"Rattlesnake","unitcost":12.00,"status":"P","listprice":38.50,"attr1":"Venomless","itemid":"EST-11"},
        {"productid":"RP-SN-01","productname":"Rattlesnake","unitcost":12.00,"status":"P","listprice":26.50,"attr1":"Rattleless","itemid":"EST-12"},
        {"productid":"RP-LI-02","productname":"Iguana","unitcost":12.00,"status":"P","listprice":35.50,"attr1":"Green Adult","itemid":"EST-13"},
        {"productid":"FL-DSH-01","productname":"Manx","unitcost":12.00,"status":"P","listprice":158.50,"attr1":"Tailless","itemid":"EST-14"},
        {"productid":"FL-DSH-01","productname":"Manx","unitcost":12.00,"status":"P","listprice":83.50,"attr1":"With tail","itemid":"EST-15"},
        {"productid":"FL-DLH-02","productname":"Persian","unitcost":12.00,"status":"P","listprice":23.50,"attr1":"Adult Female","itemid":"EST-16"},
        {"productid":"FL-DLH-02","productname":"Persian","unitcost":12.00,"status":"P","listprice":89.50,"attr1":"Adult Male","itemid":"EST-17"},
        {"productid":"AV-CB-01","productname":"Amazon Parrot","unitcost":92.00,"status":"P","listprice":63.50,"attr1":"Adult Male","itemid":"EST-18"}
        ],
      });
    }
    function initNetwork(){
      var centerDiv = document.getElementById('north2');
      var view = network.getView();
      centerDiv.appendChild(view);
      network.adjustBounds({
        x: 0,
        y: 0,
        width: centerDiv.clientWidth,
        height: centerDiv.clientHeight
      });
    }
    function initNode(){
      var group = new twaver.Group();
      group.setName("Group");
      box.add(group);
      var group1 = new twaver.Group({
        name: 'Group1',
        location: {
          x: 150,
          y: 20
        },
      });
      group1.setParent(group);
      box.add(group1);
      var group2 = new twaver.Group({
        name: 'Group2',
        location: {
          x: 320,
          y: 80
        },
      });
      group2.setParent(group);
      box.add(group2);
      var node1 = new twaver.Node({
        name: 'Node1',
        location: {
          x: 240,
          y: 30
        },
      });
      node1.setParent(group1);
      box.add(node1);
      var node2 = new twaver.Node({
        name: 'Node2',
        location: {
          x: 80,
          y: 50
        },
      });
      node2.setParent(group1);
      box.add(node2);
      var link1 = new twaver.Link(group1, node1);
      link1.setName("Link1");
      box.add(link1);
      var link2 = new twaver.Link(group1, node2);
      link2.setName("Link2");
      box.add(link2);
    }
    function initTree(){
      var treeDom = tree.getView();
      var westDiv = document.getElementById('west');
      treeDom.style.width = "100%";
      treeDom.style.height = "100%";
      westDiv.appendChild(treeDom);
      tree.setVisibleFunction(function (element) {
        return element instanceof twaver.Node; });
      tree.expandAll();
    }
  </script>
</head>
<body  onload="init()">
  <div class="easyui-layout" style="width:700px;height:440px;">
    <div data-options="region:'north'" style="height:50px"></div>
    <div data-options="region:'south',split:true" style="height:50px;">
    </div>
    <div data-options="region:'east',split:true" title="East" style="width:100px;"></div>
    <div data-options="region:'west',split:true" title="West" style="width:120px; position:relative;"  id="west"></div>
    <div data-options="region:'center',title:'Main Title',iconCls:'icon-ok'"  style="position:relative;"  id="center" >
      <div class="easyui-layout" data-options="fit:true">
        <div data-options="region:'north',split:true,border:false" style="height:180px"   id="north2"></div>
        <div data-options="region:'center',border:false">
          <table class="easyui-datagrid"   id ="dg">
            <thead>
              <tr>
                <th data-options="field:'itemid'" width="70">Item ID</th>
                <th data-options="field:'productid'" width="80">Product ID</th>
                <th data-options="field:'listprice',align:'right'" width="70">List Price</th>
                <th data-options="field:'unitcost',align:'right'" width="60">Unit Cost</th>
                <th data-options="field:'attr1'" width="135">Attribute</th>
                <th data-options="field:'status',align:'center'" width="50">Status</th>
              </tr>
            </thead>
          </table>
        </div>
      </div>
    </div>
  </div>
</body>
</html>

 帶上一堆數據果然顯得代碼豐富,好有成就感!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、浮動(float)對內聯元素的影響。 1.我們都知道,內聯元素(例如:span/img/input...)在正常情況下不可以對其設置寬高的,它的大小之只和它內部內容的多少有關。 我們怎樣才可以對其設置寬、高呢?可以用display:block;或者display:inline-block;讓它轉 ...
  • 源代碼如下: <!DOCTYPE html><html><head> <title>xi</title> <meta charset="utf-8"> <style type="text/css"> .ww{ width: 70px; height: 70px; background: red; b ...
  • 1. rem單位方式,用法當前像素除以100。 2. px單位方式,以640px設計圖比例實現。 3.px單位方式,以設計圖640除以2實現。 4.px單位方式及media媒體查詢方式實現,判斷最大、最小方式實現,設計圖還是640標準。 註,第一種、二種方式是現在比較好用的 ...
  • 一、line-height的定義 line-height,行高,是指文本行基線間的垂直距離。 1. 什麼是基線? 一般而言,一個文本行一共有四條線,從上到下依次為頂線、中線、基線、底線;在英文中,基線為小寫 x 字母下邊緣所在的那條線。如圖: 註意,基線的位置與字體有關,不同的字體基線的位置有偏差。 ...
  • HTML可以看成是由節點(node)組成的樹結構 我們一般都是在<p>節點裡面寫字元串。 在上圖中,<p>節點和字元串之間有一個text, 這個text就是文本節點。 我們可以這樣創建文本節點 document.createTextNode(String); 我們也可以把他添加到<p>節點 var ...
  • 做的一個項目中需要得到經緯度.. 實現:先寫一個方法如下 在直接用就可以了 第一個參數是地名,第二個參數是城市名,第三個是你想在哪個文本框顯示...就可以得到文本框的值也就是該地名.. 最後就是取文本框的值,如果不想看到這個文本框,可以隱藏,同樣可以取到值 ...
  • (?:pattern) 匹配 pattern 但不獲取匹配結果,也就是說這是一個非獲取匹配,不進行存儲供以後使用。這在使用 "或" 字元 (|) 來組合一個模式的各個部分是很有用。例如, 'industr(?:y|ies) 就是一個比 'industry|industries' 更簡略的表達式。 ( ...
  • × 目錄 [1]表達式 [2]塊語句 [3]空語句[4]聲明 前面的話 如果表達式在javascript中是短語,那麼語句(statement)就是javascript整句或命令。表達式計算出一個值,語句用來執行以使某件事發生。javascript程式無非就是一系列可執行語句的集合,javascri ...
一周排行
    -Advertisement-
    Play Games
  • GoF之工廠模式 @目錄GoF之工廠模式每博一文案1. 簡單說明“23種設計模式”1.2 介紹工廠模式的三種形態1.3 簡單工廠模式(靜態工廠模式)1.3.1 簡單工廠模式的優缺點:1.4 工廠方法模式1.4.1 工廠方法模式的優缺點:1.5 抽象工廠模式1.6 抽象工廠模式的優缺點:2. 總結:3 ...
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...