Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/benelliott/slimclamp
A stripped-down JavaScript text clamper, inspired by the original Clamp.js
https://github.com/benelliott/slimclamp
Last synced: 3 days ago
JSON representation
A stripped-down JavaScript text clamper, inspired by the original Clamp.js
- Host: GitHub
- URL: https://github.com/benelliott/slimclamp
- Owner: benelliott
- License: mit
- Created: 2015-08-06T16:46:52.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2019-06-04T15:40:48.000Z (over 5 years ago)
- Last Synced: 2024-04-27T18:46:35.184Z (9 months ago)
- Language: JavaScript
- Size: 11.7 KB
- Stars: 1
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# SlimClamp
A stripped-down JavaScript text clamper, inspired by the original [Clamp.js](https://github.com/josephschmitt/Clamp.js/).# Features
In short, this library allows you to limit the number of lines of text that are visible in an HTML element, gracefully truncating the text with an ellipsis if necessary. It uses browser-native functionality to do this if available, but otherwise will fall back to an iterative approach. This approach uses a binary search method to converge on an admissible truncation.
This library will improve on the original in the following ways:
- Full IE8+ compatibility
- Much smaller file size
- Cleaner code structure
- Fewer bugs
- Complete function documentation
- Bower and NPM supportHowever this comes at the cost of cutting away some features, such as the 'auto' and '__px' clamping settings. Neither of these were suitable for my use case and I am sceptical that the former does not work in the original library. I may include the latter at a later date. Thus it currently only supports usage in the following way:
```
$clamp(elementToBeClamped, numberOfLinesToClamp);
```
Another difference is that this library will happily split a text string at any character, while the original will iterate through a list of preferred 'split characters' (such as whitespace) before resorting to breaking words arbitrarily.Note that one limitation which exists on both versions of the library is that text will not be correctly truncated if the clamping is performed before the elements have been fully rendered, if viewing on a browser that lacks native support for text clamping.
# Installation
SlimClamp is available through NPM or Bower. Install using
```
npm install slimclamp
```
or
```
bower install slimclamp
```# TODOs
- Add '__px' config setting (maybe).