Skip to content

Instantly share code, notes, and snippets.

Last active November 30, 2019 18:30
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
Star You must be signed in to star a gist
Save d3noob/10633704 to your computer and use it in GitHub Desktop.
HTML number input and d3.js
license: mit

This is a simple example of implimenting an HTML input using a <number> input tag and using that to adjust a d3.js drawn svg element (rotate text).

It is used as an example and described in the book D3 Tips and Tricks.

<!DOCTYPE html>
<meta charset="utf-8">
<title>Input (number) test</title>
<label for="nValue"
style="display: inline-block; width: 240px; text-align: right">
angle = <span id="nValue-value"></span>
<input type="number" min="0" max="360" step="5" value="0" id="nValue">
<script src=""></script>
var width = 600;
var height = 300;
var holder ="body")
.attr("width", width)
.attr("height", height);
// draw the element
.style("fill", "black")
.style("font-size", "56px")
.attr("dy", ".35em")
.attr("text-anchor", "middle")
.attr("transform", "translate(300,150) rotate(0)")
// when the input range changes update value"#nValue").on("input", function() {
// Initial update value
// adjust the text
function update(nValue) {
// adjust the value"text")
.attr("transform", "translate(300,150) rotate("+nValue+")");
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment