The Docsify Versioned Plugin allows you to manage and display multiple versions of your documentation using a simple dropdown selector. Users can easily switch between different versions of the documentation, while the plugin ensures that the content and links are updated accordingly.
- Add the following script tag to your
index.html
file, preferably after the Docsify script:
<script src="https://cdn.jsdelivr.net/npm/[email protected]/index.js"></script>
- Add the following style tag to your index.html file to include the plugin's CSS:
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/[email protected]/styles.css">
In your index.html file, update the Docsify configuration to include the versions and default version:
window.$docsify = {
// ... Other configuration options
versions: [
{ folder: 'v2', label: 'v2.0.0', default: true },
{ folder: 'v1', label: 'v1.0.0', default: false }
],
versionSelectorLabel: 'Version',
};
Update the versions
array with your version names and folders. Set the default
property to true
for the version you want to display by default. The order of the array also defines the order in the dropdown.
Make sure the respective folder exists. Labels can be updated without the need to change the folder name.
You can also update the versionSelectorLabel
, if you want to change the label in front of the dropdown.
Once the plugin is installed and configured, it will automatically display a dropdown selector at the top of the navigation bar, allowing users to switch between different versions of the documentation. The content and links will be updated accordingly based on the selected version.
In your Markdown files, you can use the {{versionLabel}}
placeholder to display the current version label. For example, you can include the following line in your _coverpage.md file:
# My Project Documentation ({{versionLabel}})
This will display the current version label (e.g., "v1.0.0" or "v2.0.0") next to the project title on the cover page.
If you want to use the search plugin and have the search limited to the current version, you can paste the following code in your index.html
and create a separate name space for each version.
<script>
(function() {
// Get the current version from the URL
const versionFolder = window.location.pathname.split('/')[1];
// Set the search configuration based on the current version
window.$docsify.search = {
maxAge: 86400000,
paths: 'auto',
placeholder: 'Search',
noData: 'No Results!',
depth: 2,
hideOtherSidebarContent: false,
namespace: 'docs-' + versionFolder // Set a unique namespace for each version
};
})();
</script>
Current limitations are as follows:
- Images or other assets need to be stored within the respective version-folder, a direct access to an outside folder is not possible.
- Styling is adapted to
theme-simple
, might not look as good with other themes.
MIT License.