MarkDown教程记录

news2025/1/16 15:48:04

什么是 Markdown?

  1. Markdown 是一款轻量级标记语言,不同于HTML (Hypertext Markup Language)Markdown 的语法非常简单,且容易上手
  2. Markdown纯文本格式 编写文档,依赖键盘而非鼠标,专注于写作本身,感受书写的魅力
  3. Markdown 的通过添加一些简单的 标识符,让文本具有恰到好处的格式
  4. Markdown 核心特征就是 删繁剪芜简扼 + 精炼
  5. Markdown笔记网页文章 的最佳载体
  6. Down 的核心:坐 来,就能把思维写
    • 牛津高阶英汉双解词典第九版 中,关于 down 的释义:

在这里插入图片描述


为什么要使用 Markdown?

有朋友问我 ,Markdown 的效果 用Word 完全可以复现,甚至功能更多,那为何要用 Markdown 呢?

答:

  • 功能多,不一定是好事
    • 功能一多,选择就会变多,然后你会开始纠结……
      • 这个字号是不是该大一点呢?
      • 这个颜色好像有点不太搭呢?
      • 这个粗体,是不是该再加点颜色呢?
      • 这个图片的位置看起来有点不大对劲呢?
    • 结果,写了半天,就憋出一点点东西
      • 写出来的内容…好像…也不咋滴

MD的优势:

  1. Markdown 让我们免于 被繁杂臃肿的功能晃花了眼 的困扰
  2. Markdown 让我们回归内容本身,拥抱笔记的内核,而非浮于表象的样式,写出高效精练的笔记!

Markdown 写东西,记住一个原则

能用10个字搞定的,绝不用11个字

经常使用 Markdown 书写的朋友,也许会有一种奇妙的感触

  • 书写,会倒逼思维的跃进。像是有东西拽着你的思绪往前冲
    • 倒逼:逆向逼迫,反向推动

关于标识符的滥用

这个其实是写在最后的,之所以放在这里,是因为它很重要

如果你有一定的MD语法基础,可以直接[[#19 避免标识符的滥用|点击跳转]]


Markdown 相关软件推荐

  • Markdown 书写软件 推荐:Typora 优秀的 MD网页文章 书写软件
    • 点击跳转下载地址
      • 提示以前是免费的,现在收费了,不过是买断制
  • Markdown 笔记软件 推荐:Obsidian 银河系最强 MD+双向链 笔记软件
    • 点击跳转下载地址



Markdown 语法

  • 提示1: 本教程推荐使用 Obsidian 打开阅读
  • 提示2: 下文提到的所有标识符都是 英文状态

1. 标题&目录


1.1 标题

  • Markdown标题共有 六级,和 HTML 一样
  • 区分 一级标题 → 六级标题
    • 标题 的格式:
      • # × 标题级数 + 空格 + 文本内容
这是一段普通的文本

# 这是一级标题
## 这是二级标题
### 这是三级标题
#### 这是四级标题
##### 这是五级标题
###### 这是六级标题 

1.2 目录

  • 目录的 格式:
    • 在文档的顶部 输入 [toc] ,会根据 标题 自动生成目录 ( Table of Content )
  • 不是所有 MD编辑器 都支持目录生成
    • Obsidian 就不支持,不过 OB 是自带大纲的,就是目录的效果
输入下方内容会生成一个目录:

@[toc]



2. 斜体&粗体


2.1 斜体

  • 斜体 的格式:
    1. * + 文本内容 + *
    2. _ + 文本内容 + _ ( 下划线 )
  • 说明:
    • 斜体文本,首尾只有 单个 标识符
这是一段普通文本

*这里是一段斜体文本*
_这也是一段斜体文本_
示范

这是一段普通文本

这里是一段斜体文本
这也是一段斜体文本


2.2 粗体

  • 粗体 的格式:

    1. ** + 文本内容 + **
    2. __ + 文本内容 + __ (这里是两个 _ )
  • 说明:

    • 粗体文本,首尾各有 两个 标识符
这是一段普通文本

**这里是一段加粗文本**
__这也是一段加粗文本__
示范

这是一段普通文本

这里是一段加粗文本
这也是一段加粗文本


2.3 粗斜体 (斜粗体)

  • 粗斜体 的格式:

    1. *** + 文本内容 + ***
    2. ___ + 文本内容 + ___ ( 这里是3个 _ )
    3. **_ + 文本内容 + _**
    4. __* + 文本内容 + *__
    5. *__ + 文本内容 + __*
    6. _** + 文本内容 + **_
  • 说明:

    • 粗斜体文本,首尾各有 三个 标识符
这是一段普通文本

***粗斜体文本1***
___粗斜体文本2___
**_粗斜体文本3_**
__*粗斜体文本4*__
*__粗斜体文本5__*
_**粗斜体文本6**_
示范

这是一段普通文本

粗斜体文本1
粗斜体文本2
粗斜体文本3
粗斜体文本4
粗斜体文本5
粗斜体文本6


2.4 斜体包含粗体

  • 斜体中包含粗体 的格式:

    1. * + 斜体文本 + ** + 粗体文本 + ** + 斜体文本 + *
    2. _ + 斜体文本 + __ + 粗体文本 + __ + 斜体文本 + _ ( 这里是两个 _ )
    3. * + 斜体文本 + __ + 粗体文本 + __ + 斜体文本 + *
    4. _ + 斜体文本 + ** + 粗体文本 + ** + 斜体文本 + _
  • 说明:

    • 斜体 中包含 粗体,其实就是嵌套的关系,外层斜体内层粗体
    • 外层是斜体,标识符是单个;内层是粗体,标识符是两个
    • 因为 粗体 是被包裹在 斜体 中的,所以显示效果为 斜粗体
这是一段普通文本

*这里是一段斜体中**包含粗体**的文字*
_这也是一段斜体中**包含粗体**的文字_
*这又是一段斜体中__包含粗体__的文字*
_这还是一段斜体中**包含粗体**的文字_
示范

这是一段普通文本

这里是一段斜体中包含粗体的文字
这也是一段斜体中包含粗体的文字
这又是一段斜体中__包含粗体__的文字
这还是一段斜体中包含粗体的文字


2.5 粗体包含斜体

  • 粗体中包含斜体 的格式:
    1. ** + 粗体文本 + * + 斜体文本 + * + 粗体文本 + **
    2. __ + 粗体文本 + _ + 斜体文本 + _ + 粗体文本 + __ ( 这里是两个 _ )
    3. ** + 粗体文本 + _ + 斜体文本 + _ + 粗体文本 + **
    4. __ + 粗体文本 + * + 斜体文本 + * + 粗体文本 + __
  • 说明:
    • 粗体 中包含 斜体,也就是嵌套的关系,外层粗体内层斜体
    • 外层是粗体,标识符是两个;内层是斜体,标识符是单个
    • 因为 斜体 是被包裹在 粗体 中的,所以显示效果为 粗斜体
这是一段普通文本

**这里是一段粗体中*包含斜体*的文字**
__这也是一段粗体中_包含斜体_的文字__
**这又是一段粗体中_包含斜体_的文字**
__这还是一段粗体中*包含斜体*的文字__
示范

这是一段普通文本

这里是一段粗体中包含斜体的文字
这也是一段粗体中_包含斜体_的文字
这又是一段粗体中_包含斜体_的文字
这还是一段粗体中包含斜体的文字



3. 线


3.1 水平分割线

  • 水平分割线由至少 3*- 组成
下面是一条水平分割线:
---
***
示范



3.2 文本删除线

  • 删除线 的格式:
    • ~~ + 文本内容 +~~ 首尾各加两个 ~ 波浪号
~~这是一段加了删除线的文本~~
示范

这是一段加了删除线的文本


3.3 文本下划线

  • 下划线的格式,和 HTML 是一样的
    • <u> + 文本内容 + </u>
<u>这是一段加了下划线的文本</u>
示范

这是一段加了下划线的文本



4. 列表&引用


4.1 有序列表

  • 有序列表 的格式:

    • 1. + 空格 + 文本内容
  • 说明:

    • 输入文本内容后,敲击 Enter 自动补全格式,并进入 下个 有序列表
    • 若需要在同个列表内,增加 换行显示 的内容 (但不进入下个列表)
      敲击 Shift + Enter ,即可另起一行输入文本
    • 在有序列表的中间,插入一个新的列表,后面列表的 数字序号 会自动 递进 一层
    • 即便在源代码模式中修改了数字序号,渲染界面依然是 依照顺序 显示的
1. 这是第一个有序列表 <!-- (Enter) -->
2. 这是第二个有序列表 <!-- (Enter) -->
3. 这是第三个有序列表 


1. 这是第一个有序列表 <!-- (Shift + Enter) -->
   这是同个列表下,另起一行的文本内容 <!-- (Enter) -->
2. 这是第二个有序列表 <!-- (Shift + Enter) -->
   这是同个列表下,另起一行的文本内容 
示范
  1. 这是第一个有序列表

  2. 这是第二个有序列表

  3. 这是第三个有序列表

  4. 这是第一个有序列表
    这是同个列表下,另起一行的文本内容

  5. 这是第二个有序列表
    这是同个列表下,另起一行的文本内容

补充
  • 由于有序列表存在强制排序性,它的数字序号必然是逐一递进
    若你希望内容前的数字,不依照递进顺序排序,或者以 整百整十数 排序
  • 可以配合无序列表,在无序列表中输入:
    • 数字 + . + 内容
      注意 点号 与 内容 之间,没有空格 (其实有空格也行,就是会感觉有点奇怪)
- 10.这是无序列表下,整十数排列的内容
- 20.这是无序列表下,整十数排列的内容
- 30.这是无序列表下,整十数排列的内容


- 100.这是无序列表下,整百数排列的内容
- 200.这是无序列表下,整百数排列的内容
- 300.这是无序列表下,整百数排列的内容

效果:

  • 10.这是无序列表下,整十数排列的内容
  • 20.这是无序列表下,整十数排列的内容
  • 30.这是无序列表下,整十数排列的内容

  • 100.这是无序列表下,整百数排列的内容
  • 200.这是无序列表下,整百数排列的内容
  • 300.这是无序列表下,整百数排列的内容

4.2 无序列表

  • 无序列表 的格式:
  • - + 空格 + 文本内容
  • 说明:
    • 输入文本内容后,敲击 Enter 自动补全格式,并进入 下个 无序列表
    • 若需要在同个列表内,增加换行显示的内容 (但不进入下个列表)
      敲击 Shift + Enter ,即可另起一行输入文本
  • 补充:
    • Obsidian中,按下 Ctrl + Enter
    • 即可快速生成一个无序列表
- 这是第1个无序列表 <!-- (Enter) -->
- 这是第2个无序列表 <!-- (Enter) -->
- 这是第3个无序列表

- 这是第一个无序列表 <!-- (Shift + Enter) -->
  这是同个列表下,另起一行的文本内容
- 这是第二个无序列表 <!-- (Shift + Enter) -->
  这是同个列表下,另起一行的文本内容 
示范
  • 这是第1个无序列表
  • 这是第2个无序列表
  • 这是第3个无序列表

  • 这是第一个无序列表
    这是同个列表下,另起一行的文本内容
  • 这是第二个无序列表
    这是同个列表下,另起一行的文本内容

4.3 引用

  • 引用 的格式:
    • > + 文本内容 (不需要空格)
  • 说明:
    • 同个引用段落内的换行直接敲击 Enter 即可
    • 若需添加 第二个独立引用段落 ,连续敲击 两下 Enter 即可
>这是第一段引用文本的第1行 <!-- (Enter) -->
>这是第一段引用文本的第2行 <!-- (Enter) -->
<!-- (Enter) -->
>这是第二段引用文本的第1行 <!-- (Enter) -->
>这是第二段引用文本内第2行
示范

这是第一段引用文本的第1行
这是第一段引用文本的第2行

这是第二段引用文本的第1行
这是第二段引用文本的第2行


4.4 缩进&退格

在列表和引用的书写过程中,我们需要利用 缩进退格 ,让文章肌理分明,更具层级

  • 缩进:

    1. Tab
    2. Ctrl + [   (左中括号)
  • 退格:

    1. Shift + Tab
    2. Ctrl + ] (右中括号)

4.4.1 有序列表的缩&退
1. 第一级有序列表1 <!-- (Enter) -->
	1. 第二级有序列表1    <!-- 写文本之前,先( Tab 或 Ctrl + ] ) ;写完文本后,再(Enter) -->
	2. 第二级有序列表2 <!-- (Enter) -->
2. 第一级有序列表2    <!-- 写文本前,先 ( Shift + Tab 或 Ctrl + [ ) --> 
  • 补充说明:
    • 有序列表的数字序号,即便你在源代码模式里 强行改掉 数字,它仍然会 依照顺序 显示
示范
  1. 第一级有序列表1
    1. 第二级有序列表1
    2. 第二级有序列表2
  2. 第一级有序列表2

4.4.2 无序列表的缩&退
- 第一级无序列表1 <!-- (Enter) -->
	- 第二级无序列表1  <!-- 写文本前,先( Tab 或 Ctrl + ] ) ;写完后,再(Enter) -->
	- 第二级无序列表2 <!-- (Enter) -->
- 第一级无序列表2  <!-- 写文本前,先 ( Shift + Tab 或 Ctrl + [ ) -->
示范
  • 第一级无序列表1
    • 第二级无序列表1
    • 第二级无序列表2
  • 第一级无序列表2

4.4.3 引用的缩&退
  • 引用的 缩进 和列表 不同
    • 引用需另起一行,并额外多打一个 > 来完成 缩进
  • 引用的 退格 与列表 相同
    1. Shift + Tab
    2. Ctrl + ] (右中括号)
>第一级引用1 <!-- (enter) -->
>>第二级引用1 <!-- 先打1个 > (这里的第一个 > 是会自动补充的,只需额外增补1个即可) ,再(enter) -->
>>第二级引用2 <!-- (enter) -->
>第一级引用2   <!-- 写文本前,先 ( Shift + Tab 或 Ctrl + [ ) -->
示范

第一级引用1

第二级引用1
第二级引用2

第一级引用2


  • 补充:
    Obsidian 中,引用的退格是不太一样的
  • **Obsidian **中,如果想让已经缩进的引用 退回一层
    • 得使用 Shift + Enter ,配合方向键,在多个 > 之间灵活断行
      并在下一行 根据需要 选择性补充 >
  • 这个用文字比较难以描述,这里选择用2个带键位的 Gif图 来描述

Gif演示1:


引用退格1


  • 效果1:

111

222

333

444

555


Gif演示2:

引用退格2


  • 效果2:

111

222

333

444

555

666

777


4.4.4 有序&无序&引用 连续套娃
  • 有序列表无序列表引用 三者之间,可以相互嵌套
  • 核心键Shift + Enter & Enter & Shift + Tab ( 或 Ctrl + [ )
    • Shift + Enter 在切换格式的嵌套中,是 自带一层 缩进 效果的
1. 第一级 有序列表1 <!-- (Shift + Enter) --> 
	- 第二级 无序列表1 <!-- (Shift + Enter) -->
		>第三级 引用1  <!-- (Enter) -->
			- 第四级 无序列表2 <!-- (Shift + Enter) -->
            	1. 第五级 有序列表2 <!-- (Enter) -->
            - 第四级 无序列表3   <!-- 写文本前,先( Shift + Tab 或 Ctrl + [ ) ;写完后再 (Enter) -->
        >第三级 引用2  <!-- 写文本前,先( Shift + Tab 或 Ctrl + [ ) ;写完后再 (Enter × 2) -->
    - 第二级 无序列表4  <!-- 写文本前,先( Shift + Tab 或 Ctrl + [ ) -->
2. 第一级 有序列表3  <!-- 写文本前,先( Shift + Tab 或 Ctrl + [ ) -->
示范
  1. 第一级 有序列表1

    • 第二级 无序列表1

      第三级 引用1

      • 第四级 无序列表2
        1. 第五级 有序列表2
      • 第四级 无序列表3

      第三级 引用2

    • 第二级 无序列表4

  2. 第一级 有序列表3

4.4.5 Obsidian 的一些缩退问题
  • Obsidian 在列表首行使用缩进的时候,后续的列表会出现一些问题
    • TabShift + tab 会无法 缩进 退格
      • 可以使用 Ctrl + ]Ctrl + [ 来解决问题
- - 这是第一段就被缩进的列表
	- 这是第二段被再次缩进的列表  <!-- 这里需按两次 Ctrl + ] ,Tab键是无效的 -->
  - 这是第三段列表  <!-- Ctrl + [ -->
    • 这是第一段就被缩进的列表
      - 这是第二段被再次缩进的列表
      • 这是第三段列表



5. 网页链接与图像


5.1 网页链接

  • 网页链接的 格式:
    • [ + 显示文本内容 + ] + ( + 链接地址 + 空格 + " + 提示信息文本 + " + )
  • 说明:
    • 显示文本内容,是在渲染界面实际 可见 的文本,用以 说明 链接
    • 提示信息文本,需鼠标悬停于 显示文本内容 方可触发,用于增加额外提示信息
      • 注意 "提示信息文本"可选项,一般不会填
      • 一般来讲,需按住 Ctrl + 鼠标左键点击 才可跳转链接,不过也有 直接鼠标点击 就能跳转的
[显示文本内容](链接地址 "提示信息文本")

[百度一下,你就知道](http://www.baidu.com "按住Ctrl点击跳转百度")

示范:

百度一下,你就知道


5.1.1链接的加粗
  • 格式有两种:
    1. 把一对 ** 加在 显示文本内容的首尾
      • 格式1:[**显示文本内容**](链接地址)
      • 效果: 百度一下,你就知道
    2. 把一对 ** 加在 链接格式整体 的首尾
      • 格式2:**[显示文本内容](链接地址)**
      • 效果: 百度一下,你就知道



5.2 图像

  • 图像格式:
    • 图像格式,就是在网页链接前面加个 ! (英文格式的),! 代表 可见
    • 图片的提示信息,和网页链接一样,写在 " "
    • [ ] 方括号里的文字信息在 Markdown 没啥实质的作用,只是方便在源代码模式下,知道这个图片是什么,在渲染界面是不会显示的。有点类似于HTML img标签 里的 alt属性
![文字信息](图片链接 "提示文本信息")	

![湘湖1](https://z3.ax1x.com/2021/08/06/fuNkXq.jpg "湘湖一角")
  • 补充:

    • 图像链接可以是本地的,也可以是在线
      • 本地图像直接 Ctrl + C 黏贴,Ctrl + V 复制 就可以
      • 在线图像推荐使用 图床
    • 调整图像的大小需要使用 HTML 和 CSS,在 Typora编辑器 中右键可以直接缩放图片
      本质是转成了HTML的格式,最后会有一个 style="zoom: %;" ,这里数值可以自己修改
    • 如果有使用 Obsidian 的朋友,在线图片链接是通用的。不过,因为 Obsidian 是双向链笔记
      它的本地图片格式不太一样
      • ![[图片名]]
        • Obsidian 中的图片是以双链的格式引用在目标笔记中,用 ! 使它可见
        • Obsidian的图片设置大小是用 | 分隔,后面写宽度数值,单位是px。
          设定好宽度,高度会自动等比例调整
          • ![[图片名|宽度数值]]
            - 若想自主调整图片宽高,则用:
            - ![[图片名|宽度数值x高度数值]]
            - 提示这里的 x 是 英文字母x
      • 如果是在线图床,需要调整图片大小:
        • ![图床|宽度数值](链接地址)
示范

在这里插入图片描述



6. 表格

  • Markdown的表格,比HTML简单很多
    • | 是构成表格的主要 框架
    • - 区分 表头表格主体
    • : 控制 表格内 文本内容对齐方式
    • **Typora编辑器中 ** 输入 Ctrl + T 即可快速插入表格,自由定义样式
|这里是表头1|这里是表头2|这里是表头3|
|:-|:-:|-:|    <!--区分表头和表格主体,:代表文本对齐方式,分别是左对齐,居中对齐,右对齐-->
|单元格数据1|单元格数据2|单元格数据3|
|单元格数据4|单元格数据5|单元格数据6|
示范
这里是表头1这里是表头2这里是表头3
单元格数据1单元格数据2单元格数据3
单元格数据4单元格数据5单元格数据6

6.1 表格中文本内容的换行

  • Mardown中表格,它的宽高是由 单元格数据内的文本内容 撑开
  • 当我们输入一段很长很长的文本,它所在的单元格会变得过宽

如下图所示:

表头1表头2
这是一段很长很长很长很长很长很长很长很长很长很长很长很长很长很长的文本普通文本
  • 若想对一段长文本进行换行,可以在 中间 插入一个 <br> ( 换行标签 )
| 表头1 |  表头2 |
|:-:|:-:|
|这是第一行文本<br>这是另起一行的文本|普通文本|
示范
表头1表头2
这是第一行文本
这是另起一行的文本
普通文本



7. 代码域


7.1 行内代码

  • 行内代码 的格式:
    • 输入两个 ` 反引号 ,在中间写代码内容
  • 补充:
    • 行内代码不一定非得写代码,也可以作为**着重标记**,突出显示内容
    • 行内代码中,源代码界面和渲染界面是完全一致的,标识符会失效
    • 所谓行内代码: 只要你的屏幕足够宽,它就不会换行
`这是一段行内代码`

`<table border="1" cellspacing="0" width="500" height="500">`

`print("Hello, World!")`

`这是一行突出显示的文本内容`
示范

<table border="1" cellspacing="0" width="500" height="500">


print("Hello, World!")


这是一行突出显示的文本内容


7.2 代码块

  • 代码块 的格式:
    1. 在首行和末行各加 三个 ` 反引号
    • `````** + 语言种类 代码内容 ** `````
    1. 在首行和末行各加 三个 ~ 波浪号
      • ~~~ + 语言种类
        代码内容
        ~~~
  • 补充:
    • 在代码块也不一定要写代码,可以写一段突出的文本内容,语言类型可以填写 txt 或者 干脆不写
    • 代码块中,源代码界面和渲染界面是完全一致的,标识符会失效
    • Typora编辑器 ,用键盘按键脱离代码块区域,需输入: Ctrl + Enter
```语言种类
代码内容
代码内容
代码内容
```

下面是HTML代码块

```html
<table border="1">
    <tr>
        <td>row 1, cell 1</td>
        <td>row 1, cell 2</td>
    </tr>
    <tr>
        <td>row 2, cell 1</td>
        <td>row 2, cell 2</td>
    </tr>
</table>
```

下面是CSS代码块

```css
.box {
	width: 600px;
	height: 400px;
	margin: 100px auto;
	background-image: linear-gradient(black 33.3%,red 33.3%, red 66.6%, yellow 66.6%, yellow);
}	
```

下面是JavaScript代码块

```js
    // 定义一个30个整数的数组,按顺序分别赋予从2开始的偶数;然后按顺序每五个数求出一个平均值,放在另一个数组中并输出。试编程
    let arr = [2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 32, 34, 36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56, 58, 60]
    let newarr = [];
    for (let i = 0, count = 0, sum = 0, len = arr.length; i < len; i++) {
        sum += arr.shift();
        count++;
        if (count % 5 === 0) {
            newarr.push(sum / 5);
            sum =  0;
        }
    }
    console.log(newarr);

    let arr = [2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 32, 34, 36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56, 58, 60]
    let newarr = [];
    for (let i = 0, len = arr.length; i < len / 5; i++) {
        let subarr = arr.splice(0, 5)
        for (let j = 0, sum = 0; j < subarr.length; j++) {
            sum += subarr[j];
        }
        newarr.push(sum / 5);
    }
    console.log(newarr);
```


下面是Python代码块

```python
#!/usr/bin/python
# -*- coding: UTF-8 -*-

i = 2
while(i < 100):
   j = 2
   while(j <= (i/j)):
      if not(i%j): break
      j = j + 1
   if (j > i/j) : print i, " 是素数"
   i = i + 1
 
print "Good bye!"
```

下面是一块突出显示的文本

```txt
这是一段
突出显示的
文本内容
```
示范
<table border="1">
    <tr>
        <td>row 1, cell 1</td>
        <td>row 1, cell 2</td>
    </tr>
    <tr>
        <td>row 2, cell 1</td>
        <td>row 2, cell 2</td>
    </tr>
</table>
.box {
	width: 600px;
	height: 400px;
	margin: 100px auto;
	background-image: linear-gradient(black 33.3%, red 33.3%, red 66.6%, yellow 66.6%, yellow);
}	
// 定义一个30个整数的数组,按顺序分别赋予从2开始的偶数;然后按顺序每五个数求出一个平均值,放在另一个数组中并输出。试编程
let arr = [2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 32, 34, 36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56, 58, 60]
let newarr = [];
for (let i = 0, count = 0, sum = 0, len = arr.length; i < len; i++) {
	sum += arr.shift();
	count++;
	if (count % 5 === 0) {
		newarr.push(sum / 5);
		sum =  0;
	}
}
console.log(newarr);

let arr = [2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 32, 34, 36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56, 58, 60]
let newarr = [];
for (let i = 0, len = arr.length; i < len / 5; i++) {
	let subarr = arr.splice(0, 5)
	for (let j = 0, sum = 0; j < subarr.length; j++) {
		sum += subarr[j];
	}
	newarr.push(sum / 5);
}
console.log(newarr);
#!/usr/bin/python
# -*- coding: UTF-8 -*-

i = 2
while(i < 100):
   j = 2
   while(j <= (i/j)):
      if not(i%j): break
      j = j + 1
   if (j > i/j) : print i, " 是素数"
   i = i + 1
 
print "Good bye!"
这是一段
突出显示的
文本内容

7.2.1 代码块的嵌套

格式:

  • 使用4` 包裹 3`
示范
````txt
```js
// 3. 输出 100以内(不包括100) 所有偶数的和
// 这类求和问题的核心 : 利用循环  (总和 = 旧数的和 + 新数)

let sum = 0;

for (let i = 1, sum = 0; i < 100; i++) {
 if (i % 2 == 0) {
 // 筛选偶数
 sum += i; // sum = sum + i // 累加偶数并赋值给sum
 // sum为(旧的,已经进入循环的数)的和,i 为新进入循环的数。当加到(最后一个新数i)时,sum就是最后的 总和
 }
}

console.log(sum); // 打印总和
```
````

如果要再套一层,就在最外层 加 5` ,以此类推……


7.3 如何在行内代码里显示反引号

首尾各用 两个反引号`+ 空格 包裹

格式:

``+空格+带`的内容+空格+``  <!-- 不要忘记前后的两个空格 -->

`` 这是一段能显示`反引号`的行内代码 ``

效果:

这是一段能显示`反引号`的行内代码



8. 任务列表(待办)

  • 任务列表 的格式:

    • - + 空格 +[ ] +空格 + 任务列表内容 ( 中括号[ ] 里面必须有个空格)
    • 给待办任务列表打 ,变成 已办
      1. 在渲染界面,直接鼠标左键点击框框
      2. 在源代码界面,在中括号内输入 英文字母x
        • 部分编辑器,在 中括号内 输入任意字符都可以打 ( 例如 Obsidian )
  • 补充:

    • 大部分 MD编辑器 支持输入第一个任务列表后,按下 Enter 进入下一行会 自动补全待办格式
    • Obsidian中,连续输入两次 Ctrl + Enter ,即可生成一个待办列表
      • 再输入一次 Ctrl + Enter ,会在待办列表 打
  • 格式:

- [ ] 待办任务列表1
- [ ] 待办任务列表2
- [x] 已办任务列表1    <!-- 英文字母X -->
- [x] 已办任务列表2

示范

  • 待办任务列表1
  • 待办任务列表2
  • 已办任务列表1
  • 已办任务列表2

  • Obsidian 中,可以利用 Ctrl + Enter ,快速生成任务列表
    1. - + 空格 + Ctrl + Enter +待办文本内容
    2. 待办文本内容 + Ctrl + Enter ×2   ( 输入文本后,连续2次 Ctrl + enter )

  • 任务列表也是可以缩进+退格的,操作跟 无序、有序列表一样

示范

  • 第一级待办列表1
    • 第二级待办列表1
      另起一行的第二级待办列表1
      • 第三级已办列表1
      • 第三级已办列表2
    • 第二级待办列表2
      另起一行的第二级待办列表2
  • 第一级待办列表2



9. 注释

Markdown注释HMTL 一样,注释的内容在 渲染界面 不可见 (部分编辑器可见)

  • 注释 的格式:
    • <!-- 这里是注释的内容 -->
      • 注释可以是单行,也可以是多行
    • 如果有在使用 Obsidian 的,它的注释格式是不一样的
      • %%这是Obsidian的注释内容%%
<!-- 这里是一行注释 -->

<!--
这里是
一段
假装有
很多行的
注释
-->

%%这是一行Obsidian里的注释%%

%%
这里是
一段
假装有
很多行的
Obsidian里的
注释
%%

示范 (只有切换至 编辑模式 才能看到喔)

%%这是一行Obsidian里的注释%%

%%
这里是
一段
假装有
很多行的
Obsidian里的
注释
%%



10. 变量


10.1 网页链接变量

  • 网页链接变量 的格式:
    1. 首先输入
      • [显示文本内容] + [变量名]
        • 变量名可以自己取,没啥限制,任意字符都可以
    2. 在文档任意一个区域,输入:
      • [变量名] + : + 空格 + 链接地址 (这个**空格** 不打也没事)
[百度一下,你就知道][度娘]
[知乎-有问题,就会有答案][知乎]

<!-- 这里是变量区域 -->
[度娘]: http://www.baidu.com 
[知乎]: https://www.zhihu.com    
示范

百度一下,你就知道

知乎-有问题,就会有答案


10.2 脚注

  • 脚注 的格式:
    • 在需要脚注的地方,输入:
      • [^脚注代号] ( 脚注代号会直接显示在渲染界面 )
        • 脚注代号可以随便命名,不过推荐使用 数字序号
    • 在其他区域,输入:
      • [^脚注代号] + : + 空格 + 脚注内容 (这个 空格 不打也没事)
鲁迅原名是什么[^1] ,浙江哪里人[^2]

<!-- 这里是变量区域 -->
[^1]: 周树人
[^2]: 绍兴人
示范

鲁迅原名是什么1,浙江哪里人2



11. 拓展文本格式标记

  • Markdown 想实现更多的文本显示效果,只能依赖HTML标记实现
  • 个人不是很推荐在 MD 中使用 HTML,不过一些简单的标记还是可以 轻度使用

11.1 键盘文本

  • 键盘文本的 格式:

    • <kbd>键盘文本</kbd>
    • <kbd>Ctrl</kbd> + <kbd>X</kbd>
  • 效果:

    • 键盘文本
    • Ctrl + X ( 剪切 )
  • 说明:

    • 键盘文本也不一定非得是键盘按键,也可以作为着重文本突出显示
      • 效果: 这也算一种着重文本的方式
11.1.1 加粗键盘文本
  • 加粗键盘文本的格式有两种

    • <kbd>**键盘文本**</kbd>
    • **<kbd>ctrl + x</kbd>**
  • 效果:

    1. 键盘文本
    2. ctrl + x

11.2 放大文本

  • 放大文本 的格式:

    • 这是一段普通文本
      <big>这是一段放大文本</big>
  • 效果:

    • 这是一段普通文本
      这是一段放大文本
11.2.1 放大粗体文本
  • 放大加粗文本的格式有两种
    1. **<big>这是一段放大粗体文本</big>**
    2. <big>**这是一段放大粗体文本**</big>
  • 效果:
    1. 这是一段放大粗体文本
    2. 这是一段放大粗体文本

11.3 缩小文本

  • 缩小文本 的格式:
    • 这是一段普通文本
      <small>这是一段缩小文本</small>
  • 效果:
    • 这是一段普通文本
      这是一段缩小文本
11.3.1 缩小斜体文本
  • 斜体缩小文本 的格式有两种
    1. <small>*这是一段缩小斜体文本*</small>
    2. *<small>这是一段缩小斜体文本</small>*
  • 效果:
    1. 这是一段缩小斜体文本
    2. 这是一段缩小斜体文本

11.4 多彩文本

  • 多彩文本 的格式:
    • <font color=orange>这是一段橘色文本</font>
  • 效果:
    • 这是一段橘色文本
      • color 里的颜色支持 英文单词,16进制,rgb,rgba

11.4.1 多彩粗体文本
  • 只需要在上面示例的基础上,加上 加粗标识符,有两种格式:
    1. 格式1: **<font color=teal>这是一段加粗的水鸭色文本</font>**
      • 效果: 这是一段加粗的水鸭色文本
    2. 格式2: <font color=teal>**这是一段加粗的水鸭色文本**</font>
      • 效果: 这是一段加粗的水鸭色文本
  • 若上述混搭方法的样式失效 ,可以使用 纯HTML标记
    • 格式: <strong style="color:teal;">这是一段加粗的水鸭色文本</strong> (标记略复杂,不是很推荐)
    • 效果: 这是一段加粗的水鸭色文本

11.4.2 多彩斜体文本
  • 跟多彩加粗文本完全一样,只需把首尾的 ** 换成 * 即可
  1. 格式1: *<font color=teal>This is an italic teal text</font>*
    • 效果: This is an italic teal text
  2. 格式2: <font color=teal>*This is an italic teal text*</font>
    • 效果: This is an italic teal text

11.4.2 多彩粗斜体文本
  • 首尾换成 ***
  1. 格式1: ***<font color=teal>This is a bold italic teal text</font>***
    • 效果: This is a bold italic teal text
  2. 格式2: <font color=teal>***This is a bold italic teal text***</font>
    • 效果: This is a bold italic teal text

注意 多彩文本尽量慎用,Markdown 的核心就是 简洁精炼,注重 实质内容,而非花哨的 颜色样式



12. 拓展文本显示效果

  • 拓展显示效果既不是原生 Markdown语法 支持的,也非 HTML标记,而是部分编辑器 提供的 额外标识符,属于拓展语法,旨在为 Markdown使用者 提供更多样式选择
  • 不同编辑器,支持不一样,这里以 Typora编辑器 为例

12.1 文本高亮

  • 文本高亮 的格式:
    • ==这里是一段高亮文本==
  • 效果:
    • 这里是一段高亮文本

12.2 上标

  • 用一对 ^ 包裹 (Shift+ 6)
    • 格式: x^2^
    • 效果: x2
  • Obsidian 没效果的,可以用后面会讲的 Latex
  • 或者,也可以使用 HTML标记
    • <sup>这里是上标内容</sup>
    • X<sup>2</sup>
  • 效果:
    • X2

12.3 下标

  • 用一对 ~ 包裹 (Shift + `)
    • 格式: H~2~O
    • 效果: H2O
  • Obsidian 没效果的,可以用后面会讲的 Latex
  • 或者,也可以使用 HTML标记
    • <sub>这里是下标内容</sub>
    • H<sub>2</sub>O
  • 效果:
    • H2O

12.4 Emoji 符号

用一对 : 包裹,里面是 Emoji 符号的 语义化文本 ( Typora编辑器 中,输入 : 就会带提示器 )

  • 示例:
    • :smile:
      :sweat:
      :cat:
      :woman_cartwheeling:
  • 效果:
    • 😄
      😓
      🐱
      🤸‍♀

  • 补充:
    • 不支持上述方式的 MD编辑器或笔记软件,直接用 输入法 输入也是可以的
    • Windows系统 用户 win + . 就可以输入 Emoji 了
    • Obsidian 用户可以安装第三方插件来支持 Emoji 的输入,推荐两个
      1. Emoji Shortcodes
      2. Emoji Toolbar



13. 转义字符

  • Markdown 中,我们 通过 标识符 改变 文本显示效果
  • 现在我们希望它不作为标识符,而是 作为字符本身呈现出来 (不具备改变文本显示效果的功能,只是一个普通字符)
    • 首先我们可以用前面介绍的 代码域 ,因为代码模式的显示效果就是源代码完全一致
    • 还有一种方法,可以利用转义字符,在这些标识符 前面 加上 反斜线 \ ( 反斜线要紧贴在标识符前面,不能空格 )
      • 原理:
        • \ 的作用是让标识符 转义 变为一个普通字符,完成这个效果后,反斜线会自动隐藏
        • 隐藏后的反斜线仅在源代码界面可见,在渲染界面不可见
        • 反斜线只争对标识符起作用,其他字符添加 \\ 不会自动隐藏
      • 补充:
        • 如果想给已经被加在标识符前面,会自动隐藏的 \ 显示出来,可以在反斜线前面再加一个 \ ,用它自己来转义自己
          • 示例: 这里紧跟在标识符前面的反斜线\\*会被转义成普通字符显示出来,不会自动隐藏,且这段文件会是斜体*
          • **效果: ** 这里紧跟在标识符前面的 反斜线\会被转义成普通字符显示出来,不会自动隐藏,且这段文件会是斜体

例1 以普通字符显示星号

  • 如何让被一对或多对 * 号 包裹的文本内容,能够正常显示 * ,且文本不改变格式
    • \*这段文本被一对星号包裹,但不会倾斜\*
      • 效果: *这段文本被1对星号包裹,但不会倾斜*
    • \*\*这段文本被2对星号包裹,但不会加粗\*\*
      • 效果: **这段文本被2对星号包裹,但不会加粗**
    • \*\*\*这段文本被3对星号包裹,但它既不倾斜也不加粗\*\*\*
      • 效果: ***这段文本被3对星号包裹,但它既不倾斜也不加粗***

例2 表格内 单元格中的竖杠

  • 在表格中,使用 | 作为单元格的内容,但不会被识别为表格的结构,不会增加额外的单元格
|表头1|表头2|
|-|-|
|这里的文本被\|分隔|这里的文本也被\|分隔|
  • 效果:
表头1表头2
这里的文本被|分隔这里的文本也被|分隔

补充该技巧可用于 Obsidian 表格 内 双链的文本修饰

文本修饰:

在 双链[[ ]]内 以 | 引导的内容

  • 格式: [[链接的内容|文本修饰]]
  • 说明: 文本修饰是渲染界面实际显示的文本,便于更好地融入语境

表格内的格式:

| 前面加上 \

  • [[表格内的链接内容\|文本修饰]]

示例:

|                  表头1                  |                        表头2                        |
|:---------------------------------------:|:---------------------------------------------------:|
| [[#例2 表格内 单元格中的竖杠\|单元格中的竖杠]] | [[#例3 不会变成代码的反引号\|不会变成代码的反引号]] |

效果:

表头1表头2
[[#例2 表格内 单元格中的竖杠|单元格中的竖杠]][[#例3 不会变成代码的反引号|不会变成代码的反引号]]

例3 不会变成代码的反引号

使用 转义符号\ 让 反引号` 变成普通字符,不再具有[[#7 1 行内代码|行内代码]]的标识符功能

格式:

\`这段被反引号包裹的内容不会变成行内代码\`

效果:

`这段被反引号包裹的内容不会变成行内代码`


例4 链接中的中括号

网页链接显示文本内容 中,使用 中括号 [ ]

  • 在显示文本内容中,在其中一个中括号前面,加上转义符号 反斜杠 \
    • 格式: [链接里的 \[中括号\] 能被正常显示](https://www.runoob.com)
    • 效果: 链接里的 [中括号] 能被正常显示

例5 不是列表的连接符(横杠)

  • 引用一段话,一般会在换行之后,加上 - 出处
  • 因为 - 是标识符,会变成一个无序列表

如下所示:

The Web, the Tree, and the String.
写作之难,在于把网状的思考,用树状结构,体现在线性展开的语句里。

  • 史蒂芬·平克
  • 解决方法:

    • - 前面加上 转义符号 \
    >The Web, the Tree, and the String.
    >写作之难,在于把网状的思考,用树状结构,体现在线性展开的语句里。
    >\- 史蒂芬·平克   <!-- 加上转义符号 \ , 不会变成无序列表 -->
    
  • 效果:

The Web, the Tree, and the String.
写作之难,在于把网状的思考,用树状结构,体现在线性展开的语句里。
- 史蒂芬·平克


例6 不是标题的 #

# 不被识别为标题标识符

格式:

\# 这里的内容不会被识别为标题

效果:

# 这里的内容不会被识别为标题


例7 不会注释的 %

Obsidian 中 注释是前后各两个 %

使用 转义符号\,让 %% 作为普通字符显示出来,不具备注释的功能

  • 格式: \%\%这里的内容可以被显示喔\%\%
  • 效果: %%这里的内容可以被显示喔%%

例8 木有链接的双链

Obsidian 的双向链格式是2个方括号 [[ ]] (双方),使用 转义符号\,让 [ ] 不再具有 双链功能

格式:

\[\[这段文本被双方包裹,但不是一个双向链\]\]

效果:

[[这段文本被双方包裹,但不是一个双向链]]


例9 页链接里 显示文本内的 中括号

使用转义符号\,让中括号可以作为显示文本 在[[#5 1 网页链接|网页链接]]中显示出来

格式:

[\[这是一个带中括号的网页链接显示文本,点击会跳转至百度\]](https://www.baidu.com/)

效果:

[这是一个带中括号的网页链接显示文本,点击会跳转至百度]


特殊情况 文本修饰的中括号

文本修饰的 中括号[ ] 不需要使用 转义符号\

示范:

[[#例8 木有链接的双链|[这是一个带中括号的文本修饰]]]

效果:

[[#例8 木有链接的双链|[这是一个带中括号的文本修饰]]]



14. 空格&换行&强制删除


14.1 空格

  • 在一些编辑器或者支持MD的笔记软件里,无论你打多少个空格,它只会显示单个 空格 的距离
    • 可以使用 HTML中 空格字符实体 —— &nbsp;
    • 若要添加 多个 空格,就输入多个 —— &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
  • 格式:
    • 这里有&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;6个空格分隔
  • 效果:
    • 这里有      6个空格分隔

14.2 换行

场景1:

  • 在一些编辑器或者支持MD的笔记软件里,无论你打多少个 回车,它只会显示单个 回车 的空行间距
    • 可以使用之前表格里提到的 <br> 标签,在 单独一行 中使用,增加额外的空行间距
    • 如果要增加 多个,就输入 多个 —— <br><br><br><br><br>
    • 注意 当单独一行使用 <br> 标签的时候,如果前后有标题标识符或者列表标识符,确保 br元素 前后两行都是空白行

格式:

这里是第一段文本

<br><br><br><br><br>     <!-- 这里插入了5个空行间距 -->

这里是第二段文本

效果:

这里是第一段文本






这里是第二段文本



场景2:

  • 在列表中也可以插入换行符
- 这是一段无序列表
  <br>     <!-- 插入一个空行间距,需单独一行,上下不用预留空格 -->
  这是同一段无序列表中,空一行距离显示的内容
- 这是第二段无序列表

效果:

  • 这里是第一段无序列表


    这里是同一段无序列表中,空一行距离显示的内容
  • 这里是第二段无序列表

  • 补充:
    • 有一些MD编辑器或笔记软件,严格遵循MD的换行规则,你敲一个回车是没法换行的,必须在 行末2个空格,再按回车键
      • 格式:
        • 这里是一段想换行的文本空格 空格 Enter
          这是换行后的文本

14.3 强制删除

  • 很多编辑器都有英文标点自动补全功能,自动生成一对,光标落在中间
    只想删除前面1个,却会把 一整对 都删掉
  • 在多个列表的嵌套中,也许会遇到一些 无法被删除列表标识符
  • 解决方法:
    使用 Shift + Backspace 即可强制删除
    • Bcakspace   ( 退格键 )



15. 嵌入

  • 嵌入都是依赖 HTML标签 实现的,嵌入的都是在线链接格式
    • 如果是本地的,Obsidian 中音频是有自带的可录制的录音机插件的,其他的 音频、视频 直接复制黏贴就可以了,也可以直接拖拽到OB的笔记界面
      • 其他的媒体文件在 Obsidian 也和图片一样,以双链的格式引用在目标笔记中,使用 ! 使它可见

15.1 嵌入音频

  • 格式:

    • <audio controls="controls" preload="none" src="音频链接地址"></audio>
  • 示例:

<audio controls="controls" preload="none" src="https://www.ldoceonline.com/media/english/exaProns/p008-001803372.mp3?version=1.2.37"></audio>
  • 效果:


15.2 嵌入视频

  • 格式:
<video width="600" height="420" controls>
  <source src="movie.mp4" type="video/mp4">
  <source src="movie.ogg" type="video/ogg">
  <source src="movie.webm" type="video/webm">  
</video>
  • 说明:
    • width ( 宽度 ) height ( 高度 ) ,可以自己设置,直接输入数字即可,单位默认是 px(像素)
      也可以使用 百分比
      width=100% 代表水平撑满整个窗口
      height=50% 代表垂直撑满半个窗口
    • Video标签 支持的视频格式 :MP4 ogg webm

15.3 嵌入页面

  • 格式: <iframe width=600 height=400 src="页面链接地址" scrolling="auto" border="0" frameborder="no" framespacing="0" allowfullscreen="true"> </iframe>
<iframe width=600 height=400 src="https://www.runoob.com/html/html-tutorial.html" scrolling="auto" border="0" frameborder="no" framespacing="0" allowfullscreen="true"> </iframe>
  • 效果:

  • iframe标签 除了嵌入页面,也可以嵌入在线视频,主流的视频网站都会提供嵌入代码

    • 具体可以看这个 iframe视频嵌入教程
    • B站 的视频,得在 // 前面补充 http:
    • 不是所有的 编辑器和笔记软件 都支持这个
  • 示例:

<iframe width=600 height=400 src="http://player.bilibili.com/player.html?aid=20190823&bvid=BV1yW411s7og&cid=32964980&page=1" scrolling="no" border="0" frameborder="no" framespacing="0" allowfullscreen="true"> </iframe>
  • 宽高设置和前面的 video 一样

  • 效果:



16. Latex 数学公式

  • 主要用于 数学公式化学公式 的书写

16.1 行内公式

  • 格式:

    • < / k b d > ∗ ∗ + 行内公式 + ∗ ∗ < k b d > </kbd>** + 行内公式 + **<kbd> </kbd>+行内公式+<kbd>

  • 示例:
    • $x^2 + 2x + 5 + \sqrt x = 0$
    • $\ce{CO2 + C -> 2 CO}$
    • $\ce{CO2 + C -> 2 CO}$
    • $\ce{2Mg + O2 ->[燃烧] 2 MgO}$

  • 效果:
    • x 2 + 2 x + 5 + x = 0 x^2 + 2x + 5 + \sqrt x = 0 x2+2x+5+x =0
    • e i π + 1 = 0 e^{i\pi} + 1 = 0 e+1=0
    • KaTeX parse error: Undefined control sequence: \ce at position 1: \̲c̲e̲{CO2 + C -> 2 C…
    • KaTeX parse error: Undefined control sequence: \ce at position 1: \̲c̲e̲{2Mg + O2 ->[燃烧…

16.2 公式块

  • 格式:
    • $$
      公式块
      $$

  • 示例:
% 化学公式
$$
\ce{Zn^2+  <=>[+ 2OH-][+ 2H+]  $\underset{\text{amphoteres Hydroxid}}{\ce{Zn(OH)2 v}}$  <=>[+ 2OH-][+ 2H+]  $\underset{\text{Hydroxozikat}}{\ce{[Zn(OH)4]^2-}}$}
$$
% 麦克斯韦方程组
$$
\begin{array}{lll}
\nabla\times E &=& -\;\frac{\partial{B}}{\partial{t}}   
\ \nabla\times H &=& \frac{\partial{D}}{\partial{t}}+J   
\ \nabla\cdot D &=& \rho
\ \nabla\cdot B &=& 0
\ \end{array}
$$
% 薛定谔方程
$$
i\hbar\frac{\partial \psi}{\partial t} = \frac{-\hbar^2}{2m} \left(\frac{\partial^2}{\partial x^2} + \frac{\partial^2}{\partial y^2}+\frac{\partial^2}{\partial z^2} \right) \psi + V \psi
$$

  • 效果:

KaTeX parse error: Undefined control sequence: \ce at position 9: % 化学公式 \̲c̲e̲{Zn^2+ <=>[+ 2…


∇ × E = −    ∂ B ∂ t   ∇ × H = ∂ D ∂ t + J   ∇ ⋅ D = ρ   ∇ ⋅ B = 0   % 麦克斯韦方程组 \begin{array}{lll} \nabla\times E &=& -\;\frac{\partial{B}}{\partial{t}} \ \nabla\times H &=& \frac{\partial{D}}{\partial{t}}+J \ \nabla\cdot D &=& \rho \ \nabla\cdot B &=& 0 \ \end{array} ×E=tB ×H=tD+J D=ρ B=0 


i ℏ ∂ ψ ∂ t = − ℏ 2 2 m ( ∂ 2 ∂ x 2 + ∂ 2 ∂ y 2 + ∂ 2 ∂ z 2 ) ψ + V ψ i\hbar\frac{\partial \psi}{\partial t} = \frac{-\hbar^2}{2m} \left(\frac{\partial^2}{\partial x^2} + \frac{\partial^2}{\partial y^2}+\frac{\partial^2}{\partial z^2} \right) \psi + V \psi itψ=2m2(x22+y22+z22)ψ+Vψ

  • 补充:
    • 需要详细教程的,可戳下方链接
    • Latex详细教程



17. Mermaid

  • 一些 MD编辑器笔记软件 支持通过 Mermaid 及其所提供的 编译器 来为用户提供图表的绘制功能

  • 这里只提供一些演示的图表,具体教程可戳下方

17.1 流程图


源码1:

```mermaid
graph TB
	%% s=start  e=end  f=fork  n=normal
	
	s([开始])-->f1{{if条件}};

	%% 分支点2
	f1--true-->n1[if语句块]-->e([结束]);
	f1--false-->f2{{else if条件}};

	%% 分支点1
	f2--true-->n2[else if语句块]-->e;
	f2--false-->n3[else语句块]-->e;
```

渲染1:

true
false
true
false
开始
if条件
if语句块
结束
else if条件
else if语句块
else语句块

源码2:

```mermaid
graph LR
	%% s=start  e=end  f= fork n=normal 
	
	%% 虚线
	s[朱百六]-.->|子|n1[朱四九]-.->|子|n2[朱五四]-.->|子|f1_帝((朱八八))
	
	%% 分支点 朱八八
	f1_帝-->|长子|f2[朱标]
	f1_帝-->|次子|n3[朱樉]
	f1_帝-->|三子|n4[朱棢]
	f1_帝-->|四子|n5_帝((朱棣))
	
	%% 分支点 朱标
	f2-->|长子|e1[朱雄英]
	f2-->|次子|e2_帝((朱允炆))
	
	n5_帝-->|长子|e3[朱高炽]
```

渲染2:

长子
次子
三子
四子
长子
次子
长子
朱百六
朱四九
朱五四
朱八八
朱标
朱樉
朱棢
朱棣
朱雄英
朱允炆
朱高炽

17.2 饼图


源码:

```mermaid
pie
    title 为什么总是宅在家里?
    "喜欢宅" : 45
    "天气太热" : 70
    "穷" : 500
	"关你屁事" : 95
```

渲染:

6% 10% 70% 13% 为什么总是宅在家里? 喜欢宅 天气太热 关你屁事

17.3 序列图 (时序图)


源码:

```mermaid
sequenceDiagram
	%% 自动编号
	autonumber
	%% 定义参与者并取别名,aliases:别名
        participant A as Aly
        participant B as Bob
        participant C as CofCai
        %% 便签说明
        Note left of A: 只复习了一部分
        Note right of B: 没复习
        Note over A,B: are contacting
        
        A->>B: 明天是要考试吗?
        B-->>A: 好像是的!
        
        %% 显示并行发生的动作,parallel:平行
        %% par [action1]
        rect rgb(0, 25, 155)
            par askA
                C -->> A:你复习好了吗?
            and askB
                C -->> B:你复习好了吗?
            and self
                C ->>C:我还没准备复习......
            end
        end
        
        %% 背景高亮,提供一个有颜色的背景矩形
        rect rgb(25, 55, 0)
            loop 自问/Every min
            %% <br/>可以换行
            C ->> C:我什么时候<br/>开始复习呢?
            end
        end
        
        %% 可选择路径
        rect rgb(153, 83, 60)
            alt is good
                A ->> C:复习了一点
            else is common
                B ->> C:我也是
            end
            %% 没有else时可以提供默认的opt
            opt Extra response
                C ->> C:你们怎么不回答我
            end
        endsequenceDiagram
	%% 自动编号
	autonumber
	%% 定义参与者并取别名,aliases:别名
        participant A as Aly
        participant B as Bob
        participant C as CofCai
        %% 便签说明
        Note left of A: 只复习了一部分
        Note right of B: 没复习
        Note over A,B: are contacting
        
        A->>B: 明天是要考试吗?
        B-->>A: 好像是的!
        
        %% 显示并行发生的动作,parallel:平行
        %% par [action1]
        rect rgb(0, 25, 155)
            par askA
                C -->> A:你复习好了吗?
            and askB
                C -->> B:你复习好了吗?
            and self
                C ->>C:我还没准备复习......
            end
        end
        
        %% 背景高亮,提供一个有颜色的背景矩形
        rect rgb(25, 55, 0)
            loop 自问/Every min
            %% <br/>可以换行
            C ->> C:我什么时候<br/>开始复习呢?
            end
        end
        
        %% 可选择路径
        rect rgb(153, 83, 60)
            alt is good
                A ->> C:复习了一点
            else is common
                B ->> C:我也是
            end
            %% 没有else时可以提供默认的opt
            opt Extra response
                C ->> C:你们怎么不回答我
            end
        end
```

渲染:

Aly Bob CofCai 只复习了一部分 没复习 are contacting 明天是要考试吗? 1 好像是的! 2 你复习好了吗? 3 你复习好了吗? 4 我还没准备复习...... 5 par [askA] [askB] [self] 我什么时候 开始复习呢? 6 loop [自问/Every min] 复习了一点 7 我也是 8 alt [is good] [is common] 你们怎么不回答我 9 opt [Extra response] Aly Bob CofCai

17.4 甘特图


源码:

```mermaid
gantt
    title A Gantt Diagram
    dateFormat  YYYY-MM-DD
    section Section
    A task           :a1, 2014-01-01, 30d
    Another task     :after a1  , 20d
    section Another
    Task in sec      :2014-01-12  , 12d
    another task      : 24d
```

渲染:

2014-01-05 2014-01-12 2014-01-19 2014-01-26 2014-02-02 2014-02-09 2014-02-16 A task Task in sec another task Another task Section Another A Gantt Diagram

17.5 类图


源码:

```mermaid
classDiagram
    Animal <|-- Duck
    Animal <|-- Fish
    Animal <|-- Zebra
    Animal : +int age
    Animal : +String gender
    Animal: +isMammal()
    Animal: +mate()
    class Duck{
      +String beakColor
      +swim()
      +quack()
    }
    class Fish{
      -int sizeInFeet
      -canEat()
    }
    class Zebra{
      +bool is_wild
      +run()
    }
```

渲染:

Animal
+int age
+String gender
+isMammal()
+mate()
Duck
+String beakColor
+swim()
+quack()
Fish
-int sizeInFeet
-canEat()
Zebra
+bool is_wild
+run()



18. 标签 (Tag)

  • 标签是 Obsidian 特有的一个功能,标签可以通过点击唤起快速搜索 (搜索包含该标签的所有笔记)

格式:

  • # + 标签名
    • #标签名

关于空格

  • 在一段正文文本的后面添加 Tag, #前面 需要有个空格
    • 空格 + # + 标签名

  • # 与 标签名 之间不能有空格,否则就变成 一级标题 了

  • 标签名的内部不允许使用空格,若想区分标签中的词语,可使用以下三种方法:
    1. 驼峰式大小写: #BlueTopaz
    2. 下划线: #blue_topaz
    3. 连字符: #blue-topaz

关于数字

  • 标签内允许使用数字,但不能完全由数字组成
    • #1984
    • #1984Date
    • #da_1984_te
    • #date-1984

标签的嵌套

在标签名内,使用 / 斜杠 可以实现标签的嵌套

格式:

  • #主标签/子标签1
  • #主标签/子标签2
  • #主标签/子标签3

嵌套标签可以像普通标签一样通过点击来唤起搜索,嵌套标签允许你选择搜索的层次。例如:

  • 搜索 #主标签 ,即可找到包含任意一个子标签的所有笔记
    • 返回的结果会是上述的三个例子
  • 当你在一个主分类下设置了多个子分类,想找到这个主分类包含的所有内容时,该功能会很实用

能被使用的符号

综上所述,标签内能被使用的符号共有三种

  1. _ 下划线
  2. - 连字符
  3. / 斜杠

如何让 # 不被识别

可以使用前面提到的转义符号 \ 反斜杠,与上述的 转义标题 类似

格式:

\#这里的内容不会被识别为标签

效果:

#这里的内容不会被识别为标签


19. 避免标识符的滥用

即使在 Markdown 中,也要尽量避免标识符的滥用

比如我的这篇教程,就存在一定程度的滥用

  • 其实是因为我这篇是教学性质的,不太一样,有些不能避免
    • (好吧,我就是在甩锅)

标识符的本质是突出显示,代表重点

  • 一篇笔记里的某段文本,使用各式各样的的标识符,会造成重点不清晰

三种标识,慎用

  1. 词中对单个汉字的标识
  2. 短语中对单个英语单词的标识
    1. get a bang out of
  3. 标识符的多层嵌套
    1. 我感觉快要==原地起飞==了

原因:

  • 词义的割裂
  • 视觉的混乱
  • 不利于搜索
    • 卧==虎==藏==龙==
      • 卧虎 – 搜不到
      • 藏龙 – 搜不到

  1. 周树人 ↩︎

  2. 绍兴人 ↩︎

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1140640.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

为什么把k8s比做操作系统:kubernetes与os的架构对比

你还在背八大件吗&#xff1f;不如把k8s的架构和os一起看&#xff0c;你会发现一些超有趣的事情&#xff01;本文旨在将k8s的架构和os做个对比&#xff0c;帮助读者理解为什么k8s要这么设计。 kubernetes架构 kubernetes架构中由master节点和minion节点组成&#xff0c;maste…

c++ deque 的使用

目录 1. deque 的介绍 2. deque 底层原理 3. deque 的迭代器 4. deque 的接口使用 5. deque 和 vector&#xff0c;list 的比较 1. deque 的介绍 下面是 deque 的介绍&#xff0c;来自于&#xff1a;deque - C Reference (cplusplus.com) 的翻译&#xff0c;您可以不用…

MobPush数智化推送,精准定位万圣节狂欢年轻一族

随着中秋十一黄金周的结束&#xff0c;2023年最后一个法定节假日也一去不复返&#xff0c;但是别急&#xff0c;今年还有另一场不放假的狂欢节日——万圣节&#xff0c;万圣节作为西方国家第四季度最为重要的营销节日之一&#xff0c;在国内年轻人群体中同样具有较大的影响力和…

字节流和处理流的对象反序列化问题

细节&#xff1a; 读写要保持一致 序列对象时&#xff0c;默认将里面的所有属性都进行序列化&#xff0c;但除了static或transient修饰的成员 要求序列化或反序列化对象&#xff0c;需要实现Serializable 序列化对象时&#xff0c;要求里面的属性也要实现序列化接口 序列化…

java-- 静态数组

1.静态初始化数组 定义数组的时候直接给数组赋值。 2.静态初始化数组的格式&#xff1a; 注意&#xff1a; 1."数据类型[] 数组名"也可以写成"数据类型 数组名[]"。 2.什么类型的数组只能存放什么类型的数据 3.数组在计算机中的基本原理 当计算机遇到…

【优选算法精品】前缀和

文章目录 一、前缀和前缀和问题一维前缀和模板二维前缀和模板 细节处理题目1思路细节处理&#xff1a; 题目2思路 题目3题目4题目5题目6总结 一、前缀和 前缀和问题 前缀和用来快速解决某一段连续区间的和。 时间复杂度O(1) 注意&#xff1a;不要背模板&#xff0c;不要背模…

死锁Deadlock

定义 死锁是指两个或多个线程互相持有对方所需的资源&#xff0c;从而导致它们无法继续执行的情况。如下图所示&#xff0c;现有两个线程&#xff0c;分别是线程A及线程B&#xff0c;线程A持有锁A&#xff0c;线程B持有锁B。此时线程A想获取锁B&#xff0c;但锁B需等到线程B的结…

计算机网络之数据链路层(全)

[复习提示] 王道&#xff1a;本章是历年考试中考查的重点。要求在了解数据链路层基本概念和功能的基础上&#xff0c;重点掌握滑动窗口机制、三种可靠传输协议、各种MAC协议、HDLC协议和PPP协议&#xff0c;特别是CSMA/CD协议和以太网帧格式&#xff0c;以及局域网的争用期和最…

C++学习笔记之三(标准库、标准模板库、vector类)

C 1、C标准库2、C标准模板库2.1、vector2.1.1、vector与array2.1.2、vector与函数对象2.1.3、vector与迭代器 1、C标准库 C C C标准库指的是标准程序库( S t a n d a r d Standard Standard L i b a r a y Libaray Libaray)&#xff0c;它定义了十个大类&#xff0c;其中包括…

只有向内生长,才能向外绽放——中国人民大学与加拿大女王大学金融硕士

这个时代&#xff0c;产业迭代、竞争愈发激烈、世界局势变幻等这些都是我们无法控制的事。我们能做到的是不断地努力提升自己&#xff0c;成为所在领域的佼佼者。人的成长之路&#xff0c;就像是一场循序渐进的蜕变。不断努力是让自己逐步增值的过程。只有向内生长&#xff0c;…

世界经济论坛:ChatGPT等生成式AI,对全球23%岗位产生巨大影响

世界经济论坛与全球最大上市咨询公司之一埃森哲合作&#xff0c;联合发布了《未来工作&#xff1a;大语言模型与就业》白皮书。 世界经济论坛表示&#xff0c;随着ChatGPT、Midjourney、Github Copilot等生成式AI的飞速发展&#xff0c;对全球经济和劳动市场产生巨大影响。未来…

手写Vue渲染器render函数

使用js对象来描述UI更加的灵活。“这种对象”在vue框架中被称为虚拟DOM&#xff0c;渲染函数内部可以创建虚拟DOM&#xff0c;然后vue.js可以将其内容进行渲染。 1.渲染器的介绍 渲染器的作用就是把虚拟DOM渲染为真实DOM 思考下&#xff0c;我们有一个虚拟 DOM&#xff0c;如…

js数组的常用方法

目录 1. 添加/删除元素 2. 查找和遍历 3. 转换 4. 排序 5. 其他 JavaScript中的数组是一种用于存储多个值的对象。数组提供了一系列的方法来进行操作&#xff0c;包括添加、删除、遍历和搜索等。下面列举了一些JavaScript数组的常用方法&#xff1a; 1. 添加/删除元素 pu…

C指针 --- 进阶

目录 1. 字符指针 1.1. 一般使用 1.2. 另一种使用 2. 指针数组 3. 数组指针 3.1. 数组指针 3.2. 数组名和&数组名 3.3. 数组指针的用处 1. 传递一个数组 2. 传递数组首元素的地址 3. 数组指针处理一维数组 4. 数组指针处理二维数组 4. 数组传参和指针传参 4.1…

PHP危险函数

PHP危险函数 文章目录 PHP危险函数PHP 代码执行函数eval 语句assert()语句preg_replace()函数正则表达式里修饰符 回调函数call_user_func()函数array_map()函数 OS命令执行函数system()函数exec()函数shell_exec()函数passthru() 函数popen 函数反引号 实列 通过构造函数可以执…

杂牌行车记录仪特殊AVI结构恢复案例

最近遇到一个杂牌的行车记录仪需要恢复数据&#xff0c;其使用AVI格式&#xff0c;但是在扫描恢复的过程中却发现厂家对其AVI结构进行了“魔改”致程序无法正常识别 故障存储:16G SD卡 fat32文件系统 故障现象: 16G的SD卡&#xff0c;在发生事故后客户尝试自行接到手机上读…

小红书素人铺量推广费用是多少?

小红书作为一个拥有庞大用户群体的社交电商平台&#xff0c;在品牌营销和产品推广方面具有巨大的潜力。其中&#xff0c;素人铺量推广作为一种常见的推广方式&#xff0c;被越来越多的品牌和商家所采用。但是&#xff0c;对于很多刚刚接触小红书推广的人来说&#xff0c;素人铺…

二维码智慧门牌管理系统升级解决方案:一级属性 二级属性

文章目录 前言一、什么是智慧门牌管理系统&#xff1f;二、一级属性 vs. 二级属性三、升级中的实践意义 前言 在本文中&#xff0c;我们将深入探讨二维码智慧门牌管理系统的升级解决方案&#xff0c;特别聚焦于一级属性和二级属性的关键概念。我们将详细解释这些概念&#xff…

如何做好建筑翻译呢

近年来&#xff0c;随着跨国工程项目增加&#xff0c;建筑翻译也越来越受到重视。尤其是建筑图纸翻译在工程设计、规划和施工等方面都具有重要意义。那么&#xff0c;如何做好建筑翻译呢&#xff0c;建筑工程翻译哪个比较正规&#xff1f; 在建筑行业日新月异的发展中&#xff…

项目进度延误,危机管理5大注意事项

项目延误危机管理的重要性是不可忽视的。项目延误可能会导致资源浪费、成本增加、客户不满、信誉受损等一系列问题&#xff0c;严重影响项目的成功与效益。因此&#xff0c;有效地进行项目延误危机管理是至关重要的&#xff0c;一般主要是从以下5个方面进行管理&#xff1a; 1、…