在Blazor中使用Chart.js生成图表

1. 在Blazor中使用Chart.js

  1. 首先,从Chart.js官方网站下载Chart.js库文件。
    推荐下载这个构建好的版本https://cdnjs.com/libraries/Chart.js,最新版是v4.2.1

  2. 在Blazor项目中把刚刚下载好的Chart.js放到wwwroot目录下。

  3. 在Blazor项目中的Pages文件夹下_Host.cshtml文件中添加以下代码:

    <script src="_framework/blazor.webassembly.js"></script>
    <-- 添加下面这句 -->
    <script src="~/Chart.js"></script>
    
  4. 在Blazor组件中使用Chart.js,需要在组件中添加以下代码:
    注意!这个canvas标签的id非常重要!后面调用js的时候要用到它!
    在组件顶部添加一行代码,注入JSRuntime

     @page "/"
     @inject IJSRuntime JS
    
     <PageTitle>BlazorWithChartJS</PageTitle>
     <p>
         <h2>
             在Blazor中使用 
             <code><strong>JavaScript</strong></code>
             调用
             <code><strong>Chart.JS</strong></code>
             绘制曲线图
         </h2>
     </p>
       
     <div class="chart">
         <canvas id="AnimationsChart"></canvas>
     </div>
    
  5. Index组件的@code代码块中,添加以下C#代码:

        protected override async Task OnAfterRenderAsync(bool firstRender)
        {
            if (firstRender)
            {
                var jsmodule = $"./Pages/Index.razor.js";
                var jSObject = await JS.InvokeAsync<IJSObjectReference>("import", jsmodule);
                await jSObject.InvokeVoidAsync("animationsChart");
            }
            await base.OnAfterRenderAsync(firstRender);
        }
    
  6. 接下来我们在组件所在目录下创建一个当前组件隔离的js文件Index.razor.js,在组件的代码块中,添加以下JavaScript代码:

    export function animationsChart() {
            const ctx = document.getElementById('AnimationsChart');
    
            const data = {
                labels: ['January', 'February', 'March', 'April', 'May', 'June', 'July'],
                datasets: [{
                    label: 'Looping tension',
                    data: [65, 59, 80, 81, 26, 55, 40],
                    fill: false,
                    borderColor: 'rgb(75, 192, 192)',
                }]
            };
    
            const config = {
                type: 'line',
                data: data,
                options: {
                    animations: {
                        tension: {
                            duration: 1000,
                            easing: 'linear',
                            from: 1,
                            to: 0,
                            loop: true
                        }
                    },
                    scales: {
                        y: {
                            min: 0,
                            max: 100
                        }
                    }
                }
            };
    
            new Chart(ctx, config);
        }
    

    这将创建一个简单的折线图,您可以根据需要更改类型、数据和选项。

  7. 运行Blazor应用程序,您应该能够看到您的Chart.js图表!

blazorChartJSRunPng

更多图表类型等信息,请参阅Chart.js官方文档。https://www.chartjs.com.cn/docs/

  1. 上面的相关代码我放在GitHub了,有需要的可以查看:https://github.com/azlis/BlazorChartJS

原文链接:https://www.cnblogs.com/codecopier/p/17298282.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:在Blazor中使用Chart.js生成图表 - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月18日

相关文章

  • asp.net下常用的加密算法MD5、SHA-1应用代码

    若要在ASP.NET应用程序中使用MD5或SHA-1加密算法,可以使用.NET框架中的System.Security.Cryptography命名空间提供的类库。下面是ASP.NET下常用的加密算法MD5和SHA-1的应用代码攻略: 1.使用MD5加密 1.1 引入命名空间 using System.Security.Cryptography; using …

    C# 2023年5月31日
    00
  • c#基于winform制作音乐播放器

    C#基于Winform制作音乐播放器攻略 准备工作 确认已安装好 .NET Framework,本攻略基于.NET Framework 4.8进行讲解 了解Windows多媒体API Windows Media Player Control,本攻略使用此控件实现音乐播放器 步骤 1. 创建Winform应用程序 在Visual Studio中,打开File-…

    C# 2023年6月6日
    00
  • C#表达式树Expression动态创建表达式

    本文将会介绍C#表达式树(Expression)动态创建表达式的完整攻略,包括表达式树的基本概念、表达式树的创建、表达式树的编译以及完整的示例说明。 表达式树的基本概念 表达式树是一个由操作符和操作数组成的树状结构,是一种可以在运行时动态创建表达式的机制。在C#中,表达式树是由Expression命名空间中的类和枚举所组成,它们提供了创建和操作表达式树的方法…

    C# 2023年5月31日
    00
  • C# Dynamic之:ExpandoObject,DynamicObject,DynamicMetaOb的应用(上)

    那我开始讲解C# Dynamic之:ExpandoObject,DynamicObject,DynamicMetaObject的应用(上)的完整攻略。 1. 概述 首先,需要了解什么是动态类型,以及为什么需要使用动态类型。在C#中,变量的类型实际上是由编译器推断出来的,也就是静态类型。而动态类型是指在运行时才确定类型的类型。动态类型的主要作用是在不确定类型时…

    C# 2023年5月31日
    00
  • C# 关于AppDomain的一些总结

    关于C#中的AppDomain,我来进行详细的说明和总结。 一、什么是AppDomain 在C#中,每个线程都属于一个应用程序域(AppDomain)。AppDomain是.NET中用于进程隔离的一种技术,可以将应用程序分隔为不同的域,从而提高了程序的安全性和稳定性。 AppDomain可以看作是CLR(公共语言运行库)中的一个隔离容器,它可以加载和执行单独…

    C# 2023年5月14日
    00
  • C# 代码大小写规范说明

    下面是关于C#代码大小写规范的详细讲解: 标识符命名规范 在C#编程中,标识符通常指变量名、函数名、类名、命名空间等,其命名要符合一定的规范。具体规范如下: 标识符只能由字母、数字和下划线组成,第一个字符必须是字母或下划线; 标识符不能是C#中的关键字和保留字,如if、else、while、int、bool等; 标识符应该能够反映其所代表的含义,且不能太长;…

    C# 2023年5月15日
    00
  • 客户端实现蓝牙接收(C#)知识总结

    下面是关于“客户端实现蓝牙接收(C#)知识总结”的完整攻略。 知识总结 蓝牙简介 蓝牙技术是一种近程无线通信技术,用于在2.4GHz ISM频带上进行短距离数据通信。蓝牙技术具有低功耗、低成本及易于应用等特点,被广泛应用于消费电子、智能家居、医疗设备、安防等领域。 蓝牙规范 蓝牙协议规范由蓝牙核心规范、蓝牙连接规范、蓝牙应用规范和蓝牙设置规范四个部分组成。蓝…

    C# 2023年5月31日
    00
  • C# 重写Notification提示窗口的示例代码

    下面是详细讲解“C# 重写Notification提示窗口的示例代码”的完整攻略: 一、什么是Notification提示窗口 Notification提示窗口就是Windows操作系统的一个提示框,一般用于通知用户系统的一些状态变化或提示信息。它一般弹出在屏幕的右下角,显示一定的时间之后会自动消失。 二、怎样重写Notification提示窗口 要重写No…

    C# 2023年6月7日
    00
合作推广
合作推广
分享本页
返回顶部