HighChat 動態綁定數據記錄

来源:http://www.cnblogs.com/elsons/archive/2017/07/27/7247946.html
-Advertisement-
Play Games

最近剛開始做圖形操作,糾結了一上午,highchat 動態綁定數據這塊一直不知道怎麼綁定,後來多次嘗試,發現 1.x軸的數據是個數組格式,我從後臺傳到前臺的時候,js中用數組進行處理數據,然後賦值到chat就不會報錯, 2.y軸的數據和x軸數據還不一樣,通過數組處理後發現還是無法顯示。後來我在後臺將 ...


最近剛開始做圖形操作,糾結了一上午,highchat 動態綁定數據這塊一直不知道怎麼綁定,後來多次嘗試,發現

1.x軸的數據是個數組格式,我從後臺傳到前臺的時候,js中用數組進行處理數據,然後賦值到chat就不會報錯,

2.y軸的數據和x軸數據還不一樣,通過數組處理後發現還是無法顯示。後來我在後臺將數據添加了中括弧[]括起來後,傳到前臺,然後前臺在用eval()處理後就能夠顯示了

3.eval具有計算的功能,剛開始x軸的時候我用了eval對時間進行操作發現時間都是相減了,格式為:2017-07-27,格式居然為1998這樣的。

下麵是我的後臺和前臺的程式邏輯:

1.後臺MVC控制器

1  public ActionResult Index()
2         {
3             return View();
4         }
5         public ActionResult GetAllReport()
6         {
7             var result = new { key = "2017-01-02,2017-01-02,2017-01-02,2017-01-02,2017-01-02,2017-01-02,2017-01-02,2017-01-02,2017-01-02,2017-01-02,2017-01-02,2017-01-02", value1 = "[9,23,24,54,67,1,23,45,23,444,55,89]", value2 = "[99,89,78,67,76,75,49,47,21,32,33,55]" };
8             return Json(result);
9         }

 

2.前臺:

@{
    Layout = null;
}

<!DOCTYPE html>

<html>
<head>
    <meta name="viewport" content="width=device-width" />
    <title>Index</title>
    <script src="~/charts/highcharts/exporting.js"></script>
    <script src="~/charts/highcharts/highcharts.js"></script>
    <script src="~/charts/highcharts/highcharts_jquery-1.8.3.min.js"></script>
</head>
<body>
    <div id="container">

    </div>
</body>
</html>
<script type="text/javascript">
    $(function () {
        $.ajax({
            url: '/Home/GetAllReport',
            dataType: "json",
            type: "POST",
            data: null,
            success: function (data) {
                alert(data.key);
                Chart(data.key, data.value1, data.value2);
            }, error: function (jqXHR, textStatus, errorThrown) {
                alert("出錯");
            }
        });
    });
    function Chart(key, value1, value2) {
        var mycars = new Array();
        var myvalue1 = new Array();
        var myvalue2 = new Array();
        var _tkey = key.split(',');
        for (var i = 0; i < _tkey.length; i++) {
            mycars[i] = _tkey[i];
        }
        var _tvalue1 = value1.split(',');
        for (var i = 0; i < _tvalue1.length; i++) {
            myvalue1[i] = _tvalue1[i];
        }
        var _tvalue2 = value2.split(',');
        for (var i = 0; i < _tvalue2.length; i++) {
            myvalue2[i] = _tvalue2[i];
        }
        var chart = new Highcharts.Chart('container', {
            title: {
                text: '不同城市的月平均氣溫',
                x: -20
            },
            subtitle: {
                text: '數據來源: WorldClimate.com',
                x: -20
            },
            xAxis: {
                categories: mycars
            },
            yAxis: {
                title: {
                    text: '溫度 (°C)'
                },
                plotLines: [{
                    value: 0,
                    width: 1,
                    color: '#808080'
                }]
            },
            tooltip: {
                valueSuffix: '°C'
            },
            legend: {
                layout: 'vertical',
                align: 'right',
                verticalAlign: 'middle',
                borderWidth: 0
            },
            series: [{
                name: '東京',
                data: eval(value1)
            }, {
                name: '紐約',
                data: eval(value2)
            }]
        });

    }


</script>



 另外呢還有一些 小處理

1.   2條折線重覆的時候,滑鼠放上去需要都顯示數據

tooltip: {
shared: true
}

2.  去除highchat.com 網址

credits: {
 enabled: false
}

 

3. 刷新數據的時候 需要將上次的折線圖清除

function clearTable() {
   var series = chart.series;
   if (series.length > 0) {
         series[0].remove(false);
     }
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 網上那麼多的裝機教程,還有必要專門寫一篇裝機攻略麽?有的,非常必要的!因為真的有很多未知的坑要趟!首先,win10好不好?除了正版,其他沒什麼好的。。。如果沒有SSD,經常要卡死於磁碟讀寫。當然,你可以想辦法禁用小娜,關閉Defender,禁用自動更新,禁用超級預讀。。。那麼這還是win10麽?好了 ...
  • vmstat——Virtual Memory Statistics(虛擬記憶體統計) 1. 作用 檢測系統資源變化,可以檢測CPU/記憶體/磁碟輸入輸出狀態等。 2. 用法 vmstat 【參數】【間隔秒數】【檢測次數】 參數: -a:使用inactive/active(活躍與否)替代buffer/ca ...
  • 操作系統:CentOS 7.3.1611 IP地址:192.168.21.130 網關:192.168.21.2 DNS:8.8.8.8 8.8.4.4 備註: CentOS 7.x系列只有64位系統,沒有32位。生產伺服器建議安裝CentOS-7-x86_64-Minimal-1611.iso版本 ...
  • 轉載自http://blog.csdn.net/ldl22847/article/details/76056501.下載jdk的rpm安裝包,這裡以jdk-7u4-linux-i586.rpm為例進行說明下載地址:http://www.oracle.com/technetwork/java/java ...
  • oghost@loghost-virtual-machine:~$ ~/home/loghost/qq$ sudo dpkg -i linuxqq_v1.0.2_beta1_i386.deb bash: /home/loghost/home/loghost/qq$: 沒有那個文件或目錄 //問題1出 ...
  • 經過google,出現這個問題的原因是,這是ssh的問題, GkFool大神說(第一次使用SSH連接時,會生成一個認證,儲存在客戶端的known_hosts中)我的解決辦法是: 1 ssh-keygen -R 伺服器端的ip地址View Code提示: 1 /用戶home目錄/.ssh/known_... ...
  • 回到占占推薦博客索引 本篇文章是對自己學習Linux及在它的環境下部署工具的一個總結,以方便自己查閱,也給他人一個幫助,本文章同時會不斷的更新,歡迎大家訂閱! 本目錄包括的內容會包括linux基礎命令,redis,mongodb,node.js,.net core,kafka,rabbitmq,zo ...
  • 背景:當option特別多時,一般的下拉框選擇起來就有點力不從心了,所以使用multiselect是個很好的選擇,可以通過輸入文字來選擇選項很方便,但是有一個需要下拉框聯動,網上找了半天才找到解決方法,在此分享一下 1、先引入 <script src="~/Assets/js/bootstrap-m ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...