Cross-browser multiline text ellipsis for react
Inspired by: https://github.com/BeSite/jQuery.dotdotdot
Internally uses: https://www.npmjs.com/package/clamp-js
npm install --save react-dotdotdot
import React from 'react'
import Dotdotdot from 'react-dotdotdot'
...
render() {
return (
<div>
<Dotdotdot clamp={3}>
<p>
Long, long <br />
content,<br />
3 lines <br />
will be shown.
</p>
</Dotdotdot>
</div>
)
}
clamp (Number | String | 'auto'). This controls where and when to clamp the text of an element. Submitting a number controls the number of lines that should be displayed. Second, you can submit a CSS value (in px or em) that controls the height of the element as a String. Finally, you can submit the word 'auto' as a string. Auto will try to fill up the available space with the content and then automatically clamp once content no longer fits. This last option should only be set if a static height is being set on the element elsewhere (such as through CSS) otherwise no clamping will be done.
ellipsis (String). The character to insert at the end of the HTML element after truncation is performed. This defaults to an ellipsis (…).
React-dotdotdot is simple plugin, if you need more functionality, consider using react-truncate https://www.npmjs.com/package/react-truncate
1.0.17
- Support for IE11, Edge and Firefox (thanks, @kkwiatkowski)
1.0.16
- Remove clamp-js from package.json dependencies, as it's not maintained anymore.
- Bugfix for
TypeError: elem.lastChild is null
in Firefox.