Skip to content
Add live paragraph-, word- and character-counting to an HTML element.
JavaScript
Branch: master
Clone or download

Latest commit

RadLikeWhoa Merge pull request #48 from youjenli/type-definition
Add type definition of typescript for Countable
Latest commit 5f8339f Aug 22, 2019

Files

Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
test Add support for strings in Countable#once Jun 11, 2018
.gitignore Monitor code coverage Dec 2, 2015
.jshintrc Add jshintrc Dec 19, 2014
.travis.yml Update travis config Jul 13, 2017
CONTRIBUTING.md Update contribution guidelines May 3, 2013
Countable.js Add 'use strict' directive Jul 16, 2019
Countable.min.js Update minified script Jul 16, 2019
LICENSE.md Update license Jan 8, 2015
README.md Fix wrong method documentation in README Aug 22, 2019
index.d.ts Add interface to describe the shape of parameters of Countable. Apr 18, 2019
karma.conf.js Update travis config Jul 13, 2017
package.json Bump version Jun 11, 2018
yarn.lock Add minified script Jun 11, 2018

README.md

Countable

Build Status Code Climate Latest Tag License

Countable is a JavaScript function to add live paragraph-, word- and character-counting to an HTML element. Countable is a zero-dependency library and comes in at 1KB when minified and gzipped.

View the Demo

Installation

The preferred method of installation is npm or yarn.

npm i --save-dev countable
yarn add --dev countable

Alternatively, you can download the latest zipball or copy the script directly.

Usage

Countable is available as a Node / CommonJS module, an AMD module and as a global. All methods are accessed on the Countable object directly.

Callbacks

The on and count methods both accept a callback. The given callback is then called whenever needed with a single parameter that carries all the relevant data. this is bound to the current element. Take the following code for an example.

Countable.count(document.getElementById('text'), counter => console.log(this, counter))
=> <textarea id="text"></textarea>, { all: 0, characters: 0, paragraphs: 0, words: 0 }
Property Meaning
paragraphs The number of paragraphs. Paragraphs can be separated by either a soft or a hard (two line breaks) return. To use hard returns, set the corresponding option (hardReturns).
sentences The number of sentences. Sentences are separated by a sentence-terminating character.
words The number of words. Words are split using spaces.
characters The number of characters (without spaces). This contains all non-whitespace characters.
all The number of characters including whitespace. This is the total number of all characters in the element.

Countable.on(elements, callback, options)

Bind the callback to all given elements. The callback gets called every time the element's value or text is changed.

Countable.on(area, counter => console.log(counter))

Countable.off(elements)

Remove the bound callback from all given elements.

Countable.off(area)

Countable.count(elements, callback, options)

Similar to Countable.on(), but the callback is only executed once, there are no events bound.

Countable.count(area, counter => console.log(counter))

Countable.enabled(elements)

Checks the live-counting functionality is bound to the given.

Countable.enabled(area)

Options

Countable.on() and Countable.count() both accept a third argument, an options object that allows you to change how Countable treats certain aspects of your element's text.

{
  hardReturns: false,
  stripTags: false,
  ignore: []
}

By default, paragraphs are split by a single return (a soft return). By setting hardReturns to true, Countable splits paragraphs after two returns.

Depending on your application and audience, you might need to strip HTML tags from the text before counting it. You can do this by setting stripTags to true.

Sometimes it is desirable to ignore certain characters. These can be included in an array and passed using the ignore option.

Browser Support

Countable supports all modern browsers. Full ES5 support is expected, as are some ES6 features, namely let and const.

You can’t perform that action at this time.