国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

又快又好!巧用ChartJS打造你的實(shí)用折線圖

Airmusic / 2747人閱讀

摘要:又快又好巧用打造你的實(shí)用折線圖最終效果本示例利用官方示例改造而成,生成帶圖示的折線圖,標(biāo)出各折線的名稱,可以篩選想要顯示的折線。了解了上折線圖的數(shù)據(jù)結(jié)構(gòu),大家也就明白了顯示一條折線,即是添加隱藏一條折線,即是將其去除。

又快又好!巧用ChartJS打造你的實(shí)用折線圖 最終效果

本示例利用官方示例改造而成,生成帶圖示的折線圖,標(biāo)出各折線的名稱,可以篩選想要顯示的折線。

要實(shí)現(xiàn)最終效果,我們要分三步走:

生成折線圖;

生成自定義提示;

生成圖示(折線顯示控制板)

生成折線圖

首先,我們要設(shè)置折線圖的位置。

我們將圖表放置于id為line-chartcanvas中,而圖例則在id為line-legenddiv中。

接著,我們要生成折線圖。

設(shè)置x軸數(shù)據(jù)

var x_labels = ["January","February","March","April","May","June","July"];

設(shè)置y軸數(shù)據(jù)

var default_datasets = [
        {
            label: "My First dataset",
            fillColor : "rgba(220,220,220,0.2)",
            strokeColor : "rgba(220,220,220,1)",
            pointColor : "rgba(220,220,220,1)",
            pointStrokeColor : "#fff",
            pointHighlightFill : "#fff",
            pointHighlightStroke : "rgba(220,220,220,1)",
            data : [randomScalingFactor(),randomScalingFactor(),randomScalingFactor(),randomScalingFactor(),randomScalingFactor(),randomScalingFactor(),randomScalingFactor()]
        },
        {
            label: "My Second dataset",
            fillColor : "rgba(151,187,205,0.2)",
            strokeColor : "rgba(151,187,205,1)",
            pointColor : "rgba(151,187,205,1)",
            pointStrokeColor : "#fff",
            pointHighlightFill : "#fff",
            pointHighlightStroke : "rgba(151,187,205,1)",
            data : [randomScalingFactor(),randomScalingFactor(),randomScalingFactor(),randomScalingFactor(),randomScalingFactor(),randomScalingFactor(),randomScalingFactor()]
        }
    ];

將x軸和y軸的數(shù)據(jù)打包成數(shù)據(jù)包

 var lineChartData = {
    labels : x_labels,
    datasets : default_datasets
 };

設(shè)置顯示的效果(這里是直接從官網(wǎng)示例里copy過(guò)來(lái)的:-)

 var lineChartOptions = {
    //Boolean - If we should show the scale at all
    showScale: true,
    ...
    //Boolean - whether to make the chart responsive to window resizing
    responsive: true,
};

生成折線圖

var lineChartCanvas = chart.get(0).getContext("2d");
var lineChart = new Chart(lineChartCanvas);
var line_chart_handle = lineChart.Line(lineChartData, lineChartOptions);

本階段效果

以上示例可參考官方教程。

自定義提示

剛才我們成功地繪制了一張圖表,但是基本圖表中的提示只顯示了折線的顏色和值,我們還希望能把折線的名稱也加上,那到底該怎么做呢?

很簡(jiǎn)單,這個(gè)功能屬于圖表的要顯示的效果,還記得剛才我們?cè)O(shè)置的lineChartOptions嗎,它就是設(shè)定顯示效果的參數(shù)。只要在其中設(shè)定一項(xiàng)新的參數(shù)multiTooltipTemplate即可,該參數(shù)用于自定義數(shù)據(jù)提示tooltip。

 multiTooltipTemplate: "<%if (datasetLabel){%><%=datasetLabel%>: <%}%><%= value %>"

上面的代碼是什么意思呢?大致可以看出,是給multiTooltipTemplate賦了一個(gè)值,而這個(gè)值就是我們想要顯示的數(shù)據(jù)的樣式。你大概猜到了,datasetLabel其實(shí)就是折線標(biāo)題的變量。

該功能雖然簡(jiǎn)單,但基本上出圖表都會(huì)用到,所以在此專門用一節(jié)來(lái)說(shuō)明。

生成圖示

終于到達(dá)我們的重頭戲,現(xiàn)在要來(lái)實(shí)現(xiàn)圖示功能了。

我們?cè)賹⑦@個(gè)大目標(biāo)劃分為兩個(gè)具體的小目標(biāo):
首先,我們先將圖示展示出來(lái);
接著,點(diǎn)擊圖示之后,動(dòng)態(tài)顯示或隱藏指定的折線。

添加展示圖示

我們之前已經(jīng)設(shè)置好了圖例所在,現(xiàn)在填入兩個(gè)checkbox。

  • My First dataset
  • My Second dataset
添加曲線選項(xiàng)事件響應(yīng)

為兩條折線添加了checkbox,但點(diǎn)擊了它折線也沒(méi)有變化。沒(méi)關(guān)系,我們現(xiàn)在來(lái)為折線添加上事件響應(yīng),使得圖表能自由顯示或是隱藏折線。

// 給圖例中的選框增加事件響應(yīng)
// 被選中的則顯示其對(duì)應(yīng)折線,未選中的不顯示
$("[name = "line-legend"]:checkbox").each(function(key, value) {
    // 設(shè)置所有的checkbox為選中
    $(this).attr("checked", true);
    // 設(shè)置checkbox被取消選擇之后,將該曲線消除
    $(this).click(function() {
        // 顯示相應(yīng)的折線
    } else {
        // 刪除被選中折線上的點(diǎn)
    }
});

現(xiàn)在我們?yōu)閏heckbox添加上了事件響應(yīng),具體的響應(yīng)事件將在下一節(jié)說(shuō)明。

ChartJS數(shù)據(jù)結(jié)構(gòu)

要想知道如何讓折線從圖表中顯示出來(lái),或是消息,首先要來(lái)了解曲線的數(shù)據(jù)結(jié)構(gòu)。
ChartJS里的點(diǎn)是由數(shù)據(jù)包構(gòu)成的,而一個(gè)數(shù)據(jù)包分成兩部分:一塊包含點(diǎn)的信息,一塊用于顯示該點(diǎn)。

了解了ChartJS上折線圖的數(shù)據(jù)結(jié)構(gòu),大家也就明白了:顯示一條折線,即是添加points;隱藏一條折線,即是將其points去除。

所以,當(dāng)某一條曲線被選中時(shí),我們就根據(jù)該曲線的信息生成新的點(diǎn);

if ($(this).is(":checked")) {
    // 插入被選中折線上的點(diǎn)
    $.each(y_datasets[index].data, function(key, value) {
      line_chart_handle.datasets[index].points.push(new line_chart_handle.PointClass({
        value : value,
        label : lineChartData.labels[key],
        datasetLabel : lineChartData.datasets[index].label,
        x: line_chart_handle.scale.calculateX(line_chart_handle.scale.valuesCount + 1),
        y: line_chart_handle.scale.endPoint,
        strokeColor : line_chart_handle.datasets[index].pointStrokeColor,
        fillColor : line_chart_handle.datasets[index].pointColor
      }));
    });
}

當(dāng)一條曲線被取消選中時(shí),我們只需要將這條曲線上的點(diǎn)到清空即可。

else {
    // 刪除被選中折線上的點(diǎn)
    for (var i = line_chart_handle.datasets[index].points.length - 1; i >= 0; i--) {
      line_chart_handle.datasets[index].points.shift();
    }
}

大功告成!

示例下載

下載地址:百度云(http://pan.baidu.com/s/1c00oYJm)

注:如果鏈接失效了,私信我吧~(希望你不要以為我有別的企圖)

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/115012.html

相關(guān)文章

  • 又快又好巧用ChartJS打造你的實(shí)用線圖

    摘要:又快又好巧用打造你的實(shí)用折線圖最終效果本示例利用官方示例改造而成,生成帶圖示的折線圖,標(biāo)出各折線的名稱,可以篩選想要顯示的折線。了解了上折線圖的數(shù)據(jù)結(jié)構(gòu),大家也就明白了顯示一條折線,即是添加隱藏一條折線,即是將其去除。 又快又好!巧用ChartJS打造你的實(shí)用折線圖 最終效果 showImg(https://segmentfault.com/img/bVq52r); 本示例利用官方示例...

    channg 評(píng)論0 收藏0
  • 又快又好巧用ChartJS打造你的實(shí)用線圖

    摘要:又快又好巧用打造你的實(shí)用折線圖最終效果本示例利用官方示例改造而成,生成帶圖示的折線圖,標(biāo)出各折線的名稱,可以篩選想要顯示的折線。了解了上折線圖的數(shù)據(jù)結(jié)構(gòu),大家也就明白了顯示一條折線,即是添加隱藏一條折線,即是將其去除。 又快又好!巧用ChartJS打造你的實(shí)用折線圖 最終效果 showImg(https://segmentfault.com/img/bVq52r); 本示例利用官方示例...

    junfeng777 評(píng)論0 收藏0
  • 五個(gè)步驟,幫助您又快又好地管理混合云

    摘要:云計(jì)算這個(gè)詞出現(xiàn)至今,一直是科技技術(shù)領(lǐng)域的熱門。混合云雖然很便捷,但是由于它是不同的云組合起來(lái)的云計(jì)算環(huán)境,企業(yè)在管理時(shí)會(huì)碰到不好管理的問(wèn)題。以下五個(gè)步驟,可以幫助您又快又好地管理混合云。云計(jì)算這個(gè)詞出現(xiàn)至今,一直是科技技術(shù)領(lǐng)域的熱門。云計(jì)算又分為公有云、私有云和混合云,近兩年,混合云因?yàn)榫哂徐`活性強(qiáng)的特點(diǎn),成為眾多企業(yè)的首選,企業(yè)借助混合云,可以根據(jù)業(yè)務(wù)需求進(jìn)行云上遷移。 混合云雖然...

    Terry_Tai 評(píng)論0 收藏0
  • sass筆記-1|Sass是如何幫你又快又好地搞定CSS的

    摘要:輸出的是這樣的可以看到,當(dāng)用繼承的樣式時(shí),和也完全套用了的樣式,而且你會(huì)發(fā)現(xiàn),規(guī)則并沒(méi)有被重復(fù)輸出,而且這樣的方式更符合我們對(duì)于這幾個(gè)選擇器的認(rèn)知如果你之前用過(guò)面向?qū)ο缶幊痰脑挕? Sass學(xué)習(xí)筆記持續(xù)整理中,開篇不講怎么安裝,sass是什么,這些搜索引擎會(huì)告訴你,我們從sass的作用開始講起,知道sass用來(lái)干什么,有什么作用,我們才能相信用sass的好處,并且時(shí)時(shí)刻刻想著sass的設(shè)...

    xiaolinbang 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<