一文詳解GoJs中go.Panel的itemArray屬性
前言
上一篇文章中,為了演示go.panel
內(nèi)部元素的折疊展開,也是為了舉例子比較簡單。使用了一個go.Panel的屬性itemArray
,本文將詳細的介紹一下itemArray
屬性。
itemArray屬性的使用
只包含一種繪圖模板的渲染列表
//data nodes: [ { key: 1, text:"三國", list1: ["魏", "蜀", "吳"] }, ], //methods this.myDiagram.nodeTemplate = $$( go.Node, "Auto", $$(go.Shape, "Rectangle", { fill: "#67B73C",width:100,height:100 }), $$( go.Panel, "Table", { column: 0 }, $$(go.TextBlock, { column: 0, margin: new go.Margin(3, 3, 0, 3), font: "bold 12pt sans-serif", },new go.Binding("text", "text")), $$("PanelExpanderButton", "LIST1", { column: 1 }), $$( go.Panel, "Vertical", { name: "LIST1", row: 1, column: 0, columnSpan: 2 }, new go.Binding("itemArray", "list1") ) ) );
可以看出在節(jié)點內(nèi)部如果出現(xiàn)了很多樣式和顯示位置都相同的元素,也就是渲染列表。就可以使用itemArray
屬性。然后配置的屬性值必須為數(shù)組,否則則會報錯。
包含不同的繪圖模板的渲染列表
在真實的需求開發(fā)中,可能在需要處理的渲染列表中不是只有一種繪圖模板。需要有其他的繪圖模板配合使用,這時就需要結(jié)合itemTemplate
屬性進行結(jié)合使用。其使用方法如下
let itemTemplates = $$(go.Panel, "Auto", { margin: 2 }, $$(go.Shape, "RoundedRectangle", { fill: "#FF9900" }), $$(go.TextBlock, new go.Binding("text", ""), { margin: 2 }) ) this.myDiagram.nodeTemplate = $$( go.Node, "Auto", $$(go.Shape, "Rectangle", { fill: "#67B73C",width:150,height:150 }), $$( go.Panel, "Table", { column: 0 }, $$(go.TextBlock, { column: 0, margin: new go.Margin(3, 3, 0, 3), font: "bold 12pt sans-serif", },new go.Binding("text", "text")), $$("PanelExpanderButton", "LIST1", { column: 1 }), $$( go.Panel, "Vertical", { name: "LIST1", row: 1, column: 0, columnSpan: 2,itemTemplate:itemTemplates }, new go.Binding("itemArray", "list1") ) ) );
由此可以發(fā)現(xiàn),可以給go.Panel
配置itemTemplate
屬性。在配置nodeTemplate
屬性的時候,有兩種方式,第一種是我們在nodeTemplate
重新聲明模板,或者是直接nodeTemplate
后面直接寫對應的配置項。這里推薦第一種方式,因為寫在內(nèi)部的話會把整個節(jié)點配置模板顯得很亂。而在上面的示例中使用的go.Shape
和go.TextBlock
來示例說明,在實際開發(fā)中可以使用更多的繪圖模板在其內(nèi)部進行配置。
內(nèi)部多個繪圖模板的不同列的行循環(huán)
在很多時候,對渲染列表的展示主要是以一種key、valu
e的鍵值對的形式表現(xiàn)。而事實上會有很多鍵值對以表格的形式進行展示,并且我們還可以配置不同其他屬性,下面是配置了stroke
屬性的鍵值對配列。示例如下
let itemTemplates = $$(go.Panel, "TableRow", $$(go.TextBlock, new go.Binding("text", "name"),new go.Binding("stroke", "color"), { column: 0, margin: 2, font: "bold 10pt sans-serif" }), $$(go.TextBlock, new go.Binding("text", "info"),new go.Binding("stroke", "color"), { column: 1, margin: 2 }), ) this.myDiagram.nodeTemplate = $$( go.Node, "Auto", $$(go.Shape, "Rectangle", { fill: "#67B73C",width:150,height:150 }), $$( go.Panel, "Table", $$(go.TextBlock, { column: 0, margin: new go.Margin(3, 3, 0, 3), font: "bold 12pt sans-serif", },new go.Binding("text", "text")), $$("PanelExpanderButton", "LIST1", { column: 1 }), $$( go.Panel, "Table", { name: "LIST1", row: 1, column: 0, columnSpan: 2,itemTemplate:itemTemplates }, new go.Binding("itemArray", "list1") ) ) );
這種情況的列表鍵值對的形式,可以在itemTemplate
配置其面板屬性為TableRow
,只需要配置colum
n第幾列的繪圖模板,這個是時候行就會進行循環(huán)展示,還可以對每一列的屬性通過go.Binding
進行動態(tài)配置屬性的顯示。
注意:itemTemplate內(nèi)部設置TableRow的時候,其外部的go.Panel屬性必須是Table,否則將無法顯示
總結(jié)
對于類似vue中v-for
的渲染列表,在gojs
內(nèi)部也同樣存在,通過itemArray
屬性來配置一個數(shù)組進行渲染,如果需要配置的屬性過多,也可以在節(jié)點內(nèi)配置多個屬性,然后再itemTemplate
繪圖模板中進行解構出來就可以了。除了上述幾種示例之外,也可以把其他的繪圖模板例如go.Group、go.Picture
等等匯聚到itemTemplate
里面。
以上就是一文詳解GoJs中go.Panel的itemArray屬性的詳細內(nèi)容,更多關于GoJs go.Panel itemArray屬性的資料請關注腳本之家其它相關文章!
相關文章
JS使用canvas中的measureText方法測量字體寬度示例
這篇文章主要介紹了JS使用canvas中的measureText方法測量字體寬度,結(jié)合實例形式分析了canvas的measureText方法相關使用技巧,需要的朋友可以參考下2019-02-02小程序云開發(fā)教程如何使用云函數(shù)實現(xiàn)點贊功能
這篇文章主要為大家詳細介紹了小程序云開發(fā)教程如何使用云函數(shù)實現(xiàn)點贊功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-05-05javascript實現(xiàn)在網(wǎng)頁中運行本地程序的方法
這篇文章主要介紹了javascript實現(xiàn)在網(wǎng)頁中運行本地程序的方法,實例分析了JavaScript基于ActiveXObject運行本地程序的技巧,需要的朋友可以參考下2016-02-02layui使用templet格式化表格數(shù)據(jù)的方法
今天小編就為大家分享一篇layui使用templet格式化表格數(shù)據(jù)的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09