【发布时间】:2021-07-05 08:34:57
【问题描述】:
我正在使用 D3 charts,通过反应,我创建了条形图并使其具有响应性。
当我调整浏览器的大小时,栏会相应地占用宽度。
问题
我想要实现的一件事是动态标签,比如当我调整页面大小时,标签的长度有点大,所以它比其他的要长
所以我想克服这个问题,我搜索了很多,发现了一个例子,当它全屏呈现时,它看起来像
当我将浏览器调整为小屏幕时!it looks like this]3。
所以我想实现但没有任何想法。
我做了什么
import React, { useRef, useEffect, useState } from 'react';
import { select, axisBottom, axisRight, scaleLinear, scaleBand } from 'd3';
import ResizeObserver from 'resize-observer-polyfill';
const useResizeObserver = (ref) => { // doing this for resizing
const [dimensions, setDimensions] = useState(null);
useEffect(() => {
const observeTarget = ref.current;
const resizeObserver = new ResizeObserver((entries) => {
entries.forEach((entry) => {
setDimensions(entry.contentRect);
});
});
resizeObserver.observe(observeTarget);
return () => {
resizeObserver.unobserve(observeTarget);
};
}, [ref]);
return dimensions;
};
function BarChart({ data }) {
const svgRef = useRef();
const wrapperRef = useRef();
const dimensions = useResizeObserver(wrapperRef);
// will be called initially and on every data change
useEffect(() => {
const svg = select(svgRef.current);
if (!dimensions) return;
// scales
const xScale = scaleBand()
.domain(data.map((value, index) => index + '2021+01+06'))
.range([0, dimensions.width]) // change
.padding(0.5);
const yScale = scaleLinear()
.domain([0, 150]) // todo
.range([dimensions.height, 0]); // change
// create x-axis
const xAxis = axisBottom(xScale).ticks(data.length);
svg
.select('.x-axis')
.style('transform', `translateY(${dimensions.height}px)`)
.call(xAxis);
// create y-axis
const yAxis = axisRight(yScale);
svg
.select('.y-axis')
.style('transform', `translateX(${dimensions.width}px)`)
.call(yAxis);
// draw the bars
svg
.selectAll('.bar')
.data(data)
.join('rect')
.attr('class', 'bar')
.style('transform', 'scale(1, -1)')
.attr('x', (value, index) => xScale(index + '2021+01+06'))
.attr('y', -dimensions.height)
.attr('width', xScale.bandwidth())
.transition()
.attr('fill', '#015e89')
.attr('height', (value) => dimensions.height - yScale(value));
}, [data, dimensions]);
return (
<div ref={wrapperRef} style={{ marginBottom: '2rem' }}>
<svg ref={svgRef}>
<g className="x-axis" />
<g className="y-axis" />
</svg>
</div>
);
}
export default BarChart;
【问题讨论】:
标签: javascript reactjs d3.js react-hooks