直接上步骤:

 

生成一个options,选项包含了一些基本的配置,如标题,坐标刻度,serial等;

配置X轴显示的Category数据,为一个数组;

配置Y轴显示的数据,也为一个数据;

用生成option构建一个Hightcharts对象,即可以自动画出一个折线图了;

 

 

1.配置BundleConfig

 

  1. bundles.Add(new ScriptBundle("~/bundles/jquery").Include("~/Scripts/jquery-{version}.js", "~/Scripts/jquery.metadata.js"));
  2. bundles.Add(new ScriptBundle("~/bundles/highcharts").Include("~/Scripts/hightcharts/highcharts-custom.js"));

 

2.视图模板

 

  1. @Scripts.Render("~/bundles/highcharts")
  2.  
  3. <script type="text/javascript">
  4.     $(function () {
  5.         var option = option = getOption("container", '@ViewBag.titletext');
  6.         //生成两个serial
  7.         option.xAxis.categories = @Html.Raw(@ViewBag.categories)
  8.         option.series[0].data = @ViewBag.amount
  9.         option.series[1].data = @ViewBag.quantity
  10.         option.subtitle.text = '@ViewBag.subtitle'
  11.  
  12.         chart = new Highcharts.Chart(option);
  13.  
  14.         $("text:contains('销售数量')").trigger('click');
  15.     });
  16.  
  17.     function getOption(container, title) {
  18.         var options = {
  19.             chart: {
  20.                 renderTo: container,
  21.                 type: 'line'
  22.             },
  23.             title: {
  24.                 text: title
  25.             },
  26.             subtitle: {
  27.                 text: 'imc'
  28.             },
  29.             xAxis: {
  30.                 title: {
  31.                     text: '日期'
  32.                 }
  33.             },
  34.             yAxis: {
  35.                 title: {
  36.                     text: '数量或金额'
  37.                 },
  38.                 min: 0, // 定义最小值
  39.             },
  40.             plotOptions: {
  41.                 line: {
  42.                     dataLabels: {
  43.                         enabled: true
  44.                     }
  45.                 }
  46.             },
  47.             tooltip: {
  48.                 shared: true, //共享数据提示框
  49.             },
  50.             credits: {
  51.                 enabled: false
  52.             },
  53.             series: [{
  54.                 name: "销售金额"
  55.             }, {
  56.                 name: "销售数量"
  57.             }]
  58.         }
  59.  
  60.         return options;
  61.     }
  62.  
  63. </script>

 

3.后台代码

  1. categories = "['" + string.Join("','", list.Select(zw => zw.DTStr)) + "']";
  2. quantity = "[" + string.Join(",", list.Select(zw => zw.Quantity)) + "]";
  3. amount = "[" + string.Join(",", list.Select(zw => zw.Amount)) + "]";
  4.  
  5. ViewBag.titletext = title;
  6. ViewBag.categories = categories;
  7. ViewBag.quantity = quantity;
  8. ViewBag.amount = amount;
  9. ViewBag.subtitle = subtitle;

 

4.效果图

 

5.参考资料

 

中文教程与资料:http://www.hcharts.cn/docs/index.php?doc=basic-axis

示例:http://www.cnblogs.com/TivonStone/p/3539766.html

更多的charts插件:http://www.cnblogs.com/chu888chu888/archive/2012/12/22/2828962.html

ASP.NET MVC中使用highcharts 生成简单的折线图的更多相关文章

  1. ASP.NET MVC 中的视图生成

    关于 ASP.NET MVC 中的视图生成 在 ASP.NET MVC 中,我们将前端的呈现划分为三个独立的部分来实现,Controller 用来控制用户的操作,View 用来控制呈现的内容,Mode ...

  2. 关于 ASP.NET MVC 中的视图生成

    在 ASP.NET MVC 中,我们将前端的呈现划分为三个独立的部分来实现,Controller 用来控制用户的操作,View 用来控制呈现的内容,Model 用来表示处理的数据. 从控制器到视图 通 ...

  3. 关于ASP.NET MVC中的视图生成

    在 ASP.NET MVC 中,我们将前端的呈现划分为三个独立的部分来实现,Controller 用来控制用户的操作,View 用来控制呈现的内容,Model 用来表示处理的数据.   从控制器到视图 ...

  4. ASP.NET MVC中权限控制的简单实现

    1.重写AuthorizeAttribute类,用自己的权限控制逻辑重写AuthorizeCore方法 public class MyAuthorizeAttribute : AuthorizeAtt ...

  5. ASP.NET MVC中使用Ninject

    ASP.NET MVC中使用Ninject 在[ASP.NET MVC 小牛之路]系列上一篇文章(依赖注入(DI)和Ninject)的末尾提到了在ASP.NET MVC中使用Ninject要做的两件事 ...

  6. asp.net mvc 中 一种简单的 URL 重写

    asp.net mvc 中 一种简单的 URL 重写 Intro 在项目中想增加一个公告的功能,但是又不想直接用默认带的那种路由,感觉好low逼,想弄成那种伪静态化的路由 (别问我为什么不直接静态化, ...

  7. C# 动态生成word文档 [C#学习笔记3]关于Main(string[ ] args)中args命令行参数 实现DataTables搜索框查询结果高亮显示 二维码神器QRCoder Asp.net MVC 中 CodeFirst 开发模式实例

    C# 动态生成word文档 本文以一个简单的小例子,简述利用C#语言开发word表格相关的知识,仅供学习分享使用,如有不足之处,还请指正. 在工程中引用word的动态库 在项目中,点击项目名称右键-- ...

  8. ADO.NET .net core2.0添加json文件并转化成类注入控制器使用 简单了解 iTextSharp实现HTML to PDF ASP.NET MVC 中 Autofac依赖注入DI 控制反转IOC 了解一下 C# AutoMapper 了解一下

    ADO.NET   一.ADO.NET概要 ADO.NET是.NET框架中的重要组件,主要用于完成C#应用程序访问数据库 二.ADO.NET的组成 ①System.Data  → DataTable, ...

  9. 在Asp.Net MVC 中配置 Serilog

    Serilog 是一种非常简便记录log 的处理方式,使用Serilog可以生成本地的text文件, 也可以通过 Seq 来在Web界面中查看具体的log内容. 接下来就简单的介绍一下在Asp.Net ...

随机推荐

  1. [Android Pro] Android打包一个Apk后,如何查看它的VersionCode、VersionName 等等。

    Android打包成Apk后,其实是一个压缩文件,我们用winrar打开也能看到里面的文件结构.还能看到AndroidManifest.但是里面的内容有点问题. 不知道是因为加密还是Android就是 ...

  2. 模拟赛1102d2

    /* φ(n)=φ(p^k)=p^k-p^(k-1)=(p-1)*p^(k-1) φ(m*n)=φ(m)*φ(n) 直接套公式做,因为分解质因数时,只分解一个数,所以可以不打素数表,只将n分解到√n就 ...

  3. UVa1592_数据库

    #include<iostream> #include<cstdio> #include<vector> #include<utility> #incl ...

  4. Lambda表达式与标准运算符查询

    class Program { static void Main(string[] args) { //Lambda表达式输出List集合每一项 List<string> list = n ...

  5. ios 弹出键盘 视图向上平移

    [[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(keyboardwillAppear:) name:U ...

  6. NYOJ_37.回文字符串 (附滚动数组)

    时间限制:3000 ms  |  内存限制:65535 KB 难度:4 描述 所谓回文字符串,就是一个字符串,从左到右读和从右到左读是完全一样的,比如"aba".当然,我们给你的问 ...

  7. Good Bye 2015B(模拟或者二进制枚举)

    B. New Year and Old Property time limit per test 2 seconds memory limit per test 256 megabytes input ...

  8. 警告 - no rule to process file 'WRP_CollectionView/README.md' of type net.daringfireball.markdown for architecture i386

    warning: no rule to process file '/Users/mac/Downloads/Demo/Self/WRP_CollectionView/WRP_CollectionVi ...

  9. Swift - 获取、改变按钮的标题文本(UIButton点击切换title)

    在开发中,我们常常需要动态地改变按钮标签文字,使用 setTitle() 函数就可以了.有时我们需要在几个标题间切换,比如下面样例所示,按钮点击后按钮文字会在"播放""暂 ...

  10. mysql 5.6.33 重置密码后报错

    [root@ Desktop]# mysql -uroot -p Enter password: Welcome to the MySQL monitor. Commands end with ; o ...