【Markdown】CSDN 的 Markdown 编辑器锚点使用-进阶篇

1. 原始 Markdown 代码

1.1 “目录”元素

@[TOC](8.6 InnoDB ClusterSet 的状态和拓扑)

1.2 “1号标题-1”元素

# InnoDB ClusterSet 状态

1.3 “1号标题-2”元素

<h1>
<a id="innodb-clusterset-topology">InnoDB ClusterSet 拓扑</a>
</h1>

1.4 “1号标题-3”元素

# <a id="mysql-router-status">InnoDB ClusterSet 的 MySQL Router 状态</a>

1.5 独立 <a> 标签

<a id="standalone"></a>

1.6 跳转到独立 <a> 标签

[跳转到自定义 `<a>` 标签](#standalone)

2. 显示效果

存在两个缺陷:

  1. 目录少了一个标题,@TOC并未识别到自定义的 HTML 标签 <h1> 标题。
  2. 点击 “InnoDB ClusterSet 的 MySQL Router 状态” 无法跳转到对应标题,而点击 “InnoDB ClusterSet 状态” 则可以跳转到对应标题。后文会说明原因。

2.1 “目录”显示效果

在这里插入图片描述

2.2 “1号标题-1”元素

在这里插入图片描述

2.3 “1号标题-2”元素

在这里插入图片描述

2.4 “1号标题-3”元素

在这里插入图片描述

2.5 跳转到独立 <a> 标签

在这里插入图片描述

在这里插入图片描述

3. F12 开发工具查看 HTML 代码

3.1 “目录”元素

由以下代码可以看出,CSDN 的 Markdown 编辑器自动生成了一个 div 元素 toc ,内部包含一个无序列表,无序列表内却只包含两个定义的标题元素,少了一个我用 <h1> 标签自定义的标题。

<div class="toc">
 <h3><a name="t0"></a>8.6 InnoDB ClusterSet 的状态和拓扑</h3>
 <ul>
 <li>
 <a href="#InnoDB_ClusterSet__2" target="_self">InnoDB ClusterSet 状态</a>
 </li>
 <li>
 <a href="#a_idmysqlrouterstatusInnoDB_ClusterSet__MySQL_Router_a_262" target="_self"></a>
 <a id="mysql-router-status">InnoDB ClusterSet 的 MySQL Router 状态</a>
 </li>
 </ul>
</div>

3.2 “1号标题-1”元素

使用 Markdown 语法 # 标题 生成的标题,对应的自动生成的 HTML 代码为:

<h1>
<a name="t1"></a>
<a id="InnoDB_ClusterSet__2"></a>InnoDB ClusterSet 状态</h1>

在“目录”上右键查看“1号标题-1”元素的链接,为 https://blog.csdn.net/wudi53433927/article/details/128761806#InnoDB_ClusterSet__2 ,即自动生成的 id 。
在这里插入图片描述

3.3 “1号标题-2”元素

与前面的定义相比,多了一行代码 <a name="t2"></a>

<h1>
<a name="t2"></a> 
<a id="innodb-clusterset-topology">InnoDB ClusterSet 拓扑</a> 
</h1>

在“目录”上右键查看“1号标题-2”元素的链接,显示效果与“1号标题-1”元素不一样,证明不是链接,无法链接到该锚点。
在这里插入图片描述

3.4 “1号标题-3”元素

与前面的定义对比可知,CSDN 的 Markdown 编辑器自动生成的 HTML 多为 <h1> 标签创建了一个 <a> 标签,id="a_idmysqlrouterstatusInnoDB_ClusterSet__MySQL_Router_a_262" 的值= aid + 我定义的 <a> 标签中的 id mysql-router-status + CSDN 的 Markdown 编辑器自动生成的 HTML 规则定义的 id InnoDB_ClusterSet__MySQL_Router_a_262

<h1>
<a name="t3"></a>
<a id="a_idmysqlrouterstatusInnoDB_ClusterSet__MySQL_Router_a_262"></a>
<a id="mysql-router-status">InnoDB ClusterSet 的 MySQL Router 状态</a>
</h1>

3.5 独立 <a> 标签

<p>
<a id="standalone"></a>
</p>

1.6 跳转到独立 <a> 标签

<p>
<a href="#standalone">跳转到自定义 <code>&lt;a&gt;</code> 标签</a>
</p> 

总结

由此可知,在使用 CSDN 的 Markdown 编辑器时,如果想同时实现目录功能,与页内、页外跳转到标题的功能,可以选择:

  1. 先试用目录代码 TOC 生成目录,然后:
    • 使用CSDN 的 Markdown 编辑器自动生成的锚点的名称访问,这个最便捷,只需要使用 #t1#t2#t3 的方式访问标题1、2、3即可。但 HTML5 的 <a> 标签已经不支持 name 属性了。
    • 查看 CSDN 的 Markdown 编辑器自动生成的锚点 id ,然后使用该锚点 id 访问;
  2. 自定义 HTML 目录元素和标题元素,需调试,与CSDN 的 Markdown 编辑器自动生成 HTML 代码规则适配。

并且,将目录代码 TOC 与 使用 <a># 定义的标题一起使用时,会破坏 TOC 原本的功能,而且无法通过页内、页外跳转到该标题。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

独上西楼影三人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值