我使用了一个插件 http://www.jqueryscript.net/demo/Simple-Bar-Chart-Plugin-with-jQuery-Bootstrap-jchart/ 但问题是,我无法使酒吧可点击。 我的动机是制作每个条形链接,如果用户点击它将在新链接上重定向用户。 但我无法做到这一点,我已经尝试但只能为每个栏提供单个网址。 请帮我 html页面上的代码:
<div id="bar_of_pies" data-sort="true" data-width="300" class="jChart chart-sm" name="">
<div class="define-chart-row " data-color="#dfdfdf" title="1">13</div>
<div class="define-chart-row" data-color="#F4BE44" title="2">22</div>
<div class="define-chart-row" data-color="#dfdfdf" title="3">20</div>
<div class="define-chart-row" data-color="#F4BE44" title="4">18</div>
<div class="define-chart-row" data-color="#dfdfdf" title="5">16</div>
<div class="define-chart-row" data-color="#F4BE44" title="6">14</div>
<div class="define-chart-row" data-color="#dfdfdf" title="5">12</div>
<div class="define-chart-row" data-color="#F4BE44" title="6">10</div>
<div class="define-chart-footer">10</div>
<div class="define-chart-footer">20</div>
<div class="define-chart-footer">30</div>
</div>
js到活动图表:
$(document).ready(function () {
$("#bar_of_pies").jChart({
sort: false,
x_label:'Hello',
});
})
});
答案 0 :(得分:1)
我把你的小提琴分开并在这里更新: http://jsfiddle.net/5ryEZ/5/
<强>更改强>: 必须编辑插件才能使其正常工作。我将整个插件复制到document.ready()并进行了更改。
<div class="define-chart-row" data-clicker="http://google.com" data-color="#009182" title="1">13</div>
您的document.ready代码位于底部。 对于网址,请添加&#34;数据点击工具&#34;归属于div。
/* replace this code in the jChart.js */
$.fn.jChart = function (options) {
var selector = $(this);
var default_color = "#6b9bd6";
var bar_height = 19;
var settings = $.extend({
width: 750,
clicker: "http://wditot.in",
name: null,
type: "bar",
headers: null,
values: null,
footers: Array(),
sort: false,
sort_colors: false,
colors: Array(),
x_label: null
}, options);
//Initialize some settings that can be set via HTML
if (settings.name == null) {
settings.name = $(this).attr("name");
}
if ($(this).data("sort") == true) {
settings.sort = true;
}
if ($(this).data("width") != null) {
settings.width = parseInt($(this).data("width"));
}
if ($(this).data("x_label") != null) {
settings.x_label = $(this).data("x_label");
}
if ($(this).data("clicker") != null) {
settings.clicker = $(this).data("clicker");
}
var chart_width = settings.width;
if ($(this).hasClass("chart-sm")) {
bar_height = 17;
} else if ($(this).hasClass("chart-lg")) {
bar_height = 25;
} else if (settings.width != null) {
chart_width = parseInt(settings.width);
}
checkForHTMLSettings();
//Clear the data in the jChart div
$(this).html("");
//Create the html containers for the chart
var chart_title = $("<div>", {
class: "chart-title",
html: settings.name
});
var legend_left = $("<div>", {
class: "legend legend-left"
});
var x_label = $("<span>", {
class: "chart-x-label",
html: settings.x_label
});
//Calculate what the chart width should be
var max_data = Math.max.apply(Math, settings.values);
var max_footer = Math.max.apply(Math, settings.footers);
var maxes = [max_data, max_footer];
var chart_max = Math.max.apply(Math, maxes);
var container_width = chart_width + 250;
var chart_container = $("<div>", {
class: "chart-container",
width: container_width + "px"
});
var chart = $("<div>", {
class: "chart",
width: chart_width + "px"
});
var legend_bottom = $("<div>", {
class: "legend-bottom"
});
//Place the containers into the target element
$(this).append(chart_container);
chart_container.append(chart_title);
chart_container.append(legend_left);
chart_container.append(chart);
//Sort the data if the setting is enabled (Insertion sort)
if (settings.sort) {
for (var i = 1; i < settings.values.length; i++) {
var j = i;
while (j > 0 && settings.values[j - 1] < settings.values[j]) {
var temp = settings.values[j];
var head_temp = settings.headers[j];
settings.values[j] = settings.values[j - 1];
settings.values[j - 1] = temp;
//Sort headings
settings.headers[j] = settings.headers[j - 1];
settings.headers[j - 1] = head_temp;
//Sort colors
if (settings.sort_colors) {
var color_temp = settings.colors[j];
settings.colors[j] = settings.colors[j - 1];
settings.colors[j - 1] = color_temp;
}
j--;
}
}
}
//Loop through headings and create/place them and their corresponding value bars
for (var i = 0; i < settings.headers.length; i++) {
var heading = $("<div>", {
class: "heading heading-left",
style: "height: " + bar_height + "px;font-size: 10pt;",
html: settings.headers[i]
});
var bar_width = (settings.values[i] / chart_max) * chart_width;
var bar = $("<div>", {
class: "bar",
"data-placement": "right",
"data-toggle": "tooltip",
title: commaSeparateNumber(settings.values[i]),
style: "height:" + bar_height + "px;background-color:" + settings.colors[i % settings.colors.length],
width: bar_width,
onclick: settings.clicker[i]
});
legend_left.append(heading);
chart.append(bar);
}
chart.append(legend_bottom);
for (var i = 0; i < settings.footers.length; i++) {
var margin = "margin-left:" + ((settings.footers[i] / chart_max) * chart_width - 9).toString() + "px;";
var chart_label_bottom = $("<div>", {
class: "chart-label chart-label-bottom",
style: margin,
html: commaSeparateNumber(settings.footers[i])
});
var margin = "margin-left:" + ((settings.footers[i] / chart_max) * chart_width - 2).toString() + "px;";
var chart_label_hr = $("<div>", {
class: "chart-label-hr",
style: margin
});
legend_bottom.append(chart_label_bottom);
chart.append(chart_label_hr);
legend_bottom.append(x_label);
}
//Enable hover details
$(".bar").tooltip();
return this;
/**
* Checks for settings defined in the HTML
* like chart-define-row and chart-define-footer classes
*/
function checkForHTMLSettings() {
//Check for HTML defined bar chart data
if (selector.find(".define-chart-row").length > 0) {
settings.headers = Array();
settings.values = Array();
settings.clicker = Array();
selector.find(".define-chart-row").each(function () {
settings.headers.push($(this).attr("title"));
var value = $(this).html();
if (value == null || value == "") {
settings.values.push(0);
} else {
settings.values.push(parseInt(value));
}
var color = $(this).data("color");
var clicker = $(this).data("clicker"); {
if (clicker == null || clicker == "") {
settings.clicker.push('#');
} else {
settings.clicker.push(clicker);
}
}
if (color != null) {
settings.sort_colors = true;
settings.colors.push(color);
} else {
settings.colors.push(default_color);
}
});
} else {
settings.colors.push(default_color);
}
//Check for HTML defined footers
if (selector.find(".define-chart-footer").length > 0) {
settings.footers = Array();
selector.find(".define-chart-footer").each(function () {
var footer = $(this).html();
if (footer != null && footer != "") {
settings.footers.push(parseInt(footer));
}
});
}
}
/**
* Converts a number into a comma separated string
*/
function commaSeparateNumber(val) {
while (/(\d+)(\d{3})/.test(val.toString())) {
val = val.toString().replace(/(\d+)(\d{3})/, '$1' + ',' + '$2');
}
return val;
}
};
/* End of code to be copied into jChart.js */