如何按百分比滚动反应?
How to scroll by percentage in react?
我有一个像这样的可水平滚动的 flexbox。
每个框的宽度为 25%。我正在尝试使用按钮左右滚动。现在它像代码中那样滚动 420px,但这会导致响应问题。有没有办法在反应中使用“25%”而不是“420”。
const scrollLeftHandler = () => {
var elmnt = document.getElementById("programCard");
if (elmnt.scrollLeft !== 0) {
elmnt.scrollLeft += -420;
setIsRightSlide(true);
} else {
setIsLeftSlide(false);
}
};
const scrollRightHandler = () => {
var elmnt = document.getElementById("programCard");
if (elmnt.scrollLeft % 420 === 0 && isRightSlide) {
console.log("if");
setIsLeftSlide(true);
elmnt.scrollLeft += 420;
} else if (isRightSlide) {
elmnt.scrollLeft = elmnt.scrollLeft - (elmnt.scrollLeft % 420);
elmnt.scrollLeft += 420;
setIsRightSlide(false);
} else {
console.log("else", elmnt.scrollLeft);
setIsRightSlide(false);
}
您可以使用:
let step = (window.innerWidth || docElem.clientWidth || body.clientWidth)*(25/100)
您可以将 420
替换为 step
。
我有一个像这样的可水平滚动的 flexbox。
每个框的宽度为 25%。我正在尝试使用按钮左右滚动。现在它像代码中那样滚动 420px,但这会导致响应问题。有没有办法在反应中使用“25%”而不是“420”。
const scrollLeftHandler = () => {
var elmnt = document.getElementById("programCard");
if (elmnt.scrollLeft !== 0) {
elmnt.scrollLeft += -420;
setIsRightSlide(true);
} else {
setIsLeftSlide(false);
}
};
const scrollRightHandler = () => {
var elmnt = document.getElementById("programCard");
if (elmnt.scrollLeft % 420 === 0 && isRightSlide) {
console.log("if");
setIsLeftSlide(true);
elmnt.scrollLeft += 420;
} else if (isRightSlide) {
elmnt.scrollLeft = elmnt.scrollLeft - (elmnt.scrollLeft % 420);
elmnt.scrollLeft += 420;
setIsRightSlide(false);
} else {
console.log("else", elmnt.scrollLeft);
setIsRightSlide(false);
}
您可以使用:
let step = (window.innerWidth || docElem.clientWidth || body.clientWidth)*(25/100)
您可以将 420
替换为 step
。