我正在制作一个网站,每个月都会在问题中发布文章。这很简单,我认为使用 Markdown 编辑器(如 Stack Overflow 中的WMD编辑器)将是完美的。
但是,他们确实需要在给定段落中使图像右对齐的能力。
我看不到使用当前系统的方法 - 有可能吗?
您可以在 Markdown 中嵌入 HTML,因此您可以执行以下操作:
<img style="float: right;" src="whatever.jpg">
Continue markdown text...
我在纯 Markdown中找到了一个不错的解决方案,带有一点CSS 3 hack :-)
data:image/s3,"s3://crabby-images/a82c9/a82c9d90624980bc8d3097f7b6701752eed95575" alt="image alt >"
data:image/s3,"s3://crabby-images/79658/79658960a83abd98fbd59aae2b012a888f6cd8ff" alt="image alt <"
data:image/s3,"s3://crabby-images/9f201/9f2010a5e7446a83e65174194c2988d3ea442a39" alt="image alt ><"
当以或image alt
结尾时,遵循左侧或右侧的 CSS 3 代码浮动图像。<
>
img[alt$=">"] {
float: right;
}
img[alt$="<"] {
float: left;
}
img[alt$="><"] {
display: block;
max-width: 100%;
height: auto;
margin: auto;
float: none!important;
}
许多 Markdown “额外”处理器支持属性。所以你可以像这样包含一个类名(PHP Markdown Extra):
data:image/s3,"s3://crabby-images/0a448/0a44865c733bc155e0cfaa1c9e12450fac509f35" alt="Flowers"{.callout}
或者,或者(Maruku、Kramdown、Python Markdown):
data:image/s3,"s3://crabby-images/0a448/0a44865c733bc155e0cfaa1c9e12450fac509f35" alt="Flowers"{: .callout}
然后,当然,您可以以正确的方式使用样式表:
.callout {
float: right;
}
如果你的支持这种语法,它会给你两全其美:没有嵌入的标记,以及一个足够抽象的样式表,不需要你的内容编辑器修改。
对于上面使用 ALT 标记和 alt 标记上的 CSS 选择器的方法,我有一个替代方法......相反,添加这样的 URL 哈希:
首先是您的 Markdown 图像代码:
data:image/s3,"s3://crabby-images/d555c/d555cc34d5fa563b62db0b22a98f56fa2993f5fa" alt="my image"
data:image/s3,"s3://crabby-images/6b8b1/6b8b10a3c941336cc61fddb01c5299b5bbcf32f7" alt="my image"
data:image/s3,"s3://crabby-images/8db9c/8db9c88ce445770d981761358af6135485140f36" alt="my image"
请注意添加的 URL 哈希 #center。
现在使用 CSS 3 属性选择器在 CSS 中添加此规则以选择具有特定路径的图像。
img[src*='#left'] {
float: left;
}
img[src*='#right'] {
float: right;
}
img[src*='#center'] {
display: block;
margin: auto;
}
您应该能够像定义类名一样使用这样的 URL 哈希,并且它不是像某些人针对该解决方案所评论的那样滥用 ALT 标记。它也不需要任何额外的扩展。为左右浮动或您可能想要的任何其他样式做一个。
我喜欢通过使用表格将图像与垂直管道 ( |
) 语法对齐来变得超级懒惰。这得到了一些 Markdown 风格的支持(如果你的船漂浮的话,Textile也支持):
| I am text to the left | data:image/s3,"s3://crabby-images/0a448/0a44865c733bc155e0cfaa1c9e12450fac509f35" alt="Flowers" |
或者
| data:image/s3,"s3://crabby-images/0a448/0a44865c733bc155e0cfaa1c9e12450fac509f35" alt="Flowers" | I am text to the right |
它不是最灵活的解决方案,但它可以满足我的大部分简单需求,以 markdown 格式易于阅读,并且您不需要记住任何 CSS 或原始 HTML。
嵌入 CSS 很糟糕:
data:image/s3,"s3://crabby-images/0a448/0a44865c733bc155e0cfaa1c9e12450fac509f35" alt="Flowers"
另一个文件中的 CSS:
img[alt=Flowers] { float: right; }
更p#given img { float: right }
简洁的方法是只放入样式表,或者<head>
放入style
标签中。然后,只需使用 markdown data:image/s3,"s3://crabby-images/0cd30/0cd30133a7dbc6a8e60279b69bc3438371d3d583" alt="Alt text"
。
<div style="float:left;margin:0 10px 10px 0" markdown="1">
data:image/s3,"s3://crabby-images/ec710/ec710d4e469c1a60fd6ce49a6f7227ef4bc7f2f7" alt="book"
</div>
markdown
Markdown 内部的属性可能性。
我喜欢learnvst使用表格的答案,因为它非常易读(这是编写 Markdown 的目的之一)。
但是,对于 GitBook 的 Markdown 解析器,除了一个空的标题行之外,我还必须在其下添加一个分隔线,以便识别和正确呈现表格:
| - | - |
|---|---|
| I am text to the left | data:image/s3,"s3://crabby-images/0a448/0a44865c733bc155e0cfaa1c9e12450fac509f35" alt="Flowers" |
| data:image/s3,"s3://crabby-images/0a448/0a44865c733bc155e0cfaa1c9e12450fac509f35" alt="Flowers" | I am text to the right |
分隔线需要至少包含三个破折号---
。
如果你在 Python 中实现它,有一个扩展可以让你添加 HTML 键/值对和类/ID 标签。语法是:
data:image/s3,"s3://crabby-images/43d42/43d426b7174df6230f06bc762dd81b64d8fd3fc7" alt="A picture of a cat"{: style="float:right"}
或者,如果嵌入式样式不能让你的船漂浮,
data:image/s3,"s3://crabby-images/43d42/43d426b7174df6230f06bc762dd81b64d8fd3fc7" alt="A picture of a cat"{: .floatright}
带有相应的样式表,stylish.css
:
.floatright {
float: right;
/* etc. */
}
正如 greg所说,您可以在 Markdown 中嵌入 HTML 内容,但 Markdown 的要点之一是避免必须拥有广泛的(或任何,就此而言)CSS/HTML 标记知识,对吧?这就是我所做的:
在我的 Markdown 文件中,我只是指示我所有的 wiki 编辑器嵌入所有图像,如下所示:
'<div> // Put image here </div>`
(当然..他们不知道是什么<div>
意思,但这不重要)
所以 Markdown 文件看起来像这样:
<div>
![optional image description][1]
</div>
[1]: /image/path
在包含整个页面的 CSS 内容中,我可以使用图像标签做任何我想做的事情:
img {
float: right;
}
当然,您可以对 CSS 内容做更多的事情......(在这种特殊情况下,img
用 div 包装标签可以防止其他文本包装在图像上......不过,这只是一个例子),但恕我直言,Markdown的重点是您不希望潜在的非技术人员进入 CSS/HTML 的来龙去脉。作为 Web 开发人员,您可以让包含页面的 CSS 内容尽可能通用和干净,但是随后再次,您的编辑不需要知道这一点。
我有同样的任务,我通过添加以下内容将图像向右对齐:
<div style="text-align: right"><img src="/default/image/sms.png" width="100" /></div>
要将图像向左或居中对齐,请替换
<div style="text-align: right">
和
<div style="text-align: center">
<div style="text-align: left">
在警告框中将图像和文本并排对齐,作为单个块中段落的一部分。
<div class="warning" style='background-color:#EDF2F7; color:#1A2067; border-left: solid #718096 4px; border-radius: 4px;'>
<p style='padding:0.7em; margin-left:0.7em; display: inline-block;'>
<img src="typora_images/image-20211028083121348.png" style="zoom:70%; float:right; padding:0.7em"/>
<b>isomorphism</b> → In mathematics, an isomorphism is a structure-preserving mapping between two structures of the same type that can be reversed by an inverse mapping.<br>
</p>
</div>
输出 :
这对我有用
<p align="center">
<img src="/LogoOfficial.png" width="300" >
</p>
最简单的是将图像包装在中心标签中,就像这样......
<center>data:image/s3,"s3://crabby-images/b39ed/b39edd49eaa37bf97afdc68880869309ac5e7f41" alt="Alt test"</center>
与 Markdown 相关的任何事情都可以在这里进行测试 - http://daringfireball.net/projects/markdown/dingus
当然,<center>
可能会被弃用,但它很简单而且有效!