使用D3.js进行数据可视化

D3.js介绍

  D3.js是一个流行的JavaScript数据可视化库,全称为Data-Driven Documents,即数据驱动文档。它以数据为核心,通过数据来驱动文档的展示和操作。D3.js提供了丰富的API和工具,使得开发者能够创建出各种交互式和动态的数据可视化效果。

官方介绍网站:What is D3? | D3 by Observable

D3.js导入方式介绍

  在JavaScript中导入D3.js通常使用ESM+CDN、UMD+CDN和UMD+local这三种方式,其中:ESM (ES Modules):ESM是ECMAScript模块(ECMAScript Modules)的缩写,也被称为ES6模块,是JavaScript官方的模块化方案。它使用importexport语句进行模块的导入和导出,支持静态导入和动态导入。

CDN (Content Delivery Network):CDN即内容分发网络,是一种通过分布在多个地理位置的服务器来快速、有效地向用户分发内容的网络服务。使用CDN可以加快资源的加载速度,提高用户体验。

UMD (Universal Module Definition):UMD是一种通用的模块定义方式,旨在使JavaScript库或模块能够在多种环境中使用,包括浏览器全局变量方式、AMD环境和CommonJS环境(如Node.js)。UMD允许库或模块在各种不同的JavaScript模块加载器和环境中运行。

local:将JavaScript库或模块直接保存在本地项目中,而不是从外部CDN或其他远程位置加载。

D3.js导入方式1:ESM+CDN
<!DOCTYPE html>
<div id="container"></div>
<script type="module">

import * as d3 from "https://cdn.jsdelivr.net/npm/d3@7/+esm";

// 一大堆代码

</script>
D3.js导入方式2:UMD+CDN 
<!DOCTYPE html>
<div id="container"></div>
<script src="https://cdn.jsdelivr.net/npm/d3@7"></script>
<script type="module">

// 一大堆代码
</script>
 D3.js导入方式3:UMD+local
<!DOCTYPE html>
<div id="container"></div>
<script src="/d3.v7.js"></script>
<script type="module">

// 一大堆代码
</script>

D3.js文件官方下载地址:Getting started | D3 by Observable

使用D3.js绘制柱形图
<!DOCTYPE html>  
<html>  
<head>  
    <meta charset="utf-8">  
    <title>GGBoy</title>  
    <script src="/d3.v7.js"></script>  
</head>  
<body>  
    <script>  
        const width = 640;  
        const height = 400;  
        const marginTop = 20;  
        const marginRight = 20;  
        const marginBottom = 30;  
        const marginLeft = 40;  
        const innerWidth = width - marginLeft - marginRight;  
        const innerHeight = height - marginTop - marginBottom;  
        const svg = d3.select("body").append("svg")  
            .attr("width", width)  
            .attr("height", height);  
        const plotArea = svg.append("g")  
            .attr("transform", `translate(${marginLeft},${marginTop})`);  
        const x = d3.scaleBand()  
            .domain(["Category1", "Category2", "Category3"]) 
            .padding(0.1);
        const y = d3.scaleLinear()  
            .domain([0, 100]) 
            .range([innerHeight, 0]);  
  
        // Add the x-axis.  
        plotArea.append("g")  
            .attr("transform", `translate(0,${innerHeight})`)  
            .call(d3.axisBottom(x));  
  
        // Add the y-axis.  
        plotArea.append("g")  
            .call(d3.axisLeft(y));  
        const data = [  
            { category: "Category1", value: 50 },  
            { category: "Category2", value: 75 },  
            { category: "Category3", value: 30 }  
        ];  
  
        plotArea.selectAll(".bar")  
            .data(data)  
            .enter().append("rect")  
            .attr("class", "bar")  
            .attr("x", d => x(d.category))  
            .attr("width", x.bandwidth())  
            .attr("y", d => y(d.value))  
            .attr("height", d => innerHeight - y(d.value))  
            .attr("fill", "steelblue");  
    </script>  
</body>  
</html>

 使用D3.js绘制曲线图
<!DOCTYPE html>  
<html>  
<head>  
    <title>GGBoy</title>  
</head>  
<body>  
    <div id="container" style="width: 600px; height: 400px;"></div>  
    <script type="module">  
        import * as d3 from "https://cdn.jsdelivr.net/npm/d3@7/+esm";  
  
        var data = [  
            {date: '2024-05-01', close: 100},  
            {date: '2024-05-02', close: 110},  
            {date: '2024-05-03', close: 95},  
            {date: '2024-05-04', close: 120},  
            {date: '2024-05-05', close: 105}  
        ];  
        var parseDate = d3.timeParse("%Y-%m-%d");  
        data.forEach(function(d) {  
            d.date = parseDate(d.date);  
        });  
  
        const width = 600;  
        const height = 400;  
        const marginTop = 20;  
        const marginRight = 20;  
        const marginBottom = 30;  
        const marginLeft = 40;  
  
        var x = d3.scaleTime()  
            .range([marginLeft, width - marginRight])  
            .domain(d3.extent(data, function(d) { return d.date; }));  
        var y = d3.scaleLinear()  
            .range([height - marginBottom, marginTop])  
            .domain(d3.extent(data, function(d) { return d.close; }));  
        var svg = d3.select("#container").append("svg")  
            .attr("width", width)  
            .attr("height", height);  
  
        svg.append("g")  
            .attr("transform", `translate(0,${height - marginBottom})`)  
            .call(d3.axisBottom(x));  
        svg.append("g")  
            .attr("transform", `translate(${marginLeft},0)`)  
            .call(d3.axisLeft(y));  
  
        var line = d3.line()  
            .x(function(d) { return x(d.date); })  
            .y(function(d) { return y(d.close); })  
            .curve(d3.curveBasis);  
   
        svg.append("path")  
            .datum(data)  
            .attr("class", "line")  
            .attr("d", line)  
            .attr("stroke", "blue")  
            .attr("stroke-width", 2)  
            .attr("fill", "none");   
    </script>  
</body>  
</html>

 使用D3.js实现网页时钟
<!DOCTYPE html>  
<html lang="zh">  
<head>  
    <meta charset="UTF-8">  
    <meta name="viewport" content="width=device-width, initial-scale=1.0">  
    <title>GGBoy</title>  
    <script src="https://cdn.jsdelivr.net/npm/d3@7"></script>  
    <style>  
        .time {  
            font-family: Cursive;  
            font-size: 40px;  
            stroke: black;  
            stroke-width: 2;  
            fill: none; 
        }  
    </style>  
</head>  
<body>  
    <svg width="600" height="400"></svg> 
    <script>  
        function getTime() {  
            var time = new Date();  
            var hour = time.getHours();  
            var minute = time.getMinutes();  
            var second = time.getSeconds();  
            hour = hour < 10 ? '0' + hour : hour;
            minute = minute < 10 ? '0' + minute : minute;  
            second = second < 10 ? '0' + second : second;  
            return hour + ':' + minute + ':' + second;  
        }  
        var svg = d3.select("svg"); // 选择SVG元素  
        var timeText = svg.append("text")    
            .attr("x", 100)    
            .attr("y", 100)    
            .attr("class", "time")  
            .text(getTime());  
        function updateTime() {  
            timeText.text(getTime());  
        }  
        setInterval(updateTime, 1000);  
    </script>  
</body>  
</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/591626.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Linux服务器常用命令总结

view查找日志关键词 注意日志级别&#xff0c;回车后等一会儿&#xff0c;因为文件可能比较大加载完需要时间 当内容显示出来后&#xff0c;使用“/关键词”搜索 回车就能搜到&#xff0c;n表示查找下一个&#xff0c;N表示查找上一个 find 查找 find Family -name book …

华为平板手机如何清理应用市场的存储空间

如何清理应用市场的存储空间 适用产品&#xff1a; 手机&#xff0c;平板 适用版本&#xff1a;不涉及系统版本 如果您的应用市场显示应用的数据较大&#xff0c;可能是下载的安装包没有安装成功&#xff0c;导致安装包未自动删除。&#xff08;可参考&#xff1a;应用市场下…

Delta lake with Java--将数据保存到Minio

今天看了之前发的文章&#xff0c;居然有1条评论&#xff0c;看到我写的东西还是有点用。 今天要解决的问题是如何将 Delta产生的数据保存到Minio里面。 1、安装Minio&#xff0c;去官网下载最新版本的Minio&#xff0c;进入下载目录&#xff0c;运行如下命令&#xff0c;曾经…

2024年第11届生物信息学研究与应用国际会议(ICBRA 2024)即将召开!

2024年第11届生物信息学研究与应用国际会议&#xff08;ICBRA 2024&#xff09;将于2024年9月13-15日在意大利米兰举行。生物信息学&#xff0c;作为连接生物学与信息技术的桥梁&#xff0c;正日益成为探索生命奥秘、推动生命科学发展的重要力量。ICBRA 2024的召开&#xff0c;…

使用PyTorch从头实现Transformer

前言 本文使用Pytorch从头实现Transformer&#xff0c;原论文Attention is all you need paper&#xff0c;最佳解读博客&#xff0c;学习视频GitHub项目地址Some-Paper-CN。本项目是译者在学习长时间序列预测、CV、NLP和机器学习过程中精读的一些论文&#xff0c;并对其进行了…

突破传统 重新定义:3D医学影像PACS系统源码(包含RIS放射信息)实现三维重建与还原

突破传统&#xff0c;重新定义PACS/RIS服务,洞察用户需求&#xff0c;关注应用场景&#xff0c;新一代PACS/RIS系统&#xff0c;系统顶层设计采用集中分布式架构&#xff0c;满足医院影像全流程业务运行,同时各模块均可独立部署&#xff0c;满足医院未来影像信息化扩展新需求、…

爬虫自动化之drissionpage实现随时切换代理ip

目录 一、视频二、dp首次启动设置代理三、dp利用插件随时切换代理一、视频 视频直接点击学习SwitchyOmega插件使用其它二、dp首次启动设置代理 from DrissionPage import ChromiumPage, ChromiumOptions from loguru

成都旅游攻略

第一天 大熊猫基地(55一人) 切记要去早&#xff0c;否则只能看到熊猫屁股 文殊院(拜文殊菩萨) 杜甫草堂(50一人) 宽窄巷子(旅游打卡拍照) 奎星楼街吃晚饭 这里的饭菜很可口 第二天 东郊记忆(成都故事.川剧变脸)主要是拍照打卡 春熙路 IFS国金中心(打卡熊猫屁屁) 太…

【数据结构与算法】堆

定义 堆是是一个完全二叉树&#xff0c;其中每个节点的值都大于等于或小于等于其子节点的值。这取决于是最大堆还是最小堆。 小根堆&#xff1a;每个根都小于子节点。 大根堆&#xff1a;每个根都大于子节点。 以下部分图例说明来源&#xff1a;【从堆的定义到优先队列、堆排…

使用 TensorFlow 和 Keras 构建 U-Net

原文地址&#xff1a;building-a-u-net-with-tensorflow-and-keras 2024 年 4 月 11 日 计算机视觉有几个子学科&#xff0c;图像分割就是其中之一。如果您要分割图像&#xff0c;则需要在像素级别决定图像中可见的内容&#xff08;执行分类时&#xff09;&#xff0c;或者从像…

模型 SOP(标准操作程序)

系列文章 分享 模型&#xff0c;了解更多&#x1f449; 模型_思维模型目录。标准化流程&#xff0c;提质增效&#xff0c;保障合规。 1 SOP的应用 1.1 餐厅日常卫生清洁标准操作程序&#xff08;SOP&#xff09; 下面展示一个餐厅如何通过SOP确保清洁工作的标准化&#xff0c…

202209青少年软件编程(Python) 等级考试试卷(一级)

第 1 题 【单选题】 表达式 len(“学史明理增信 , 读史终生受益”) > len(" reading history will benefit you ") 的结果是? ( ) A :0 B :True C :False D :1 正确答案:C 试题解析: 第 2 题 【单选题】 在 turtle 画图中, 常常使用 turtle.color(co…

【doghead】mac构建

先构建libuv libuv ✘ zhangbin@zhangbin-mbp-2  ~/tet/Fargo/zhb-bifrost/Bifrost-202403/worker/third_party/libuv/build   main  cmake .. -DBUILD_TESTING=ON -- The C compiler identification is AppleClang 12.0.5.12050022 -- Check for working C compiler: …

Git的基本操作和使用

git分支指令 列出所有本地分支 git branchmaster是绿的 前面有个 表示当前分支是master* 列出所有远程分支 git branch -r列出所有本地分支和远程分支 git branch -a新建一个分支&#xff0c;但依然停留在当前分支 git branch [branch-name]新建一个分支&#xff0c;并切…

【全网首出】npm run serve报错 Expression: thread_id_key != 0x7777

总结 困扰了一天&#xff01;&#xff01;&#xff01;一直以为是自己哪里配置错了&#xff0c; 结果最后发现是node.js官方的问题&#xff0c; Node.js v16.x版本的fibers.node被弃用 本文阅读大概&#xff1a;3min #npm run serve时就报错 #找了一天的文章&#xff0c;找不…

U盘到底要格式化成什么格式比较好?

前言 前段时间有小伙伴问我&#xff1a;U盘为啥无法粘贴超过4GB的压缩包。 相信这个问题很多人都会遇到&#xff0c;无论是压缩包、镜像文件还是电影&#xff0c;都会有超过4GB的时候。 如果文件超过了4GB&#xff0c;那么就会小伙伴遇到电脑提示&#xff1a;无法粘贴超过4G…

结构体介绍(1)

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 结构体&#xff08;1&#xff09; 前言一、struct介绍结构体声明结构体创建和初始化struct 的特殊声明结构体自引用 二、结构体内存对齐2.1.对齐规则 总结 前言 结构体 属于…

npm install digital envelope routines::unsupported解决方法

目录 一、问题描述二、问题原因三、解决方法 一、问题描述 执行命令 npm install 报错&#xff1a;digital envelope routines::unsupported 二、问题原因 Node.js 17 版本引入了 OpenSSL 3.0&#xff0c;它在算法和密钥大小方面实施了更为严格的限制。这一变化导致 npm 的升…

✔ ★Java项目——设计一个消息队列(五)【虚拟主机设计】

虚拟主机设计 创建 VirtualHost实现构造⽅法和 getter创建交换机删除交换机创建队列删除队列创建绑定删除绑定发布消息 ★路由规则1) 实现 route ⽅法2) 实现 checkRoutingKeyValid3) 实现 checkBindingKeyValid4) 实现 routeTopic5) 匹配规则测试⽤例6) 测试 Router 订阅消息1…

idea 新建spring maven项目、ioc和依赖注入

文章目录 一、新建Spring-Maven项目二、在Spring-context使用IOC和依赖注入 一、新建Spring-Maven项目 在pom.xml文件中添加插件管理依赖 <build><plugins><plugin><artifactId>maven-compiler-plugin</artifactId><version>3.1</ver…
最新文章