Render a simple interactive slider using SVG.
Examples:
Inspired by The New York Times Is It Better to Rent or Buy?
If you need to include a slider within an svg element this is for you. For example, use a slider in place of an axis in a chart.
If you don't need to work inside an svg element then I would consider using one of the many excellent html-based components which may be better suited to your needs. Of course you might just love using d3!
If you use NPM, npm install d3-simple-slider
. Otherwise, download the latest release. AMD, CommonJS, and vanilla environments are supported. In vanilla, a d3
global is exported:
<script src="https://d3js.org/d3.v5.js"></script>
<script src="https://unpkg.com/d3-simple-slider"></script>
<p id="value"></p>
<div id="slider"></div>
<script>
var slider = d3
.sliderHorizontal()
.min(0)
.max(10)
.step(1)
.width(300)
.displayValue(false)
.on('onchange', val => {
d3.select('#value').text(val);
});
d3.select('#slider')
.append('svg')
.attr('width', 500)
.attr('height', 100)
.append('g')
.attr('transform', 'translate(30,30)')
.call(slider);
</script>
Regardless of orientation, sliders are always rendered at the origin. To change the position of the slider specify a transform attribute on the containing element. For example:
d3.select('body')
.append('svg')
.attr('width', 1440)
.attr('height', 30)
.append('g')
.attr('transform', 'translate(0,30)')
.call(slider);
The orientation of a slider is fixed; to change the orientation, remove the old slider and create a new slider.
All sliders may take a scale as an argument. If scale is specified, the slider will use the scale to render the slider. This must be either scaleLinear or scaleTime. The domain will be used to calculate minimum and maximum values. The range will be used to calculate the width or height of the slider. This means you do not need to set these if passing a scale.
# d3.sliderHorizontal([scale]) <>
Constructs a new horizontal slider generator. Note that this is equivalent to sliderBottom
.
# d3.sliderVertical([scale]) <>
Constructs a new vertical slider generator. Note that this is equivalent to sliderLeft
.
Constructs a new horizontal slider generator. Ticks on top.
Constructs a new vertical slider generator. Ticks to the right;
Constructs a new horizontal slider generator. Ticks on the bottom.
Constructs a new vertical slider generator. Ticks to the left;
Render the slider to the given context, which may be either a selection of SVG containers (either SVG or G elements) or a corresponding transition.
To generate twenty ticks:
slider.ticks(20);
# slider.tickValues([values]) <>
If a values array is specified, the specified values are used for ticks rather than using the sliders' automatic tick generator. If values is null, clears any previously-set explicit tick values and reverts back to the sliders' tick generator. If values is not specified, returns the current tick values, which defaults to null. For example, to generate ticks at specific values:
slider.tickValues([1, 2, 3, 5, 8, 13, 21]);
# slider.tickFormat([format]) <>
If format is specified, sets the tick format function and returns the slider. If format is not specified, returns the current format function, which defaults to null. A null format indicates that the slider's default formatter should be used.
See d3-format and d3-time-format for help creating formatters. For example, to display integers with comma-grouping for thousands:
slider.tickFormat(d3.format(',.0f'));
# slider.displayFormat([format]) <>
If format is specified, sets the function used to format the highlighted value and returns the slider. If format is not specified, returns the current format function, which defaults to null. A null format indicates that the tickFormat should be used. If tickFormat is null then the slider's default formatter should be used.
See d3-format and d3-time-format for help creating formatters. For example, to display integers with comma-grouping for thousands:
slider.displayFormat(d3.format(',.0f'));
If value is specified, sets the value of the slider to the specified value and returns the slider. If value is not specified, returns the current value.
If value is an array of length two then the values represent a range.
# slider.silentValue([value]) <>
If value is specified, sets the value of the slider to the specified value and returns the slider without invoking any listeners. If value is not specified, returns the current value.
If value is an array of length two then the values represent a range.
# slider.displayValue([value]) <>
If value is specified, sets the whether the highlighted value of the slider should be shown and returns the slider. If value is not specified, returns the current value, which defaults to true.
If value is specified, sets the SVG path definition used to render the slider handle and returns the slider. If value is not specified, returns the current value, which defaults to 'M-5.5,-5.5v10l6,5.5l6,-5.5v-10z'.
If size is specified, sets the width of the slider to the specified value and returns the slider. If size is not specified, returns the current width, which defaults to 100. This property only affects horizontal sliders and is ignored otherwise.
If size is specified, sets the height of the slider to the specified value and returns the slider. If size is not specified, returns the current height, which defaults to 100. This property only affects vertical sliders and is ignored otherwise.
If value is specified, sets the minimum value of the slider to the specified value and returns the slider. If value is not specified, returns the current minimum value, which defaults to 0.
If value is specified, sets the maximum value of the slider to the specified value and returns the slider. If value is not specified, returns the current maximum value, which defaults to 10.
If value is specified, an array which sets the minimum and maximum values of the slider and returns the slider. If value is not specified, returns the current maximum value, which defaults to [0, 10].
If color is specified, sets the color of the slider track-fill and returns the slider. If color is not specified, returns the current value, which defaults to null.
If value is specified, sets the increment which the slider will move in and returns the slider. If value is not specified, returns the current value, which defaults to null.
If value is specified, sets the values to which the slider will snap to and returns the slider. If value is not specified, returns the current value, which defaults to null.
If value is specified, sets the initial value of the slider and returns the slider. If value is not specified, returns the current value, which defaults to null.
# slider.on(typenames, [listener]) <>
If listener is specified, sets the event listener for the specified typenames and returns the slider. If an event listener was already registered for the same type and name, the existing listener is removed before the new listener is added. If listener is null, removes the current event listeners for the specified typenames, if any. If listener is not specified, returns the first currently-assigned listener matching the specified typenames, if any. When a specified event is dispatched, each listener will be invoked with the same context and arguments as selection.on listeners: the current datum d
and index i
, with the this
context as the current DOM element.
The typenames is a string containing one or more typename separated by whitespace. Each typename is a type, optionally followed by a period (.
) and a name, such as drag.foo
and drag.bar
; the name allows multiple listeners to be registered for the same type. The type must be one of the following:
onchange
- after the slider value has changed.start
- after a new pointer becomes active (on mousedown or touchstart).drag
- after an active pointer moves (on mousemove or touchmove).end
- after an active pointer becomes inactive (on mouseup, touchend or touchcancel).
You might consider throttling onchange
and drag
events. For example using lodash.throttle
.
See dispatch.on for more.