Slugify URLs

Slugify all page URLs to remove potentially conflicting characters

Options See on deno.land

extensions string[] *

The list of extensions this plugin applies to

Default:
[ ".html" ]
lowercase boolean

Convert the paths to lower case

Default:
true
alphanumeric boolean

Remove all non-alphanumeric characters

Default:
true
separator string

Character used as word separator

Default:
"-"
replace object

Characters to replace

Default:
{
  "Ð": "D",
  "ð": "d",
  "Đ": "D",
  "đ": "d",
  "ø": "o",
  "ß": "ss",
  "æ": "ae",
  "œ": "oe"
}
stopWords string[]

Words to remove

Description

The slugify_urls plugin converts all URLs in your HTML documents by removing or replacing potentially conflicting characteres like accents, spaces, etc.

Once enabled, all output paths are automatically slugified: the spaces are replaced with -, characters like ñ or á are replaced by ASCII equivalents (n and a), and converted to lower case:

/posts/My First Post.md  =>  /posts/my-first-post/index.html

Installation

Import this plugin in your _config.ts file to use it:

import lume from "lume/mod.ts";
import slugifyUrls from "lume/plugins/slugify_urls.ts";

const site = lume();

site.use(slugifyUrls());

export default site;

Configuration

You can configure the slugifier in your _config.js file with the following options:

site.use(slugifyUrls({
  lowercase: true, // Converts all characters to lowercase
  alphanumeric: true, // Replace non-alphanumeric characters with their equivalent. Example: ñ to n.
  separator: "-", // Character used as separator for words
  stopWords: ["and", "or", "the"], // A list of words not included in the slug
  replace: { // An object with individual character replacements
    "Ð": "D", // eth
    "ð": "d",
    "Đ": "D", // crossed D
    "đ": "d",
    "ø": "o",
    "ß": "ss",
    "æ": "ae",
    "œ": "oe",
}));