txtgen
Lightweight util for generating random sentences, paragraphs and articles in English. Inspired by Sentencer and metaphorpsum.com.
Demo
Want to see how it works?
Setup
Usage
Node.js:
import {
sentence
} from 'txtgen'
sentence()
Note:
Since Node.js v14, ECMAScript modules have became the official standard format.
Just ensure that you are using module system and enjoy with ES6 import/export syntax.
Browsers:
Currently, ECMAScript modules work fine on almost all browsers:
<script type="module">
import { sentence } from 'https://unpkg.com/txtgen/dist/txtgen.esm.js'
console.log(sentence())
</script>
With outdated browsers, we can use the traditional method:
<script type="text/javascript" src="https://unpkg.com/txtgen/dist/txtgen.min.js"></script>
<script>
console.log(window.txtgen.sentence())
</script>
APIs
- .sentence()
- .paragraph([Number totalSentences])
- .article([Number totalParagraphs])
- .addNouns(Array nouns)
- .addAdjectives(Array adjectives)
- .addTemplates(Array sentenceTemplates)
- .setNouns(Array nouns)
- .setAdjectives(Array adjectives)
- .setTemplates(Array sentenceTemplates)
- .getNouns()
- .getAdjectives()
- .getTemplates()
As their name suggests, we have 4 groups of methods:
sentence()
, paragraph()
, article()
: generate text by given grammatical unitaddNouns()
, addAdjectives()
, addTemplates()
: add more samples to current sample setsetNouns()
, setAdjectives()
, setTemplates()
: replace current sample set with new onesgetNouns()
, getAdjectives()
, getTemplates()
: get current sample set
The set*
and get*
methods were added in v2.2.3 to help you customize your sample data.
Template
If you want to add more kinds of sentences, just use the .addTemplates()
method; it expects a list of sentence templates.
Each sentence template is an English sentence, containing placeholders that can be replaced with any alternative word.
For example:
import {
addTemplates
} from 'txtgen'
const templates = [
'{{a_noun}} is {{a_noun}} from the right perspective',
'the {{noun}} of {{a_noun}} becomes {{an_adjective}} {{noun}}'
]
addTemplates(templates)
Here are the available placeholders:
noun
nouns
a_noun
adjective
an_adjective
Test
git clone https://github.com/ndaidong/txtgen.git
cd txtgen
npm install
npm test
License
The MIT License (MIT)