(Yet another) Node.js module to generate URL slugs, also known as clean URLs, user-friendly URLs and SEO-friendly URLs.
The difference?
This module includes Romanisation of non-Latin scripts. Give it a string of text in pretty much any major world language and it will convert it to valid characters, conforming to RFC3986, for use within the path element of a URL.
Currently supports, but not limited to, the following scripts:
- Latin: e.g. English, français, Deutsch, español, português
- Cyrillic: e.g. Русский язык, български език, українська мова
- Chinese: e.g. 官话, 吴语 (converts to Latin script using Pinyin with optional tone number)
- Japanese: e.g. ひらがな, カタカナ (converts to Romaji using Hepburn)
If you already use either the
speakingurl or
slug modules,
you can probably swap in limax
without changing the logic in your code.
Oh, and limax
is the Latin word for slug.
npm install limax
var slug = require('limax');
var latin = slug('i ♥ latin'); // i-love-latin
var cyrillic = slug('Я люблю русский'); // ya-lyublyu-russkij
var pinyin = slug('我爱官话'); // wo3-ai4-guan1-hua4
var romaji = slug('私は ひらがな が大好き'); // ha-hiragana-gaki
options:
replacement
: String to replace whitespace with, defaults to-
(provides API compatibility with theslug
module)separator
: String, equivalent toreplacement
(provides API compatibility with thespeakingurl
module)lang
: String, ISO 639-1 two-letter language code, defaults to auto-detected languagetone
: Boolean, add tone numbers to Pinyin transliteration of Chinese, defaults totrue
separateNumbers
: Boolean, separate numbers that are within a word, defaults totrue
maintainCase
: Boolean, maintain the original string's casing, defaults tofalse
custom
:- Object, custom map for translation, overwrites all i.e. { '&': '#', '*': ' star ' }
- Array, add chars to allowed charMap
var strich = slug('Ich ♥ Deutsch', {lang: 'de'}); // ich-liebe-deutsch
var unterstreichen1 = slug('Ich ♥ Deutsch', {lang: 'de', replacement: '_'}); // i_liebe_deutsch
var unterstreichen2 = slug('Ich ♥ Deutsch', {lang: 'de', separator: '_'}); // i_liebe_deutsch
var wuYin = slug('弄堂里的菜品赤醬', {tone: false}); // nong-tang-li-di-cai-pin-chi-jiang
// separateNumbers example
var numbersInWord = slug('hello2world', {separateNumbers: false}); // hello2world
var numbersSeparated = slug('hello2world'); // hello-2-world
// maintainCase example
var caseNotMaintained = slug('Hello2World'); // hello-2-world
var caseMaintained = slug('Hello2World', { maintainCase: true }); // Hello-2-World
// custom example
var custom1 = slug('hello.world', { custom: ['.'] }); // hello.world
var custom2 = slug('hello-*-world', { custom: { '*': 'asterisk' } }); // hello-asterisk-world
Provided to support backwards-compatibility with the slug
module.
var underscore = slug('i ♥ unicode', '_'); // i_love_unicode
Run the unit tests with:
npm test
Pull requests with mappings and tests for further scripts and languages are more than welcome.
Copyright 2013, 2014, 2015, 2016 Lovell Fuller and contributors.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.