查看“Docsify 服务端渲染(SSR)”的源代码
←
Docsify 服务端渲染(SSR)
跳到导航
跳到搜索
因为以下原因,您没有权限编辑本页:
您请求的操作仅限属于该用户组的用户执行:
用户
您可以查看和复制此页面的源代码。
先看例子 https://docsify.now.sh 项目地址在 https://github.com/docsifyjs/docsify-ssr-demo [[File:https://dn-mhke0kuv.qbox.me/2bfef08c592706108055.png]] 文档依旧是部署在 GitHub Pages 上,Node 服务部署在 now.sh 里,渲染的内容是从 GitHub Pages 上同步过来的。所以静态部署文档的服务器和服务端渲染的 Node 服务器是分开的,也就是说你还是可以用之前的方式更新文档,并不需要每次都部署。 <span id="什么是-ssr"></span> == 什么是 SSR? == * 更好的 SEO * 更酷的感觉 == 快速开始 == 如果你熟悉 <code>now</code> 的使用,接下来的介绍就很简单了。先创建一个新项目,并安装 <code>now</code> 和 <code>docsify-cli</code>。 <pre lang="bash">npm i now docsify-cli -D</pre> 编辑 <code>package.json</code>。假设你的文档放在 <code>./docs</code> 子目录。 <pre lang="json">{ "name": "my-project", "scripts": { "start": "docsify start . -c ssr.config.js", "deploy": "now -p" }, "files": [ "docs" ], "docsify": { "config": { "basePath": "https://docsify.js.org/", "loadSidebar": true, "loadNavbar": true, "coverpage": true, "name": "docsify" } } }</pre> !> 其中 <code>basePath</code> 相当于 webpack 的 <code>publicPath</code> ,为文档所在的路径,可以填你的 docsify 文档网站。我们可以使用本地或者远程文件。 配置好了以后,我们可以在本地预览。 <pre lang="bash">npm start # open http://localhost:4000</pre> 发布! <pre lang="bash">now -p</pre> 现在,你有一个支持服务端渲染的文档网站了。 == 定制模板 == 你可以提供一个整页模板,例如: <pre lang="html"><!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>docsify</title> <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0"> <link rel="stylesheet" href="//cdn.jsdelivr.net/npm/docsify/themes/vue.css" title="vue"> </head> <body> <!--inject-app--> <!--inject-config--> <script src="//cdn.jsdelivr.net/npm/docsify/lib/docsify.js"></script> <script src="//cdn.jsdelivr.net/npm/docsify/lib/plugins/search.js"></script> <script src="//cdn.jsdelivr.net/npm/prismjs/components/prism-bash.min.js"></script> <script src="//cdn.jsdelivr.net/npm/prismjs/components/prism-markdown.min.js"></script> <script src="//cdn.jsdelivr.net/npm/prismjs/components/prism-nginx.min.js"></script> </body> </html></pre> 模板可以包含占位符,会自动将渲染后的 html 和配置内容注入到页面上。 * <code><!--inject-app--></code> * <code><!--inject-config--></code> == 配置 == 配置可以单独写在配置文件内,然后通过 <code>--config config.js</code> 加载,或者写在 <code>package.json</code> 中。 渲染的基础模版也可以自定义,配置在 <code>template</code> 属性上。 <pre lang="js">module.exports = { template: './ssr.html', maxAge: 60 * 60 * 1000, // lru-cache 设置 config: { // docsify 设置 } }</pre> == 更多玩法 == 你可以直接在你的 Node 服务器上执行 <code>docsify start</code> 。 <code>docsify start</code> 其实是依赖了 [https://npmarket.surge.sh/?name=docsify-server-renderer <code>docsify-server-renderer</code>] 模块,如果你感兴趣,你完全可以用它自己实现一个 server,可以加入缓存等功能。 <pre lang="js">var Renderer = require('docsify-server-renderer') var readFileSync = require('fs').readFileSync // init var renderer = new Renderer({ template: readFileSync('./docs/index.template.html', 'utf-8'), config: { name: 'docsify', repo: 'docsifyjs/docsify' } }) renderer.renderToString(url) .then(html => {}) .catch(err => {})</pre> 当然文档文件和 server 也是可以部署在一起的,<code>basePath</code> 不是一个 URL 的话就会当做文件路径处理,也就是从服务器上加载资源。
返回至“
Docsify 服务端渲染(SSR)
”。
导航菜单
个人工具
登录
命名空间
页面
讨论
大陆简体
查看
阅读
查看源代码
查看历史
更多
搜索
导航
首页
基础知识
正则表达式
Markdown
分布式
项目管理
系统集成项目管理基础知识
云原生
Docker
云原生安全
云原生词汇表
十二因素应用
Kubernetes
音频处理
音频合成
Edge-tts
CMS系统
Docsify
VuePress
Mediawiki
自动生成
Marp
CI/CD
GitLab
设计
颜色
平面设计
AI
数字人
操作系统
GNU/Linux
数据库
Mysql
工具
链入页面
相关更改
特殊页面
页面信息