Redirects
To create redirections from one page to other
Options
- output html json netlify vercel function
The redirects output format
Default:"html"
- defaultStatus 301 302 307 308
The default status code to use
Default:301
Description
This plugin allows to create redirections from one page to other. It can output Netlify and Vercel config files, JSON and HTML pages with http-equiv="refresh"
meta tags.
Installation
Import this plugin in your _config.ts
file to use it:
import lume from "lume/mod.ts";
import redirects from "lume/plugins/redirects.ts";
const site = lume();
site.use(redirects());
export default site;
Usage
Let's say you have the following page in your site:
---
url: /articles/hello/
---
At some point, you decide to change the url to simply /hello/
. All urls to /articles/hello/
will be broken and the SEO ranking lost. To avoid that, you can create a redirection from the old url to the new one, so both links will work fine. You only have to create the oldUrl
variable with the previous url:
---
url: /hello/
oldUrl: /articles/hello/
---
Use an array to specify more than one old URL:
---
url: /hello/
oldUrl:
- /articles/hello/
- /articles/older-hello/
---
The plugin will generate automatically the redirections from the old page(s) to the new one. There are 4 different output methods:
- html: It's the default value. It creates an html page for each old url with a
<meta http-equiv="refresh" content="0; url="...">
tag. This method doesn't require any server configuration. - json: To create the
_redirects.json
JSON file with all redirects, compatible with the redirects middleware, which works on Deno Deploy. - netlify: To create (or update) a
_redirects
file, compatible with Netlify. - vercel: To create (or update) the
vercel.json
file with all redirects.
Example:
site.use(redirects({
output: "netlify",
}));