What is the Base URL? The Base URL (aka Public Path) configures the URL root of your website.
For example, instead of serving your website at https://example.org/*
(the Base URL is /
), you can serve your website at https://example.org/some-base/*
by setting the Base URL to /some-base/
.
base
To change the Base URL:
Set vite.config.js#base
.
// vite.config.js
export default {
base: '/some-base/'
}
Use import.meta.env.BASE_URL
to implement a <Link>
component that prepends the Base URL. Example: /examples/base-url/components/Link.jsx .
Use import.meta.env.BASE_URL
for referencing static assets living in public/
. Example: /examples/base-url/renderer/+onRenderHtml.jsx .
<!-- view-source:https://my-website.com/some-base/ -->
<!-- Note how the website is served at https://my-website.com/some-base/ and
how the asset URLs are prepended with the Base URL /some-base/ -->
< html >
< head >
< link href = "/some-base/logo.svg" rel = "icon" >
< link href = "/some-base/style.css" rel = "stylesheet" type = "text/css" >
</ head >
< body >
< nav >
< a href = "/some-base/" >Landing Page</ a >
< a href = "/some-base/about" >About Page</ a >
</ nav >
< script src = "/some-base/script.js" type = "module" ></ script >
</ body >
</ html >
Example:
baseAssets
You can change the Base URL only for your assets by using the baseAssets
setting. The Base URL of the URL of your pages is left unchanged.
The most common use case for using baseAssets
is when deploying assets to a CDN.
// vite.config.js
import vike from 'vike/plugin'
export default {
plugins: [
vike ({
baseAssets: 'https://cdn.example.org/my-website-assets/'
})
]
}
Note how the Base URL of the URL of your pages isn't changed: your website is still served at https://my-website.com/*
(the Base URL is still /
).
<!-- view-source:https://my-website.com/ -->
< html >
< head >
<!-- Note how the Base URL is 'https://cdn.example.org/my-website-assets/' -->
< link
href = "https://cdn.example.org/my-website-assets/logo.svg"
rel = "icon"
>
< link
href = "https://cdn.example.org/my-website-assets/style.css"
rel = "stylesheet"
type = "text/css"
>
</ head >
< body >
< nav >
<!-- Note how the Base URL is '/' -->
< a href = "/" >Landing Page</ a >
< a href = "/about" >About Page</ a >
</ nav >
<!-- Note how the Base URL is 'https://cdn.example.org/my-website-assets/' -->
< script src = "https://cdn.example.org/my-website-assets/script.js" type = "module" >
</ body >
</ html >
You can use process.env.BASE_ASSETS
and import.meta.env.BASE_ASSETS
to access the baseAssets
value in your code.
Example:
By default, the baseAssets
setting applies to both development and production. You can apply it only to production by using process.env.NODE_ENV
:
// vite.config.js
import vike from 'vike/plugin'
const isProduction = process.env. NODE_ENV === 'production'
const baseAssets = isProduction ? 'https://cdn.example.org/my-website-assets/' : undefined
export default {
plugins: [
vike ({ baseAssets })
]
}
There is work-in-progress to apply it only in production by default .
baseServer
You can do both:
Deploy your static assets to a CDN using the baseAssets
setting.
Change the Base URL of your server using the baseServer
setting.
// vite.config.js
import vike from 'vike/plugin'
export default {
plugins: [
vike ({
baseAssets: 'https://cdn.example.org/my-website-assets/' ,
baseServer: '/some-base/'
})
]
}
<!-- view-source:https://my-website.com/ -->
< html >
< head >
<!-- Note how the Base URL is 'https://cdn.example.org/my-website-assets/' -->
< link
href = "https://cdn.example.org/my-website-assets/logo.svg"
rel = "icon"
>
< link
href = "https://cdn.example.org/my-website-assets/style.css"
rel = "stylesheet"
type = "text/css"
>
</ head >
< body >
< nav >
<!-- Note how the Base URL is '/some-base/' -->
< a href = "/some-base/" >Landing Page</ a >
< a href = "/some-base/about" >About Page</ a >
</ nav >
<!-- Note how the Base URL is 'https://cdn.example.org/my-website-assets/' -->
< script src = "https://cdn.example.org/my-website-assets/script.js" type = "module" >
</ body >
</ html >
You can use process.env.BASE_SERVER
and import.meta.env.BASE_SERVER
to access the baseServer
value in your code.
Example: