博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
使用 Gatsby.js 搭建静态博客 7 文章目录
阅读量:5986 次
发布时间:2019-06-20

本文共 2430 字,大约阅读时间需要 8 分钟。

原文链接:

前面说过基本功能已经添加完了,但是生成目录依然是我 TODO 的头号问题。今天终于把这个问题解决了,本来以为要自己解释 md 文件,没想到自带的插件就有这个功能我却没发现。

生成目录

获取目录数据

生成目录首先要获取目录数据,此功能由插件 gatsby-transformer-remark 提供,请务必先安装。

安装后在你需要获取目录的页面的 graphQL 查询代码中添加 tableOfContentstableOfContents 后面的 pathToSlugField 用于生成锚点链接地址,默认值为当前文章的 slug。在例子中就把地址的前缀改成 md 文件提供的 path 了。这个位置就看你本来的地址怎么配置,如果本来就是 slug 则不用修改,直接写 tableOfContents 不用后面括号的部分。(不过我在实践中发现改了之后地址也不会变,原因未明,谷歌也搜索不到类似的情况)

{    markdownRemark(fields: { slug: { eq: $slug } }) {      id      excerpt      html      tableOfContents(pathToSlugField: "frontmatter.path")      frontmatter {        title        tags        date(formatString: "MMMM DD, YYYY")      }    }  }

接着你就能得到像这样的目录字符串:

"
"

参考链接:

注入锚点

你可能觉得上面的字符串塞到网页就大功告成……嗯我当时也这么想。

现在你即使有这么一个带 url 的目录,点击缺不会跳转到对应位置。因为 markdown 转换到 html 之后并没有注入锚点。为解决这个问题要引入一个新插件 gatsby-remark-autolink-headers。

npm install --save gatsby-remark-autolink-headers

安装后进行如下配置

// In your gatsby-config.jsmodule.exports = {  plugins: [    {      resolve: `gatsby-transformer-remark`,      options: {        plugins: [`gatsby-remark-autolink-headers`],      },    },  ],}

如果是看过之前的教程的话一定知道我的事例项目用了 prismjs,prismjs 插件与 autolink 有迷之冲突,一定要把 autolink 放前,prismjs 放后:

// good{  resolve: `gatsby-transformer-remark`,  options: {    plugins: [      `gatsby-remark-autolink-headers`,      `gatsby-remark-prismjs`,    ],  },}// bad{  resolve: `gatsby-transformer-remark`,  options: {    plugins: [      `gatsby-remark-prismjs`, // should be placed after `gatsby-remark-autolink-headers`      `gatsby-remark-autolink-headers`,    ],  },}

添加成功后由 md 文件转换得到的 html 字符串里的标题就会都带上 id,这样锚链接就能正常使用啦!

参考链接:

调整样式

以下是我的样式代码,因为框架的全局样式对 ul 和 li 的影响挺大的,所以不少代码是用于修复的。另外是用媒体查询在大屏时把目录固定到左下角。

.css-toc {  color: $titleColor;  padding: 15px;  background: #fcfaf2;  margin-bottom: 25px;  > ul {    padding-left: 16px;  }  ul {    list-style-type: square;    list-style-position: outside;    margin-bottom: 0;    p {      vertical-align: top;      display: inline-block;    }  }  li {    margin-bottom: 0;  }  li > p {    margin-bottom: 0;  }  li > ul {    margin-top: 0;  }}@media screen and (min-width: 1045px) {  .css-toc {    position: fixed;    bottom: 0;    right: 0;    width: 200px;    max-height: 400px;    overflow: scroll;    font-size: 14px;    li > ul {      margin-left: 1rem;    }  }}

完成效果图

图片描述

转载地址:http://xtylx.baihongyu.com/

你可能感兴趣的文章
64位linux下的gns3网络模拟器配置
查看>>
让VMware ESX中的虚拟机随esx开机自动启动
查看>>
Electron Cash钱包存BCH教程
查看>>
自定义key解决zabbix端口监听取值不准确的问题
查看>>
入门级----黑盒测试、白盒测试、手工测试、自动化测试、探索性测试、单元测试、性能测试、数据库性能、压力测试、安全性测试、SQL注入、缓冲区溢出、环境测试...
查看>>
composer 安装 ubuntu 12.04
查看>>
微服务(二)hystrix
查看>>
Performing a thread dump in Linux or Windows--reference
查看>>
推荐系统中常用算法 以及优点缺点对比
查看>>
cocos2d-x v3.2环境配置(现在3.x版本号可以配置该)
查看>>
Go语言标准库之JSON编解码
查看>>
winpcap 发送数据包
查看>>
linux上架设l2tp+ipsec ***服务器
查看>>
可能是最简单的面向对象入门教程(二)为什么要有类型
查看>>
js常用的函数库
查看>>
Sqlserver 数据库安全
查看>>
netstat命令简单使用
查看>>
Python标示符命名规则
查看>>
SSL certificate problem unable to get local issuer certificate解决办法
查看>>
node.js中使用http模块创建服务器和客户端
查看>>