(六)——Ajax打造可視化

2018-02-24 15:43 更新

原文出處:https://www.phodal.com/blog/bare-minimum-iot-system-ajax/

最后效果見:http://b.phodal.com/

代碼位置:http://b.phodal.com/js/app.js

我覺得似乎我把這個(gè)代碼寫長了,但是我不是故意,只是必需的。先觀察Ajax部分:

Ajax

剝離后的Ajax部分代碼如下所示,主要用的是jQuery框架的getJSON來實(shí)現(xiàn)的

var dataLength = [];
function drawTemp() {
    var zero = [];
    $.getJSON('/athome/', function(json) {
        var items = [];
        dataLength.push(json.length);
        $.each(json, function(key, val) {
            zero.push(val.temperature);
        });
};

實(shí)際上,我們做的只是從/athome/下面獲取數(shù)據(jù),再將數(shù)據(jù)堆到數(shù)組里面,再把這部分放到圖形中。等等,什么是Ajax?

  • AJAX = Asynchronous JavaScript and XML(異步的 JavaScript 和 XML)。
  • AJAX 不是新的編程語言,而是一種使用現(xiàn)有標(biāo)準(zhǔn)的新方法。
  • AJAX 是與服務(wù)器交換數(shù)據(jù)并更新部分網(wǎng)頁的藝術(shù),在不重新加載整個(gè)頁面的情況下。

JSON我們前面也已經(jīng)了解過了,看看getJSON吧。

jQuery. getJSON

方法定義:jQuery.getJSON( url, data, callback )

通過get請求得到j(luò)son數(shù)據(jù)

  • ·url用于提供json數(shù)據(jù)的地址頁
  • ·data(Optional)用于傳送到服務(wù)器的鍵值對
  • ·callback(Optional)回調(diào)函數(shù),json數(shù)據(jù)請求成功后的處理函數(shù)

我想你似乎應(yīng)該懂得了一點(diǎn),就是在不刷新網(wǎng)頁的同時(shí),用javascript獲取數(shù)據(jù)放到圖表上,就這么簡單。

HighChart

再省去一部分,摘自我原來的博客

HIGHCHARTS Highcharts是一個(gè)制作圖表的純Javascript類庫,主要特性如下:

  • 兼容性:兼容當(dāng)今所有的瀏覽器,包括iPhone、IE和火狐等等;
  • 對個(gè)人用戶完全免費(fèi);
  • 純JS,無BS;
  • 支持大部分的圖表類型:直線圖,曲線圖、區(qū)域圖、區(qū)域曲線圖、柱狀圖、餅裝圖、散布圖;
  • 跨語言:不管是PHP、Asp.net還是Java都可以使用,它只需要三個(gè)文件:一個(gè)是Highcharts的核心文件highcharts.js,還有a canvas emulator for IE和Jquery類庫或者M(jìn)ooTools類庫;
  • 提示功能:鼠標(biāo)移動(dòng)到圖表的某一點(diǎn)上有提示信息;
  • 放大功能:選中圖表部分放大,近距離觀察圖表;
  • 易用性:無需要特殊的開發(fā)技能,只需要設(shè)置一下選項(xiàng)就可以制作適合自己的圖表;
  • 時(shí)間軸:可以精確到毫秒;

不過因?yàn)轫?xiàng)目原因,所以可能不會再使用這個(gè),只對個(gè)人免費(fèi),現(xiàn)在的考慮是基于D3做一個(gè)新的。

官方示例代碼

$(function () {
        $('#container').highcharts({
            title: {
                text: 'Monthly Average Temperature',
                x: -20 //center
            },
            subtitle: {
                text: 'Source: WorldClimate.com',
                x: -20
            },
            xAxis: {
                categories: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun',
                    'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']
            },
            yAxis: {
                title: {
                    text: 'Temperature (°C)'
                },
                plotLines: [{
                    value: 0,
                    width: 1,
                    color: '#808080'
                }]
            },
            tooltip: {
                valueSuffix: '°C'
            },
            legend: {
                layout: 'vertical',
                align: 'right',
                verticalAlign: 'middle',
                borderWidth: 0
            },
            series: [{
                name: 'Tokyo',
                data: [7.0, 6.9, 9.5, 14.5, 18.2, 21.5, 25.2, 26.5, 23.3, 18.3, 13.9, 9.6]
            }, {
                name: 'New York',
                data: [-0.2, 0.8, 5.7, 11.3, 17.0, 22.0, 24.8, 24.1, 20.1, 14.1, 8.6, 2.5]
            }, {
                name: 'Berlin',
                data: [-0.9, 0.6, 3.5, 8.4, 13.5, 17.0, 18.6, 17.9, 14.3, 9.0, 3.9, 1.0]
            }, {
                name: 'London',
                data: [3.9, 4.2, 5.7, 8.5, 11.9, 15.2, 17.0, 16.6, 14.2, 10.3, 6.6, 4.8]
            }]
        });
    });

我承認(rèn)我也不想看這些代碼,但是這樣子似乎使原文的長度變長了。大部分人也省得去查找了。

所以我們要做的只是用數(shù)組代替data

jQuery Mobile

在首頁上看到的那個(gè)效果是jQuery Mobile。。

以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號