d3_v7繪制折線圖

<!DOCTYPE html>
<html><head><meta charset='utf-8'><title>需求</title><script src="https://d3js.org/d3.v7.min.js"></script><style>* {margin: 0;padding: 0;}html, body {width: 100%;height: 100%;display: flex;justify-content: center;align-items: center;}#graph-container {width: 50%;height: 30%;position: relative;display: flex;flex-direction: column;/*一定要加position: relative*/}#graph{width: 100%;flex: 1;}.chart-title {text-align: center;color: #333;margin-bottom: 20px;}#zhe-xian-tooltip {position: absolute;padding: 12px;background: rgba(0, 0, 0, 0.85);color: white;border-radius: 6px;pointer-events: none;font-size: 14px;font-family: sans-serif;opacity: 0;}.zhe-xian-circle{fill: #e63946;stroke: white;stroke-width: 2;transition: r 0.2s;}.zhe-xian-line {fill: none;stroke: #e63946;stroke-width: 3;stroke-linejoin: round;}</style>
</head>
<body>
<button id="myButton" style="margin-right: 40px">數據變更</button><div id="graph-container"><h2 class="chart-title">標題</h2><div id="graph"><div id="zhe-xian-tooltip"></div></div></div>
<script>const generateData = () => {return Array.from({length: Math.floor(Math.random() * 12) + 5}, (_, index) => ({time: index + 1,count: Math.floor(Math.random() * 100) // 生成0-99的隨機整數}));}const drawZheXianGraph = (dataset, container, update) => {dataset.sort((a, b) => a.time - b.time);//按照月份排序console.log("繪制圖形數據", dataset);const element = document.getElementById(container);const width = element.offsetWidth;  // 寬度(含 padding + border)const height = element.offsetHeight; // 高度(含 padding + border)const margin = {left: 50,right: 30,top: 30,bottom: 50}if (!update) {d3.select(`#${container}`).append('svg').attr('width', width).attr('height', height);}const svg = d3.select(`#${container}`).select('svg');//定義x軸比例尺const xScale = d3.scaleBand().domain(dataset.map(item => item.time)).range([margin.left, width - margin.right]).padding(0) // 設置柱子之間的間隙.paddingInner(1); // 設置柱子內部的間隙console.log(xScale(1), xScale(2));// 獲取所有count值組成的數組const counts = dataset.map(item => item.count);const maxCount = Math.max(...counts);//定義y軸比例尺const yScale = d3.scaleLinear().domain([0, maxCount]).range([height - margin.bottom, margin.top]);//定義繪制折線的函數const line = d3.line().x(function (d) {return xScale(d.time) + xScale.bandwidth() / 2;}).y(function (d) {return yScale(d.count);})// .curve(d3.curveCardinal) //曲線.curve(d3.curveLinear) //直線const xAxis = d3.axisBottom(xScale).tickFormat(function (d, i) {return dataset[i].time;});const yAxis = d3.axisLeft(yScale);// 每個區域繪制一個矩形用于觸發事件const _w = (width - margin.left - margin.right) / (dataset.length - 1);const tooltip = d3.select('#zhe-xian-tooltip');function showTooltip(event, d) {tooltip.transition().duration(200).style("opacity", 0.9);tooltip.html(`time: ${d.time}<br>count: ${d.count}`).style("left", (xScale(d.time) + xScale.bandwidth() / 2 + 10) + "px").style("top", (yScale(d.count) - 10) + "px");}function hideTooltip() {tooltip.transition().duration(500).style("opacity", 0);}if (update) {//更新x軸和y軸svg.select(".zhe-xian-x-axis").transition().duration(500).call(xAxis);svg.select(".zhe-xian-y-axis").transition().duration(500).call(yAxis)svg.selectAll(".zhe-xian-line").datum(dataset).join("path").attr("class", "zhe-xian-line").transition().duration(500).attr("d", line)svg.selectAll('.zhe-xian-circle').data(dataset).join("circle").attr("class", "zhe-xian-circle").attr("r", 5).style('cursor', 'pointer').on('mouseover', showTooltip).on('mouseout', hideTooltip).transition().duration(500).attr('cx', function (d) {return xScale(d.time) + xScale.bandwidth() / 2;}).attr('cy', function (d) {return yScale(d.count);})} else {svg.append('path').datum(dataset).attr('class', 'zhe-xian-line').attr('d', line)svg.append('g').attr('class', 'zhe-xian-x-axis').attr('transform', 'translate(0,' + (height - margin.bottom) + ')').call(xAxis);svg.append('g').attr('class', 'zhe-xian-y-axis').attr('transform', 'translate(' + margin.left + ',0)').call(yAxis);// 繪制圓點svg.selectAll('.zhe-xian-circle').data(dataset).enter().append('circle').attr('class', 'zhe-xian-circle').attr('cx', function (d) {return xScale(d.time) + xScale.bandwidth() / 2;}).attr('cy', function (d) {return yScale(d.count);}).attr('r', 5)  //修改圓點大小.style('cursor', 'pointer').on('mouseover', showTooltip).on('mouseout', hideTooltip);svg.append("text").attr("class", "axis-label").attr("transform", "rotate(-90)").attr("x", -height/2).attr("y", margin.left-30).style("text-anchor", "middle").text("數量");svg.append("text").attr("class", "axis-label").attr("x", width / 2).attr("y", height-10).style("text-anchor", "middle").text("月份");}}drawZheXianGraph(generateData(), "graph", false)// 綁定點擊事件document.getElementById('myButton').addEventListener('click', function () {console.log("我被點擊了")drawZheXianGraph(generateData(), "graph", true)// 這里可以添加更多自定義邏輯});
</script>
</body>
</html>

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

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

相關文章

Hotspot分析(1):單細胞轉錄組識別信息基因(和基因模塊)

這一期我們介紹一個常見的&#xff0c;高分文章引用很高的一個單細胞轉錄組分析工具Hotspot&#xff0c;它可針對單細胞轉錄組數據識別有意義基因或者基因module&#xff0c;類似于聚類模塊。所謂的”informative "的基因是那些在給定度量中相鄰的細胞之間以相似的方式表達…

爬蟲準備前工作

1.Pycham的下載 網址&#xff1a;PyCharm: The only Python IDE you need 2.Python的下載 網址&#xff1a;python.org&#xff08;python3.9版本之后都可以&#xff09; 3.node.js的下載 網址&#xff1a;Node.js — 在任何地方運行 JavaScript&#xff08;版本使用18就可…

基于Springboot旅游網站系統【附源碼】

基于Springboot旅游網站系統 效果如下&#xff1a; 系統登陸頁面 系統主頁面 景點信息推薦頁面 路線詳情頁面 景點詳情頁面 確認下單頁面 景點信息管理頁面 旅游路線管理頁面 研究背景 隨著互聯網技術普及與在線旅游消費習慣的深化&#xff0c;傳統旅游服務模式面臨效率低、…

利用KMP找出模式串在目標串中所有匹配位置的起始下標

問題關鍵&#xff1a;完成首次匹配之后需要繼續進行模式匹配。 到這一步后&#xff0c;我們不能直接將j 0然后開始下一輪匹配&#xff0c;因為已經匹配過的部分&#xff08;藍色部分&#xff09;中仍然可能存在與模式串重疊的子串&#xff1a; 解決辦法&#xff1a; 找到藍…

RR(Repeatable Read)級別如何防止幻讀

在 MySQL 數據庫事務隔離級別中&#xff0c;RR&#xff08;可重復讀&#xff09; 通過 MVCC&#xff08;多版本并發控制&#xff09; 和 鎖機制 的組合策略來避免幻讀問題。 一、MVCC機制&#xff1a;快照讀與版本控制 快照讀&#xff08;Snapshot Read&#xff09; 每個事務啟…

Android運行時ART加載類和方法的過程分析

目錄 一,概述 二,ART運行時的入口 一,概述 既然ART運行時執行的都是翻譯DEX字節碼后得到的本地機器指令了&#xff0c;為什么還需要在OAT文件中包含DEX文件&#xff0c;并且將它加載到內存去呢&#xff1f;這是因為ART運行時提供了Java虛擬機接口&#xff0c;而要實現Java虛…

Javase 基礎加強 —— 02 泛型

本系列為筆者學習Javase的課堂筆記&#xff0c;視頻資源為B站黑馬程序員出品的《黑馬程序員JavaAI智能輔助編程全套視頻教程&#xff0c;java零基礎入門到大牛一套通關》&#xff0c;章節分布參考視頻教程&#xff0c;為同樣學習Javase系列課程的同學們提供參考。 01 認識泛型…

Oracle VirtualBox 在 macOS 上的詳細安裝步驟

Oracle VirtualBox 在 macOS 上的詳細安裝步驟 一、準備工作1. 系統要求2. 下載安裝包二、安裝 VirtualBox1. 掛載安裝鏡像2. 運行安裝程序3. 處理安全限制(僅限首次安裝)三、安裝擴展包(增強功能)四、配置第一個虛擬機1. 創建新虛擬機2. 分配內存3. 創建虛擬硬盤4. 加載系…

RAGFlow 接入企業微信應用實現原理剖析與最佳實踐

背景 近期有醫美行業客戶咨詢我們智能客服產品&#xff0c;期望將自己企業的產品、服務以及報價信息以企微應用的方式給到客戶進行體驗互動&#xff0c;提升企業運營效率。關于企業微信對接&#xff0c;我們分享下最佳實踐&#xff0c;拋磚引玉。效果圖如下&#xff1a; 這里也…

【心海資源】子比主題新增注冊與會員用戶展示功能模塊及實現方法

內容改寫&#xff1a; 本次分享的是子比主題頂部展示注冊用戶與會員信息的功能模塊及其實現方式。 你可以通過兩種方式啟用該功能&#xff1a; 直接在后臺進入“外觀 → 小工具”啟用該展示模塊&#xff0c;操作簡便&#xff1b;也可將提供的代碼覆蓋至子比主題目錄中&#…

CSDN積分詳解(介紹、獲取、用途)

&#x1f91f;致敬讀者 &#x1f7e9;感謝閱讀&#x1f7e6;笑口常開&#x1f7ea;生日快樂?早點睡覺 &#x1f4d8;博主相關 &#x1f7e7;博主信息&#x1f7e8;博客首頁&#x1f7eb;專欄推薦&#x1f7e5;活動信息 文章目錄 積分**一、積分類型及用途****二、積分獲取途…

【iview】es6變量結構賦值(對象賦值)

變量的解構賦值 以iview的src/index.js中Vue.prototype.$IVIEW改造為例練習下怎么使用變量的解構賦值 原來的寫法&#xff1a; const install function(Vue, opts {}) {if (install.installed) return;locale.use(opts.locale);locale.i18n(opts.i18n);Object.keys(iview).fo…

【c++深入系列】:萬字詳解vector(附模擬實現的vector源碼)

&#x1f525; 本文專欄&#xff1a;c &#x1f338;作者主頁&#xff1a;努力努力再努力wz &#x1f4aa; 今日博客勵志語錄&#xff1a; 種子破土時從不問‘會不會有光’&#xff0c;它只管生長 ★★★ 本文前置知識&#xff1a; 模版 1.什么是vector 那么想必大家都學過順…

MySQL基礎關鍵_007_DQL 練習

目 錄 一、題目 二、答案&#xff08;不唯一&#xff09; 1.查詢每個部門薪資最高的員工信息 2.查詢每個部門高于平均薪水的員工信息 3. 查詢每個部門平均薪資等級 4.查詢部門中所有員工薪資等級的平均等級 5.不用分組函數 max 查詢最高薪資 6.查詢平均薪資最高的部門編…

Jenkis安裝、配置及賬號權限分配保姆級教程

Jenkis安裝、配置及賬號權限分配保姆級教程 安裝Jenkins下載Jenkins啟動Jenkins配置Jenkins入門Jenkins配置配置中文配置前端自動化任務流新建任務拉取代碼打包上傳云服務并運行配置后端自動化任務流新建任務拉取代碼打包上傳云服務并運行賬號權限分配創建用戶分配視圖權限安裝…

虛函數 vs 純虛函數 vs 靜態函數(C++)

&#x1f9e9; 一圖看懂&#xff1a;虛函數 vs 純虛函數 特性虛函數&#xff08;Virtual&#xff09;純虛函數&#xff08;Pure Virtual&#xff09;語法virtual void foo();virtual void foo() 0;是否必須實現? 必須在類中實現? 不在基類實現&#xff0c;派生類必須實現是…

2025年滲透測試面試題總結-拷打題庫36(題目+回答)

網絡安全領域各種資源&#xff0c;學習文檔&#xff0c;以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各種好玩的項目及好用的工具&#xff0c;歡迎關注。 目錄 2025年滲透測試面試題總結-拷打題庫36 PHP代碼常見入口函數查找 PHP框架路由方法熟悉度 PHP變量覆蓋…

STL之vector容器

vector的介紹 1.vector是可變大小數組的容器 2.像數組一樣&#xff0c;采用連續的空間存儲&#xff0c;也就意味著可以通過下標去訪問&#xff0c;但它的大小可以動態改變 3.每次的插入都要開空間嗎&#xff1f;開空間就要意味著先開臨時空間&#xff0c;然后在拷貝舊的到新…

[學成在線]22-自動部署項目

自動部署 實戰流程 下邊使用jenkins實現CI/CD的流程。 1、將代碼使用Git托管 2、在jenkins創建任務&#xff0c;從Git拉取代碼。 3、拉取代碼后進行自動構建&#xff1a;測試、打包、部署。 首先將代碼打成鏡像包上傳到docker私服。 自動創建容器、啟動容器。 4、當有代…

74HC123的電路應用場景

74HC123的電路應用場景 **1. 引腳功能示例****2. 核心功能****&#xff08;1&#xff09;單穩態觸發器****&#xff08;2&#xff09;雙獨立通道****&#xff08;3&#xff09;靈活觸發方式** **3. 工作原理****4. 典型應用場景****&#xff08;1&#xff09;定時與延時控制***…