翻譯|使用教程|編輯:黃竹雯|2018-12-25 15:59:54.000|閱讀 917 次
概述:輕量級流程圖控件GoJS DOM樹示例
# 界面/圖表報表/文檔/IDE等千款熱門軟控件火熱銷售中 >>
相關鏈接:
GoJS是一款功能強大,快速且輕量級的流程圖控件,可幫助你在JavaScript和HTML5 Canvas程序中創建流程圖,且極大地簡化你的JavaScript / Canvas程序。本文主要演示DOM樹。
此示例顯示此網頁的DOM(Document Object Model即文檔對象模型)顯示為樹。圖中的每個節點都顯示關于DOM中相應的HTML元素的信息。
當選擇節點時,對應的HTML元素的背景顏色將更改為淡藍色(如下圖)。這個示例還使用了,它允許父節點展開和折疊其子節點。按鈕是在中定義的。帶有id屬性的元素會在括號中注明。
在頁面中查看此示例頁面的部分源代碼,。
var names = {}; // hash to keep track of what names have been used function init() { if (window.goSamples) goSamples(); // init for these samples -- you don't need to call this var $ = go.GraphObject.make; // for conciseness in defining templates myDiagram = $(go.Diagram, "myDiagramDiv", { initialAutoScale: go.Diagram.UniformToFill, // define the layout for the diagram layout: $(go.TreeLayout, { nodeSpacing: 5, layerSpacing: 30 }) }); // Define a simple node template consisting of text followed by an expand/collapse button myDiagram.nodeTemplate = $(go.Node, "Horizontal", { selectionChanged: nodeSelectionChanged }, // this event handler is defined below $(go.Panel, "Auto", $(go.Shape, { fill: "#1F4963", stroke: null }), $(go.TextBlock, { font: "bold 13px Helvetica, bold Arial, sans-serif", stroke: "white", margin: 3 }, new go.Binding("text", "key")) ), $("TreeExpanderButton") ); // Define a trivial link template with no arrowhead. myDiagram.linkTemplate = $(go.Link, { selectable: false }, $(go.Shape)); // the link shape // create the model for the DOM tree myDiagram.model = $(go.TreeModel, { isReadOnly: true, // don't allow the user to delete or copy nodes // build up the tree in an Array of node data nodeDataArray: traverseDom(document.activeElement) }); } // Walk the DOM, starting at document, and return an Array of node data objects representing the DOM tree // Typical usage: traverseDom(document.activeElement) // The second and third arguments are internal, used when recursing through the DOM function traverseDom(node, parentName, dataArray) { if (parentName === undefined) parentName = null; if (dataArray === undefined) dataArray = []; // skip everything but HTML Elements if (!(node instanceof Element)) return; // Ignore the navigation menus if (node.id === "navindex" || node.id === "navtop") return; // add this node to the nodeDataArray var name = getName(node); var data = { key: name, name: name }; dataArray.push(data); // add a link to its parent if (parentName !== null) { data.parent = parentName; } // find all children var l = node.childNodes.length; for (var i = 0; i < l; i++) { traverseDom(node.childNodes[i], name, dataArray); } return dataArray; } // Give every node a unique name function getName(node) { var n = node.nodeName; if (node.id) n = n + " (" + node.id + ")"; var namenum = n; // make sure the name is unique var i = 1; while (names[namenum] !== undefined) { namenum = n + i; i++; } names[namenum] = node; return namenum; } // When a Node is selected, highlight the corresponding HTML element. function nodeSelectionChanged(node) { if (node.isSelected) { names[node.data.name].style.backgroundColor = "lightblue"; } else { names[node.data.name].style.backgroundColor = ""; } }
想查看在線操作示例,。
本站文章除注明轉載外,均為本站原創或翻譯。歡迎任何形式的轉載,但請務必注明出處、不得修改原文相關鏈接,如果存在內容上的異議請郵件反饋至chenjj@fc6vip.cn