最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • VuePress源码阅读(三) -- 「成"站"之日」markdown建站分析篇 | 七日打卡

    正文概述 掘金(Nodreame)   2021-01-17   672

    VuePress源码阅读(三) -- 「成"站"之日」markdown建站分析篇 | 七日打卡

    之前写了两篇文章来记录对 VuePress dev 和 build 执行过程的源码阅读记录,不过那只是为了学习 VuePress 所做的一点小调研,目的是对 VuePress 的整个执行流程有个大概的把控.

    而 VuePress 在我看来更重要的是通过整合一系列技术,实现了仅靠 "markdown文件 + 配置" 快速构建网站的效果.

    在 VuePress 官方首页将 VuePress 定义为:

    • 项目结构以 Markdown 为中心
    • 是一个技术栈为"Vue + vue-router + Webpack"的静态网站生成器
    • 会为每个页面预渲染生成静态 HTML,被加载后作为 SPA 运行(Vue SSR 赋能)
    • 想要构建一个最简网站,甚至不用配置文件,只需要一个 README.md 就能成站

    前面两篇Vuepress源码分析的文章已经把整个 dev 和 build 的流程走过一遍了,现在我们对整个流程做一次整理:

    VuePress源码阅读(三) -- 「成"站"之日」markdown建站分析篇 | 七日打卡

    现在来思考一下整个流程中,VuePress 如何整合技术来实现 markdown 文件的建站.

    一. 寻找编译 markdown 文件的库

    markdown 是一种可用于在纯文本文档中添加格式化元素标记语言,故使用合适的转换工具将 markdown 文件编译成 HTML 文件,即可完成 Markdown 文件作为网站的展示.

    现在看看 VuePress 是使用什么库来完成 markdown 文件编译为 HTML 文件的.

    首先来到共享流程中的 app.process 阶段(node_modules/@vuepress/core/lib/node/App.js):

    VuePress源码阅读(三) -- 「成"站"之日」markdown建站分析篇 | 七日打卡

    可以看到这里通过 createMarkdown 函数获取到了 markdown,然后我们先倒推看看 createMarkdown 来自哪里(node_modules/@vuepress/core/lib/node/createMarkdown.js):

    VuePress源码阅读(三) -- 「成"站"之日」markdown建站分析篇 | 七日打卡

    这里的 siteConfig 其实就是 config.js 的配置,这里其实就是在 @vuepress/markdown 提供的 createMarkdown 前包装了一层,目的就是给 markdownConfig 配置添加两个属性.

    我们继续追溯 @vuepress/markdown,其内部使用了 markdown-it-chain 实现对 npm 包 markdown-it 的内置插件管理,我们可以通过require('@vuepress/markdown') 来查看或者改变内部插件的启用停用,最后使用 const md = config.toMd(require('markdown-it'), markdown) 来返回一个 markdown-it 对象(就是变量 md).

    那么什么是 markdown-it 呢?其实它是一个 markdown 的解析库,它能解析 markdown 文档,并将其渲染为 HTML 文档,官方 Demo 如下:

    VuePress源码阅读(三) -- 「成"站"之日」markdown建站分析篇 | 七日打卡

    其用法简单来说就是使用一组配置来获取 markdown-it 提供的对象,这一步就是刚刚 markdown-it-chain 做的事情,然后用这个对象调用 render 即可~ 详细用法可见 markdown-it.github.io/markdown-it…

    现在我们就已经找到了编译 markdown 文件的库了,接下来回头看看后续流程中是如何使用获得的 markdown-it 对象的.

    二. markdown-it 对象的使用

    回忆前面对于 VuePress dev 和 build 流程的分析(文章:VuePress源码阅读(二)--dev和build的执行流程分析),在 dev 和 build 的 process 函数中都会经历一个构建 Webpack 配置的阶段 prepareWebpackConfig,但是 dev 和 build 的 webpack 构建流程略有不同(左侧为 dev ,右侧为 build):

    VuePress源码阅读(三) -- 「成"站"之日」markdown建站分析篇 | 七日打卡

    可以看到相同的是都调用了 "createClientConfig(即「客户端配置构建」)",不同的是:

    • dev 多了三个插件的引用
    • build 多了一个"createServerConfig(即「服务器配置构建」)",用于生成服务端渲染程序

    无论是 createClientConfig还是createServerConfig 内部都调用了 createBaseConfig(即「基础配置构建」),之所以能够通过一个对象config来控制Webpack的配置,就是因为 config 对象是在 createBaseConfig 中通过 webpack-chain 构建,这是一个通过链式 API 来构建 webpack 配置的库,其生产的 config 对象就跟项目中的 webpack.config.js 一致,所以也可以把上面的 base、client、server 和平日的 webpack 配置文件联系起来~

    createBaseConfig 全流程比较长就不截图了,大概就是把平时 webpack.config.js 中的配置写了一遍,这里只截一下在一堆 loader 中的 markdown-loader 的配置,这里显示它接收 .md 后缀文件然后使用 markdown-loader 处理:

    VuePress源码阅读(三) -- 「成"站"之日」markdown建站分析篇 | 七日打卡

    这个 markdown-loader 也是 @vuepress 自带的,我们在里面找到了使用 markdown-it 对象调用 render函数生成 html 的代码:

    VuePress源码阅读(三) -- 「成"站"之日」markdown建站分析篇 | 七日打卡

    ok,这样 markdown 文件"成站"的整个流程已经打通了~


    起源地下载网 » VuePress源码阅读(三) -- 「成"站"之日」markdown建站分析篇 | 七日打卡

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元