在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日

相关文章

  • C# Math中常用数学运算的示例详解

    下面是“C# Math中常用数学运算的示例详解”的完整攻略: 1. C# Math库概述 C# 中的 Math 类提供了一些基本的数学运算方法和常量。可以通过该类来进行一些数值运算,比如三角函数、指数函数、对数函数、绝对值、平方根、取整等,其它还有一些常用方法。下面是 Math 类中一些常用的方法和常量: 常量:π 和 e,可以通过 Math.PI 和 Ma…

    C# 2023年6月7日
    00
  • c#一个定时重启的小程序实现代码第1/2页

    “c#一个定时重启的小程序实现代码”是一个面向Windows操作系统开发的应用程序,用于定时重启计算机。具体的实现思路如下: 获取重启时间 首先需要获取用户设定的重启时间,可通过以下代码实现: DateTime restartTime = new DateTime(year, month, day, hour, minute, second); 其中year…

    C# 2023年6月1日
    00
  • ASP.NET Core依赖注入DI容器的方法实现

    ASP.NET Core依赖注入DI容器的方法实现攻略 ASP.NET Core依赖注入(DI)是一种设计模式,它允许我们将对象的创建和管理从应用程序代码中分离出来。在ASP.NET Core中,我们可以使用内置的DI容器来实现依赖注入。本攻略将介绍如何使用ASP.NET Core的DI容器。 步骤 以下是使用ASP.NET Core的DI容器的步骤: 在S…

    C# 2023年5月17日
    00
  • C# List的用法小结

    针对题目“C# List的用法小结”的完整攻略,以下是我整理的详细讲解: 1. C# List 简介 C# List是.NET Framework中的一个通用集合类,可以存储一组对象,并且可根据索引值访问列表中的元素,支持添加、删除、排序等操作。List类是泛型类,其中“T”代表一个类型参数,表示列表中存储的元素的数据类型。由于是泛型类,因此可以根据不同的需…

    C# 2023年5月31日
    00
  • C#使用LINQ查询表达式的基本子句总结

    下面是对“C#使用LINQ查询表达式的基本子句总结”的完整攻略: C#使用LINQ查询表达式的基本子句总结 什么是LINQ LINQ是Language-Integrated Query,即语言集成查询的缩写,是.NET框架中提供的一种用于统一访问各种类型数据的高级查询技术。 LINQ查询表达式的基本子句 在LINQ中,查询操作被分解成一些基本的表达式。以下是…

    C# 2023年6月1日
    00
  • C# Clear():从 ICollection中移除所有元素

    C#Clear()方法详解 在C#中,Clear()是一个常用的方法,其函数签名为:public void Clear()。这个方法用于清除List集合中的所有元素,使其变为空集合。 具体而言,Clear()方法做两个主要方面的操作:删除所有元素,以及释放元素占用的存储空间。 下面,我们就详细介绍Clear()方法的使用。 基础用法 在 List 的对象上,…

    C# 2023年4月19日
    00
  • .NET Framework 4.5新特性介绍

    下面是关于“.NET Framework 4.5新特性介绍”的完整攻略,包含两个示例。 1. 什么是.NET Framework 4.5 .NET Framework 4.5是微软公司发布的一个开发框架,用于创建Windows应用程序、Web应用程序和服务。它包含了许多新的特性和改进,可以提高开发效率和应用程序性能。 2. .NET Framework 4.…

    C# 2023年5月15日
    00
  • C#中DateTime函数的详细用法

    下面是关于C#中DateTime函数的详细用法: 1. DateTime函数的概述 DateTime是C#中用于操作日期和时间的一个结构体类型,在.NET Framework中属于System命名空间,通常用于表示和操作当前日期和时间或指定日期和时间对象。它可以表示的日期和时间范围为公元1年1月1日00:00:00到公元9999年12月31日23:59:59…

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