react-d3-tree:React組件創建交互式D3樹形圖

在這里插入代碼片

在這里插入圖片描述

import React from "react";
import ReactDOM from "react-dom";
import Tree from "react-d3-tree";import "./styles.css";const myTreeData = [{name: "Gaurang Torvekar",attributes: {keyA: "val A",keyB: "val B",keyC: "val C"},children: [{name: "Avadhoot",attributes: {keyA: "val A",keyB: "val B",keyC: "val C"},children: [{name: "Richard"},{name: "Constantine",children: [{name: "Mia"}]},{name: "Daniel"}]},{name: "Mia"},{name: "Varun",attributes: {keyA: "val A",keyB: "val B",keyC: "val C"},children: [{name: "Ivo",attributes: {keyA: "val A",keyB: "val B",keyC: "val C"},children: [{name: "Level 2: A",attributes: {keyA: "val A",keyB: "val B",keyC: "val C"},children: [{name: "Level 2: A",attributes: {keyA: "val A",keyB: "val B",keyC: "val C"}},{name: "Level 2: B"}]},{name: "Level 2: B"}]},{name: "Vijay"}]},{name: "Mohit",children: [{name: "Rohit",attributes: {keyA: "val A",keyB: "val B",keyC: "val C"},children: [{name: "Level 2: A",attributes: {keyA: "val A",keyB: "val B",keyC: "val C"},children: [{name: "Level 2: A",attributes: {keyA: "val A",keyB: "val B",keyC: "val C"}},{name: "Level 2: B"}]}]},{name: "Pranav"}]}]}
];const svgSquare = {shape: "rect",shapeProps: {width: 180,height: 40,x: 0,y: -20,color: "#ffffff"}
};const test = {shape: "rect",shapeProps: {width: 0,height: 0,x: -20,y: 20,stroke: "#2F80ED"}
};const nodeStyle = (<svg viewbox="0 0 100 60" xmlns="http://www.w3.org/2000/svg"><rectwidth="80"height="40"x="10"y="10"style="fill: skyblue; stroke: cadetblue; stroke-width: 2;"/></svg>
);const treeStyle = {nodes: {node: {circle: <nodeStyle />,name: <nodeStyle />,attributes: <nodeStyle />}}
};class NodeLabel extends React.PureComponent {render() {const { className, nodeData } = this.props;return (<divclassName={className}style={{background: "#ffffff",height: "70px",borderTop: "2px solid #2F80ED",textAlign: "center",// position: "fixed",zIndex: "1000",// left: "-10px",boxShadow: "0px 10px 10px rgba(0, 0, 0, 0.1)",padding: "5px 0",borderRadius: "5px"}}>{nodeData.name}</div>);}
}function App() {return (<div className="App"><h1>ORG Chart POC</h1><div id="treeWrapper" style={{ width: "100%", height: "100vh" }}><Treedata={myTreeData}// nodeSvgShape={svgSquare}nodeSvgShape={test}pathFunc="step"separation={{ siblings: 2, nonSiblings: 2 }}orientation="vertical"translate={{ x: 900, y: 100 }}allowForeignObjects={true}nodeLabelComponent={{render: <NodeLabel className="myLabelComponentInSvg" />,foreignObjectWrapper: {width: 220,height: 200,y: -50,x: -100}}}initialDepth={0.02}/></div></div>);
}const rootElement = document.getElementById("root");
ReactDOM.render(<App />, rootElement);

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/16571.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/16571.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/16571.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

【軟考】2024年5月系統架構設計師考試感受

一 考試時間 5???25日上午: 8點30-12點30: 綜合知識和案例分析?? 5???25日下午: 14點30-16點30: 論文?? 二 考試感受 2024年5月25日早上5點多一點,我就起床了????。簡單洗漱后,就準備出門。可是,天吶,我的手機??忘記充電了,所以就趕緊應急充會電??…

基于Llama 3搭建中文版(Llama3-Chinese-Chat)大模型對話聊天機器人

前面兩篇博文&#xff0c;我們分別在個人筆記本電腦部署了Llama 3 8B參數大模型&#xff0c;并使用Ollama搭建了基于 Web 可視化對話聊天機器人&#xff0c;可以在自己電腦上愉快的與Llama大模型 Web 機器人對話聊天了。但在使用過程中&#xff0c;筆者發現Llama大模型經常出現…

匯編一:匯編語言前的基礎知識

計算機的工作原理就是取址執行,在哪兒執行呢,在cpu里面執行,從哪里面去取址呢?從內存中去取址,內存又被叫做存儲器 可是,cpu和存儲器是2個分開的硬件設備,那么是怎么做到把存儲器里面的東西傳給cpu呢,這就需要總線了 1.總線 總線一共可以分為3種, 一種是數據總線,一種是控制總…

OpenWrt U盤安裝使用 詳細教程 x86/64平臺 軟路由實測 系列一

1 官方穩定 版:OpenWrt 23.05 OpenWrt Downloads #根據實際情況選擇 PC支持uefi,選擇版本&#xff1a;https://downloads.openwrt.org/releases/23.05.3/targets/x86/64/openwrt-23.05.3-x86-64-generic-ext4-combined-efi.img.gz 2 rufus 制作U盤啟動 3 制作好的U盤,接入主…

Redux基礎

簡介 狀態管理工具&#xff0c;集中式管理react、vue、angular等應用中多個組件的狀態&#xff0c;是一個庫,使用之后可以清晰的知道應用里發生了什么以及數據是如何修改&#xff0c;如何更新的 在項目中添加 Redux 并不是必須的,根據項目需求選擇是否引入 Redux 三個原則 …

Linux部分漏洞處理

1、ICMP timestamp請求響應漏洞 ICMP timestamp請求響應漏洞是指&#xff0c;當網絡設備接收到ICMP timestamp請求時&#xff0c;它會返回當前時間戳作為響應&#xff0c;這可能導致設備的時間戳被暴露&#xff0c;進而可能被用于計算機時間戳協議&#xff08;TLS&#xff09;的…

PDF.js

什么是 PDF.js&#xff1f; PDF.js 是由 Mozilla 開發的一個用于呈現 PDF 文件的 JavaScript 庫。它允許開發者將 PDF 文件直接嵌入到網頁中&#xff0c;而無需使用插件或其他外部工具。PDF.js 使用 HTML5 技術&#xff0c;利用 Canvas 元素來呈現 PDF 內容&#xff0c;并提供…

基于集成經驗模態分解的心電信號降噪和基于希爾伯特變換的R峰檢測(MATLAB R2018)

近年來&#xff0c;心臟病已成為危害人類健康最常見的疾病。為了有效預防心臟疾病的發生&#xff0c;往往需要更加準確地采集與診斷心電信號&#xff0c;以便于更好地反映心臟情況。心電信號作為人體生理信號&#xff0c;對于識別心臟異常和心臟疾病具有重要的參考價值。心電信…

ubuntu如何安裝gitlab runner

一、什么是GitLab Runner GitLab Runner 是 GitLab 提供的一個開源工具,用于在構建、測試和部署過程中執行作業。它是 GitLab 持續集成和持續部署(CI/CD)工作流的核心組件之一。 GitLab Runner 有以下主要功能: 作業執行:GitLab Runner 會接收來自 GitLab 的作業請求,并在指定…

ROS基礎學習-ROS通信機制研究

研究ROS通信機制 研究ROS通信機制 0.前言1.話題通信1.1 理論模型1.2 話題通訊的基本操作1.2.1 C++1.2.2 Python0.前言 機器人是一種高度復雜的系統性實現,在機器人上可能集成各種傳感器(雷達、攝像頭、GPS…)以及運動控制實現,為了解耦合,在ROS中每一個功能點都是一個單獨的…

從File類開始,學習Java文件操作

哈嘍&#xff0c;各位小伙伴們&#xff0c;你們好呀&#xff0c;我是喵手。運營社區&#xff1a;C站/掘金/騰訊云&#xff1b;歡迎大家常來逛逛 今天我要給大家分享一些自己日常學習到的一些知識點&#xff0c;并以文字的形式跟大家一起交流&#xff0c;互相學習&#xff0c;一…

windows安裝SQL Server

1、下載 下載網頁&#xff1a;SQL Server 下載 | Microsoft 2022版下載地址&#xff1a;https://go.microsoft.com/fwlink/p/?linkid2215158&clcid0x404&culturezh-tw&countrytw 下載結果&#xff1a;SQL2022-SSEI-Dev.exe 打開選第三個&#xff0c;下載介質&…

自定義Linux命令,顯示docker鏡像、容器信息

1、修改環境變量&#xff08;僅對當前用戶有效&#xff09; vim ~/.bashrc2、給命令取別名 alias dpsdocker ps --format "table{{.ID}}\t{{.Names}}\t{{.Status}}\t{{.Ports}}" alias disdocker images#保存并退出 :wq3、讓配置重新生效 source ~/.bashrc4、測試&…

ChatGPT技術演進簡介

chatGPT&#xff08;chat generative pre-train transformer&#xff0c; 可以對話的預訓練trasformer模型&#xff09;&#xff0c;討論點&#xff1a; 1、chatGPT為什么突然火了 2、GPT 1.0、2.0、3.0、3.5 、4和4o區別和特性&#xff0c;在不同應用場景中如何選對模型 3、未…

基于ESP8266的無線通信系統設計

本文介紹了一種基于ESP8266的無線通信系統設計方案。ESP8266是一款功能強大且成本低廉的WiFi模塊&#xff0c;非常適合用于構建無線通信系統。本設計主要圍繞ESP8266模塊的功能特點&#xff0c;闡述了系統的硬件組成、軟件設計以及實際應用示例。 關鍵詞&#xff1a;ESP8266&a…

【docker】倉庫harbor的部署

harbor介紹 Harbor 是一個用于存儲和管理 Docker 鏡像的開源倉庫。它提供了一系列的功能&#xff0c;比如用戶管理、訪問控制、鏡像管理、日志審計和安全掃描等。Harbor 可以作為私有倉庫來使用&#xff0c;也可以與公有倉庫&#xff08;如 Docker Hub&#xff09;集成使用。 …

python數據分析——apply 1

參考資料&#xff1a;活用pandas庫 apply是指把函數同時作用于DataFrame的每一行或每一列。類似于編寫一些跨每行或每列的for循環&#xff0c;并同時調用apply函數。 1、函數 函數是對python代碼進行分組和復用的一種方法。如果某段代碼會被多次使用&#xff0c;并且使用時是需…

JS Lab

如何用 JavaScript 在瀏覽器中彈窗如何在 JavaScript 中制作鼠標滑過按鈕改變背景顏色如何在 JS 中點擊按鈕使數字增加如何在 JS 中循環打印多少次 HTML <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title…

優化FPGA SelectIO接口VREF生成電路

引言&#xff1a;FPGA設計中使用了各種PCB SelectIO?接口VREF生成電路。有時即使在以前的設計中已經成功的在電路板上設計了VREF生成電路&#xff0c;也會在VREF引腳上發現大量噪聲&#xff08;200–400mV&#xff09;。大量VREF噪聲的存在可能導致高性能SelectIO接口&#xf…

瑞昱半導體AMB82 MINI(RTL8735B)Arduino 方法介紹

介紹瑞昱半導體&#xff08;Realtek &#xff09;AMB82-Mini 物聯網 AI開發板 Ameba是一個易于編程的平臺&#xff0c;用于開發各種物聯網應用程序。AMB82 MINI配備了各種外設接口&#xff0c;包括WiFi、BLE、GPIO INT、I2C、UART、SPI、PWM、ADC。通過這些接口&#xff0c;AM…