單行文本溢出,可直接用css處理,很簡單css
.ellipsis { overflow: hidden; text-overflow:ellipsis; white-space: nowrap; }
多行文本溢出,在不考慮兼容性的狀況下,可直接用css 實現:react
.ellipsis { display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 3; // 顯示幾行 overflow: hidden; }
可是用css 兼容性很不友好,下面是react實現多行溢出顯示...,實現原理就是支持css處理的時候,直接用css,不支持的時候,經過js計算來處理顯示文字web
import React from 'react'; export default class Ellipsis extends React.Component { static defaultProps = { line: 2, ellipsis: '...' }; constructor(props) { super(props); let that = this; this.text = ''; this.setLineClamp = this.setLineClamp.bind(this); this.setLineNormal = this.setLineNormal.bind(this); this.clipText = this.clipText.bind(this); this.init = this.init.bind(this); } componentDidMount() { this.init(); } componentDidUpdate() { this.init(); } init() { if ('webkitLineClamp' in document.documentElement.style) { this.setLineClamp(); this.removeTpl(); } else { this.setLineNormal(); this.clipText(); } } removeTpl() { try { this.refs.ellip.removeChild(this.refs.getHeight); } catch (err) {} } setLineNormal() { Object.assign(this.refs.ellip.style, { 'word-break': 'break-all', 'white-space': 'normal' }); } setLineClamp() { Object.assign(this.refs.ellip.style, { 'overflow': 'hidden', 'display': '-webkit-box', 'webkitBoxOrient': 'vertical', 'word-break': 'break-all', 'white-space': 'normal', 'webkitLineClamp': this.props.line }); } clipText() { let {line, ellipsis, end = () => {}} = this.props; let ellip = this.refs.ellip; if (!this.h) { let getHeight = this.refs.getHeight; this.h = getHeight.offsetHeight; this.removeTpl(); } let getCountHeight = () => { return parseFloat(getComputedStyle(ellip)['height'], 10); }; let init = true; if (!this.text) { this.text = ellip.textContent; } else { ellip.innerHTML = this.text; } let text = this.text; let clip = () => { let len = 0; while (Math.floor(getCountHeight() / this.h) > line) { len += 1; text = text.slice(0, -1); ellip.innerHTML = text; if (!init) { ellip.innerHTML += ellipsis; } } return len; }; if (0 < clip()) { ellip.innerHTML += ellipsis; init = false; clip(); } end(); } render() { let {children, className = ''} = this.props; return ( <div ref="box" className={className}> <div ref="ellip"> {children} <span ref="getHeight" style={{visibility: 'hidden'}}>好</span> </div> </div> ); } }
<Ellipsis>要處理的文字</Ellipsis>