javascript – 如何在D3.js中的图表上设置滑块样式并显示动态y值的标签?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – 如何在D3.js中的图表上设置滑块样式并显示动态y值的标签?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含3157字,纯文字阅读大概需要5分钟。
内容图文
Here is a sample fiddle of a simple chart.
我是第一个学习D3.js的人,我很喜欢它并且它和它的创造者Mike Bostock印象深刻.
我创建了一个图表网页,其价值相互影响,有点像Bostock的惊人Rent Versus Buy calculator in the New York Times.
我试图创建一个滑块(使用JqueryUI)来更改输入值(如下面显示的$250,000输入框),这会影响图表的y值.它有效,但外观令人失望,不适合移动设备.
我一直无法通过教程或documentation弄清楚如何创建像Bostock那样的滑块,如下所示:
我不认为Bostock使用除D3以外的任何东西来构建他的滑块和样式.
我试图查看他的源代码,但没有运气搞清楚.
在my sample fiddle,我使用JqueryUI滑块($(“< div class ='slider'>< / div>”).insertAfter(输入).slider())和一些CSS.
我还没有找到D3的功能可以帮助我的图表看起来更像他的吗?
如果你可以指出我如何创建(和样式)滑块,y值标签和轴的正确方向,我真的很感激.
解决方法:
这是一个非常简单的演示,我从头开始编写,因此不是基于你的小提琴中的代码,显示了你想要创建的dataviz的基本方面.
在这个演示中,我只使用D3,没有jQuery(混合D3与jQuery让我头疼):
var width = 500,
height = 180,
padding = 16;
var svg = d3.select("#svg")
.append("svg")
.attr("width", width)
.attr("height", height);
var data = d3.range(1, 21);
var xScale = d3.scaleBand()
.domain(data)
.range([padding * 2, width - padding])
.padding(0.2);
var yScale = d3.scaleLinear()
.domain([0, d3.max(data, d => d)])
.range([height - padding, padding]);
var bars = svg.selectAll(".bars")
.data(data)
.enter()
.append("rect")
.attr("x", d => xScale(d))
.attr("width", xScale.bandwidth())
.attr("y", d => yScale(d))
.attr("height", d => height - padding - yScale(d))
.attr("fill", (d => d3.select("#slider").node().value == d ? "firebrick" : "teal"));
var xAxis = d3.axisBottom(xScale);
var yAxis = d3.axisLeft(yScale);
var gX = svg.append("g")
.attr("transform", "translate(0," + (height - padding) + ")")
.call(xAxis);
var gY = svg.append("g")
.attr("transform", "translate(" + padding * 2 + ",0)")
.call(yAxis);
d3.select("#slider").on("input", function() {
var currentValue = this.value;
yScale.domain([0, currentValue * 2])
bars.attr("y", d => yScale(d))
.attr("height", d => height - padding - yScale(d))
.attr("fill", (d => currentValue == d ? "firebrick" : "teal"));
gY.call(yAxis);
})
#slider {
width: 435px;
}
#sliderdiv{
padding-left: 40px;
}
<script src="https://d3js.org/d3.v4.min.js"></script>
<div id="svg"></div>
<div id="sliderdiv"><input id="slider" type="range" min="1" max="20" step="1" value="10"/></div>
说明:
在这个例子中,我使用滑块的常规HTML输入:
<input id="slider" type="range" min="1" max="20" step="1" value="10"/>
然后,我们使用此函数获取该滑块的更改:
d3.select("#slider").on("input", function() {
var currentValue = this.value;
yScale.domain([0, currentValue * 2])
bars.attr("y", d => yScale(d))
.attr("height", d => height - padding - yScale(d))
.attr("fill", (d => currentValue == d ? "firebrick" : "teal"));
gY.call(yAxis);
})
在这个功能中,我们有3个主要步骤.首先,我们得到滑块的当前值:
var currentValue = this.value;
并且,使用该值,我们更改y比例:
yScale.domain([0, currentValue * 2])
这样,选中的栏将始终保持在相同的高度,就像在Bostock的代码中一样.然后,我们更新吧:
bars.attr("y", d => yScale(d))
.attr("height", d => height - padding - yScale(d))
.attr("fill", (d => currentValue == d ? "firebrick" : "teal"));
最后,y轴:
gY.call(yAxis);
内容总结
以上是互联网集市为您收集整理的javascript – 如何在D3.js中的图表上设置滑块样式并显示动态y值的标签?全部内容,希望文章能够帮你解决javascript – 如何在D3.js中的图表上设置滑块样式并显示动态y值的标签?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。