<html>
<head>
<link href="http://cdn.kendostatic.com/2012.2.710/styles/kendo.common.min.css" rel="stylesheet" type="text/css" />
<link href="http://cdn.kendostatic.com/2012.2.710/styles/kendo.default.min.css" rel="stylesheet" type="text/css" />
<link href="http://cdn.kendostatic.com/2012.2.710/styles/kendo.dataviz.min.css" rel="stylesheet" type="text/css" />
<link href="http://cdn.kendostatic.com/2012.2.710/styles/kendo.mobile.all.min.css" rel="stylesheet" type="text/css" />
<script src="http://code.jquery.com/jquery-1.8.0.min.js"></script>
<script src="http://cdn.kendostatic.com/2012.2.710/js/kendo.all.min.js"></script>
<meta charset=utf-8 />
<title>DataViz A11y With ARIA Role and Title</title>
</head>
<body>
<figure id="chartContainer">
<div id="chart" role="img" title="Sources of Electricity Produced in Spain, 2008"></div>
<figcaption>In 2008, Spain produced electricity for its residents in four ways. Chief among these was Nuclear power, which accounted for approximately 49% of production. Next were Wind and Hydro-electric power, which produced 27% and 22% of the nation's electricity, respectively. In a distant fourth was solor power, which accounted for only 2% of all electricity produced by the country.</figcaption>
</figure>
<script id="tableScript" type="text/x-kendo-tmpl">
<table id="chartTable" class="hidden">
<caption>Sources of Electricity Produced in Spain, 2008</caption>
<tr>
<th scope="col">Category</th>
<th scope="col">Percentage</th>
</tr>
# for(var i = 0, len = data.length; i < len; i++) { #
<tr>
<th scope="row">#= data[i].category #</th>
<td>#= data[i].value #%</td>
</tr>
# } #
</table>
</script>
</body>
</html>
/* Off-screen content. Technique borrowed from http://webaim.org/techniques/css/invisiblecontent/ */
.hidden {
position:absolute;
left:-10000px;
top:auto;
width:1px;
height:1px;
overflow:hidden;
}
figcaption {
border: 5px solid #ddd;
margin: 10px;
padding: 15px;
border-radius: 10px;
}
th {
color: white;
background: #444
}
table {
width: 100%;
height: 30%;
border: 5px solid #444;
text-align: center;
font-size: 1.3em;
}
table tr, table td {
border: 2px solid #444;
}
table caption {
font-size: 1.1em;
font-weight: bold
}
var chartData = new kendo.data.DataSource({
data: [{
category: "Hydro",
value: 22
}, {
category: "Solar",
value: 2
}, {
category: "Nuclear",
value: 49
}, {
category: "Wind",
value: 27
}]
});
function createChart() {
$("#chart").kendoChart({
dataSource: chartData,
title: {
text: "Sources of Electricity Produced in Spain, 2008"
},
legend: {
position: "bottom",
labels: {
template: "#= text # (#= value #%)"
}
},
seriesDefaults: {
labels: {
visible: true,
position: "outsideEnd",
format: "{0}%"
}
},
series: [{
type: "donut",
field: "value"
}],
tooltip: {
visible: true,
format: "{0}%"
}
});
}
function createTable() {
var template = kendo.template($("#tableScript").html());
$("body").prepend(template(chartData.data()));
}
createChart();
createTable();
Output
You can jump to the latest bin by adding /latest
to your URL
Keyboard Shortcuts
Shortcut | Action |
---|---|
ctrl + [num] | Toggle nth panel |
ctrl + 0 | Close focused panel |
ctrl + enter | Re-render output. If console visible: run JS in console |
Ctrl + l | Clear the console |
ctrl + / | Toggle comment on selected lines |
ctrl + ] | Indents selected lines |
ctrl + [ | Unindents selected lines |
tab | Code complete & Emmet expand |
ctrl + shift + L | Beautify code in active panel |
ctrl + s | Save & lock current Bin from further changes |
ctrl + shift + s | Open the share options |
ctrl + y | Archive Bin |
Complete list of JS Bin shortcuts |
JS Bin URLs
URL | Action |
---|---|
/ | Show the full rendered output. This content will update in real time as it's updated from the /edit url. |
/edit | Edit the current bin |
/watch | Follow a Code Casting session |
/embed | Create an embeddable version of the bin |
/latest | Load the very latest bin (/latest goes in place of the revision) |
/[username]/last | View the last edited bin for this user |
/[username]/last/edit | Edit the last edited bin for this user |
/[username]/last/watch | Follow the Code Casting session for the latest bin for this user |
/quiet | Remove analytics and edit button from rendered output |
.js | Load only the JavaScript for a bin |
.css | Load only the CSS for a bin |
Except for username prefixed urls, the url may start with http://jsbin.com/abc and the url fragments can be added to the url to view it differently. |