0

0

Blazor 使用 Chart.js 绘制图表的方法

月夜之吻

月夜之吻

发布时间:2026-02-04 08:42:10

|

387人浏览过

|

来源于php中文网

原创

Blazor中使用Chart.js需通过JS Interop调用其API,核心步骤包括:引入Chart.js脚本、定义带唯一ID的canvas元素、在OnAfterRenderAsync中初始化图表实例,并复用实例更新数据以避免重复创建错误。

blazor 使用 chart.js 绘制图表的方法

Blazor 中使用 Chart.js 绘制图表,核心是通过 JavaScript 互操作(JS Interop)调用 Chart.js 的 API。由于 Chart.js 是纯前端库,不原生支持 Blazor 的组件模型,因此需手动初始化 canvas 元素、注入脚本,并在合适时机(如组件渲染后)创建图表实例。

引入 Chart.js 脚本

wwwroot/index.html(WebAssembly)或 wwwroot/_Host.cshtml(Server)的 前添加:

  • CDN 方式(推荐快速验证):
  • 或下载 chart.js 文件放入 wwwroot/js/,再引用本地路径

定义 canvas 元素并设置唯一 ID

在 Blazor 组件(如 Index.razor)中添加 canvas 标签,必须指定 id,Chart.js 需要它来定位绘图区域:

  • ID 值需全局唯一,避免多个图表冲突
  • 可配合 CSS 控制响应式尺寸,但建议保留 width/height 属性作为初始画布分辨率

通过 JS Interop 创建图表

在组件中声明 JS 模块引用,并在 OnAfterRenderAsyncOnInitializedAsync 中调用初始化逻辑(推荐 OnAfterRenderAsync 确保 DOM 已就绪):

jquery带商品分类侧边栏列表的商城导航菜单
jquery带商品分类侧边栏列表的商城导航菜单

这是一款使用jquery制作的带商品分类侧边栏列表的商城导航菜单。该商城菜单兼容ie8浏览器。用户可以通过点击左侧的下拉菜单来查看各种商品的列表,非常实用和方便。 使用方法 在页面中引入样式文件style.css和jquery.min.js文件。

下载
  • 定义 JS 函数(如在 wwwroot/js/charts.js):
    window.createBarChart = (elementId, labels, data) => {
    new Chart(document.getElementById(elementId), {
    type: 'bar',
    data: { labels, datasets: [{ data }] }
    });
    };
  • Blazor 组件中调用:
    @inject IJSRuntime JSRuntime
    @code {
    private bool chartRendered;
    protected override async Task OnAfterRenderAsync(bool firstRender) {
    if (!chartRendered) {
    await JSRuntime.InvokeVoidAsync("createBarChart", "myChart",
    new[] { "Jan", "Feb", "Mar" }, new[] { 12, 19, 3 });
    chartRendered = true;
    }
    }
    }

更新图表数据(非重新渲染)

若需动态更新,不要重复调用构造函数(会报错“Canvas is already in use”),而应复用已有实例:

  • 在 JS 中保存 chart 实例并提供更新方法:
    window.charts = {};
    window.initChart = (id, config) => {
    charts[id] = new Chart(...);
    }
    window.updateChart = (id, newData) => {
    const chart = charts[id];
    if (chart) { chart.data.datasets[0].data = newData; chart.update(); }
    }
  • Blazor 中调用 JSRuntime.InvokeVoidAsync("updateChart", "myChart", newData)

基本上就这些。关键点在于:确保 canvas 存在、JS 初始化时机正确、复用实例而非重复创建。不需要第三方 NuGet 包,原生 JS Interop 就够用,轻量且可控。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

790

2023.08.22

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

534

2023.09.20

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

534

2023.09.20

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

516

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

307

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

381

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5425

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

483

2023.09.01

全国统一发票查询平台入口合集
全国统一发票查询平台入口合集

本专题整合了全国统一发票查询入口地址合集,阅读专题下面的文章了解更多详细入口。

19

2026.02.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.2万人学习

CSS教程
CSS教程

共754课时 | 27.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号