txtgen
Lightweight util for generating random sentences, paragraphs and articles in English. Inspired by Sentencer and metaphorpsum.com.
Demo
See how it works?
Setup
Usage
Node.js:
Sync v14, ECMAScript modules have became the official standard format.
Just enable and enjoy with ES6 import/export syntax.
import { sentence } from 'txtgen'
console.log(sentence())
For regular CommonJS environment, require
can be used as below:
const txtgen = require('txtgen/dist/cjs/txtgen.js')
console.log(txtgen.sentence())
Browsers:
Currently ECMAScript modules work fine on almost 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 traditional way:
<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 means, 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 since v2.2.3 to help you customize your sample data.
Template
If you want to add more kinds of sentence, just use .addTemplates()
method. It expects a list of sentence templates.
Each of sentence template is an English sentence, with the 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)