网上找了一圈包括stackoverflow, 也没有找到mui textfield marquee的实现方式,结合gpt实现了下,效果是,如果这个文字不超过textfield本身,则不滚动,否则在鼠标悬浮的时候滚动,并且滚动的距离应该是比较恰到好处的
用法如下: text是你需要填写的文字
还可以再封装下比如一些style什么的..
TypeScript
<MarqueeTypography> text </MarqueeTypography>
TypeScript
import React, { useRef, useState, useEffect } from 'react';
import { Typography, GlobalStyles } from '@mui/material';
const MarqueeTypography = ({ children }) => {
const textRef = useRef(null);
const [isOverflowing, setIsOverflowing] = useState(false);
const [distance, setDistance] = useState(0);
useEffect(() => {
if (textRef.current) {
const textWidth = textRef.current.scrollWidth;
const containerWidth = textRef.current.clientWidth;
const newDistance = textWidth - containerWidth;
setIsOverflowing(textWidth > containerWidth);
if (newDistance !== distance) {
setDistance(newDistance);
}
}
}, [distance, children]);
return (
<>
<GlobalStyles
styles={{
'@keyframes marquee': {
'0%': { transform: 'translateX(0%)' },
'100%': { transform: `translateX(-${distance}px)` },
},
}}
/>
<Typography
fontSize={'14px'}
ref={textRef}
sx={{
overflow: 'hidden',
whiteSpace: 'nowrap',
textOverflow: 'ellipsis',
'&:hover': {
overflow: 'visible',
textOverflow: 'clip',
whiteSpace: 'nowrap',
animation: isOverflowing ? `marquee 3s linear infinite` : 'none',
},
}}
>
{children}
</Typography>
</>
);
};