From 48d09159ced212057583b21849c03baa4a730a63 Mon Sep 17 00:00:00 2001 From: Vitaly Orlov Date: Wed, 8 May 2019 01:36:08 +0300 Subject: [PATCH] Performance optimize option: splitEveryChars --- src/clamp.js | 21 +++++++++++++++++++-- src/index.d.ts | 3 +++ src/index.js | 1 + 3 files changed, 23 insertions(+), 2 deletions(-) diff --git a/src/clamp.js b/src/clamp.js index 1609bed..4926d9f 100644 --- a/src/clamp.js +++ b/src/clamp.js @@ -36,6 +36,7 @@ clamp: options.clamp || 2, useNativeClamp: typeof(options.useNativeClamp) != 'undefined' ? options.useNativeClamp : true, splitOnChars: options.splitOnChars || ['.', '-', '–', '—', ' '], //Split on sentences (periods), hypens, en-dashes, em-dashes, and words (spaces). + splitEveryChars: options.splitEveryChars || 0, animate: options.animate || false, truncationChar: options.truncationChar || '…', truncationHTML: options.truncationHTML @@ -189,6 +190,18 @@ lastChunk = null; } + /** + * Split a string, at every nth position + */ + function splitEvery(str, n) { + var arr = new Array; + for (var i = 0; i < str.length; i += n) + { + arr.push(str.substr(i, n)); + } + return arr; + } + var nodeValue = target.nodeValue.replace(opt.truncationChar, ''); //Grab the next chunks @@ -196,13 +209,17 @@ //If there are more characters to try, grab the next one if (splitOnChars.length > 0) { splitChar = splitOnChars.shift(); + chunks = nodeValue.split(splitChar); } //No characters to chunk by. Go character-by-character else { splitChar = ''; + if (opt.splitEveryChars) { + chunks = splitEvery(nodeValue, opt.splitEveryChars); + } else { + chunks = nodeValue.split(splitChar); + } } - - chunks = nodeValue.split(splitChar); } //If there are chunks left to remove, remove the last one and see if diff --git a/src/index.d.ts b/src/index.d.ts index c89e5cc..32f8a13 100644 --- a/src/index.d.ts +++ b/src/index.d.ts @@ -7,6 +7,9 @@ export interface DotdotdotProps { useNativeClamp?: boolean, className?: string, tagName?: string, + splitOnChars?: string[], + splitEveryChars?: number, + animate?: boolean, } export default class Dotdotdot extends React.Component { } diff --git a/src/index.js b/src/index.js index cd0541a..1dbd480 100644 --- a/src/index.js +++ b/src/index.js @@ -45,6 +45,7 @@ Dotdotdot.prototype.dotdotdot = function(container) { 'animate', 'clamp', 'splitOnChars', + 'splitEveryChars', 'truncationChar', 'truncationHTML', 'useNativeClamp'