本文共 1391 字,大约阅读时间需要 4 分钟。
本文是个人学习笔记,文中技巧均来自 StackOverflow 相关问题中的回答
前言(废话区)
现在很多 Markdown 编辑器带的解析器都支持一些快捷插入表格的语法。比如 Typora,MWeb 等支持用如下语法插入表格:
第一格表头 | 第二格表头
--------- | -------------
内容单元格 第一列第一格 | 内容单元格第二列第一格
内容单元格 第一列第二格 多加文字 | 内容单元格第二列第二格
但是当表格内容稍微复杂的时候,这个基本语法可能就满足不了需求 (不过这也不能怪 Markdown,毕竟初衷就是要简单)。典型的,比如列宽,默认都是按照单元格内容自适应,或者整表列宽与行宽相同。内容一多,排版就比较混乱。下面就分享几个我刚学的,利用简单 html 语法调列宽的方法。
Case 1: 预留宽度,用于打印后填写
一个比较简单粗暴的方法自然是加一段空格符
一个更加优雅的方法则是使用空的 标签。例如
| a | b | c |
|---|---|---|
| 1 | | 3 |使用 <img> 标签效果
Case 2: 长文本需要指定列宽,控制换行
第一种方法可以使用
**默认**
| a | b | d |
|---|---|---|
| 1 | very very very very very long long long long long text | 3 |
**使用后效果**
| a | b | d |
|---|---|---|
| 1 |
第二种方法可以从外部定义一个 「Style」来指定各列的列宽
table th:first-of-type {
width: 4cm;
}
table th:nth-of-type(2) {
width: 150pt;
}
table th:nth-of-type(3) {
width: 8em;
}
| a | b | c |
|---|---|---|
| 列宽 = 3 cm| 列宽 = 5 cm| 列宽 = 8em |用绝对长度定义列宽
当然你可以把单位改成 % 这样就相当于按照所占行宽的比例来分配列宽
table th:first-of-type {
width: 20%;
}
table th:nth-of-type(2) {
width: 30%;
}
table th:nth-of-type(3) {
width: 50%;
}
| a | b | c |
|---|---|---|
| 列宽 = 10% 行宽| 列宽 = 30% 行宽 |列宽 = 60% 行宽 |根据行宽指定比例分配列宽
需要指出的是,这种方法是全局起效的。如果你在一篇文章中,需要不同样式的表格,那么就需要额外的利用 css 语言定义不同种的表格类,这里不展开了。不是很推荐这样做,因为这样就失去 Markdwon 的核心价值了。
一个问题:如果各列百分比加起来不是 100% 结果怎么样?自己去测试吧 ️
转载地址:https://blog.csdn.net/weixin_32804237/article/details/112901110 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!