作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个组件需要在文本溢出时显示一个按钮。目前我将 text-overflow
设置为 ellipsis
并希望在那之后显示一个按钮。
这变得很复杂,因为没有固定数量的允许字符或特定大小。
无论如何,我如何使用 React 或 SCSS 检查它?
这是我目前拥有的示例:
const content = [
'short string. No button should be displayed.',
'Long string, please display button! Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.'
]
const RenderString = ({content}) => {
return (
<div style={{ border: '1px solid blue' }}>
<div className='limited-space'>
{content}
</div>
<button>You should only see me if text is too long</button>
</div>
)
}
const App = () => {
return (
<div>
{content.map((c, index) => <RenderString key={index} content={c}/>)}
</div>
)
}
ReactDOM.render(
<App />,
document.getElementById('app')
);
.limited-space {
margin: 10px;
padding: 10px;
width: 400px;
text-overflow: ellipsis;
white-space: nowrap;
overflow: hidden;
border: 1px red solid;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.8.0/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.8.0/umd/react-dom.production.min.js"></script>
<div id="app"></div>
最佳答案
来源:this answer
const content = [
'short string. No button should be displayed.',
'Long string, please display button! Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.'
]
const RenderString = ({content}) => {
const [isOverflowing, setIsOverflowing] = React.useState(false);
const widthRef = React.useRef(null);
React.useEffect(() => {
const el = widthRef.current;
if(el.offsetWidth < el.scrollWidth){
setIsOverflowing(true);
}
}, []);
return (
<div style={{ border: '1px solid blue' }}>
<div className='limited-space' ref={widthRef}>
{content}
</div>
{isOverflowing ? <button>You should only see me if text is too long</button> : null }
</div>
)
}
const App = () => {
return (
<div>
{content.map((c, index) => <RenderString key={index} content={c}/>)}
</div>
)
}
ReactDOM.render(
<App />,
document.getElementById('app')
);
.limited-space {
margin: 10px;
padding: 10px;
width: 400px;
text-overflow: ellipsis;
white-space: nowrap;
overflow: hidden;
border: 1px red solid;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.8.0/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.8.0/umd/react-dom.production.min.js"></script>
<div id="app"></div>
关于javascript - 如何仅在文本溢出时显示按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68087644/
我是一名优秀的程序员,十分优秀!