javascript - Click events on Pie Charts in Chart.js -
I got a question question chart.
I have prepared many recommendations using the documentation provided. I was thinking that on click of any one of the pieces, I can call an AJAX call based on the value of that slice. ?
For example, if this is my Is it possible to click on the label of Update: Like @ Soham Shetty comment, .getElementsAtEvent (e) is looking for an element under the event point, then returns all the elements on the same data index. It is internally used for highlighting the 'label' mode. Calling Basic Answer (chart. Valid for JS version 1.x): < / P> You can get this Calling From: So you can: Here is a complete work example: data
var data = [[value: 300, color: "# F7464A", highlight : "Green"}, {value: 100, color: "#FDB 45C", "# 5F5A5E", label: "red"}, {value: 50, color: "# 46BFBD", highlight: "# 5AD3D1 "Highlight:" # FFC 870 ", label:" yellow "},
Red and Call the URL below:
example.com?label=red&value=300 ? If so, how do I know about this?
getSegmentsAtEvent (event ) only works for 1.x and should be used for 2.x.
getElementsAtEvent (event) on your chart example, which passes through the argument of an event, or jQuery event, the point element in that state of that event.
canvas.com = function (evt) {var active points = myLineChart.getElementsAtEvent (evt); // = & gt; There are several points on the active point canvas which are in the same position as the click event. }; Example:
getSegmentsAtEvent (event)
getSegmentsAtEvent (event) on your chart example An argument is returned to an event, or section of the jQuery phenomenon, which is in the same place of that event.
$ ("# mychart"). Click (function (evt) {var activePoints = myNewChart.getSegmentsAtEvent (evt); / * something * /});
& lt; Html & gt; & Lt; Top & gt; & Lt; Script type = "text / javascript" src = "http://code.jquery.com/jquery-2.0.2.js" & gt; & Lt; / Script & gt; & Lt; Script type = "text / javascript" src = "chart.js" & gt; & Lt; / Script & gt; & Lt; Script type = "text / javascript" & gt; Var data = [{value: 300, color: "# F 7464A", highlight: "#FF5A5A", label: "red"}, {value: 50, color: "# 46BFBD", highlight Do: "# 5AD3D1", label: "green"}, {value: 100, color: "# fdb 45c", highlight: "#ffc 870", label: "yellow"}]; $ (Document) .ready (function () {var ctx = document.getElementById ("mychart"). GetContext ("2d"); var myNewChart = new chart (ctx) .pie (data); $ ("# mychart" ) .click (function (evt) {var activePoints = myNewChart.getSegmentsAtEvent (evt); var url = "http://example.com/?label=" + activePoints [0] .label + "& Price =" + Active points [0] value; alert (url);});}); & Lt; / Script & gt; & Lt; / Head & gt; & Lt; Body & gt; & Lt; Canvas ID = "My Chart" width = "400" height = "400" & gt; & Lt; / Canvas & gt; & Lt; / Body & gt; & Lt; / Html & gt;
Comments
Post a Comment