Open Event Server: No (no-wrap) Ellipsis using jquery!
Yes, the title says it all i.e., Enabling multiple line ellipsis. This was used to solve an issue to keep Session abstract view within 200 characters (#3059) on FOSSASIA‘s Open Event Server project.
There is this one way to ellipsis a paragraph in html-css and that is by using the text-overflow property:
.div_class{ white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }’’
But the downside of this is the one line ellipis. Eg: My name is Medozonuo. I am…..
And here you might pretty much want to ellipsis after a few characters in multiple lines, given that your div space is small and you do want to wrap your paragraph. Or maybe not.
So jquery to the rescue.
There are two ways you can easily do this multiple line ellipsis:
1) Height-Ellipsis (Using the do-while loop):
//script: if ($('.div_class').height() > 100) { var words = $('.div_class').html().split(/\s+/); words.push('...'); do { words.splice(-2, 1); $('.div_class').html( words.join(' ') ); } while($('.div_class').height() > 100); }
Here, you check for the div content’s height and split the paragraph after that certain height and add a “…”, do- while making sure that the paragraphs are in multiple lines and not in one single line. But checkout for that infinite loop.
2) Length-Ellipsis (Using substring function):
//script: $.each($('.div_class'), function() { if ($(this).html().length > 100) { var cropped_words = $(this).html(); cropped_words = cropped_words.substring(0, 200) + "..."; $(this).html(cropped_words); } });
Here, you check for the length/characters rather than the height, take in the substring of the content starting from 0-th character to the 200-th character and then add in extra “…”.
This is exactly how I used it in the code.
$.each($('.short_abstract',function() { if ($(this).html().length > 200) { var words = $(this).html(); words = words.substring(0,200 + "..."; $(this).html(words); } });
So ellipsing paragraphs over heights and lengths can be done using jQuery likewise.