内容简介:github项目中经常都会包含很多badge,这些badge能够很直观地展示出项目的状态来。然而大多数badge生成的站点提供的badge代码都是markdown格式的,而缺少org格式的。 比如下面是要在org文件中增加badge就必须手工将之转成org link的格式。
github项目中经常都会包含很多badge,这些badge能够很直观地展示出项目的状态来。
然而大多数badge生成的站点提供的badge代码都是markdown格式的,而缺少org格式的。
比如下面是 netlify
提供的badge代码:
[](https://app.netlify.com/sites/thirsty-pike-764a9b/deploys)
要在org文件中增加badge就必须手工将之转成org link的格式。
哪些org link会被转换成image
org并没有像markdown一样专门定义了一套语法来指明链接是图片而不是引用。
在 ox.el
的源代码中有这么一段注释:
;; `org-export-inline-image-p' returns a non-nil value when the link ;; provided should be considered as an inline image.
也就是说一个link是应该看成引用链接还是图片是由 org-export-inline-image-p
这个函数来决定的
然而具体到org-html转换来说,根据 ox-html
中的代码,一个org link转换成image必须满足两个方面的条件:
-
org-html-inline-images的值需要设置为非nil -
链接要被
org-export-inline-image-p函数识别成图片,识别的规则由org-html-inline-image-rules决定
相关代码如下:
((and (plist-get info :html-inline-images) (org-export-inline-image-p link (plist-get info :html-inline-image-rules))) (org-html--format-image path attributes-plist info)) (:html-inline-images nil nil org-html-inline-images) (:html-inline-image-rules nil nil org-html-inline-image-rules)
而 org-html-inline-image-rules
的默认值为:
(defcustom org-html-inline-image-rules '(("file" . "\\.\\(jpeg\\|jpg\\|png\\|gif\\|svg\\)\\'") ("http" . "\\.\\(jpeg\\|jpg\\|png\\|gif\\|svg\\)\\'") ("https" . "\\.\\(jpeg\\|jpg\\|png\\|gif\\|svg\\)\\'")) "Rules characterizing image files that can be inlined into HTML. A rule consists in an association whose key is the type of link to consider, and value is a regexp that will be matched against link's path." :group 'org-export-html :version "24.4" :package-version '(Org . "8.0") :type '(alist :key-type (string :tag "Type") :value-type (regexp :tag "Path")))
也就说以 .jpeg
, .jpg
, .png
, .gif
或 .svg
结尾的链接才会被认为是图片。
在org文件中添加badge
通过分析,我们可以知道,若badge给出的链接本身就是以 .jpeg
, .jpg
, .png
, .gif
或 .svg
结尾的,那么很简单,我们只需要将
[](link)
转换成
#+ATTR_HTML :alt $alt $image_link
就可以了(其中通过 #+ATTR_HTML
来为image添加alt属性).
但是对于那些不是以 .jpeg
, .jpg
, .png
, .gif
和 .svg
结尾的链接则似乎只能通过定义buffer local的 org-html-inline-image-rules
来实现了.
比如下面这段org代码
# -*- org-html-inline-image-rules: (("https" . "deploy-status\\'")); -*- https://api.netlify.com/api/v1/badges/3b4ebb33-1ce2-4238-9a69-e4ecdafd2f1a/deploy-status
导出为HTML后会变成
<div class="figure"> <p><a href="https://app.netlify.com/sites/thirsty-pike-764a9b/deploys"><img src="https://api.netlify.com/api/v1/badges/3b4ebb33-1ce2-4238-9a69-e4ecdafd2f1a/deploy-status" alt="deploy-status" /></a> </p> </div>
github直接渲染
由于github不支持buffer local 变量,其对org的渲染也不是很完善,因此对于非 .jpeg
, .jpg
, .png
, .gif
和 .svg
结尾的链接似乎是没有办法显示为图片的。
但是值得指出的是,有些badge服务提供的链接是允许在最后面添加后缀的,比如 netlify
提供的badge,我可以在其图片链接后面增加 .png
也不会影响badge的生成。
因此上面那段markdonw代码我可以改写成
https://api.netlify.com/api/v1/badges/3b4ebb33-1ce2-4238-9a69-e4ecdafd2f1a/deploy-status.png
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- go-fastdfs v1.1.9增加文件自动迁移功能、文件可重复选项
- go-fastdfs v1.1.9增加文件自动迁移功能、文件可重复选项
- go-fastdfs v1.2.8 发布,增加文件列表接口,优化文件快速迁移功能
- 分布式文件系统 go-fastdfs v1.2.8 发布,增加文件列表接口,优化文件快速迁移功能
- Proxy-Go v3.8 发布,增加了日志文件功能
- PHP 文件数据库 CuteDB v1.1 发布,增加迭代器功能
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
人工智能
腾讯研究院、中国信通院互联网法律研究中心、腾讯AI Lab、腾讯开放平台 / 中国人民大学出版社 / 2017-10-25 / 68.00元
面对科技的迅猛发展,中国政府制定了《新一代人工智能发展规划》,将人工智能上升到国家战略层面,并提出:不仅人工智能产业要成为新的经济增长点,而且要在2030年达到世界领先水平,让中国成为世界主要人工智能创新中心,为跻身创新型国家前列和经济强国奠定基础。 《人工智能》一书由腾讯一流团队与工信部高端智库倾力创作。本书从人工智能这一颠覆性技术的前世今生说起,对人工智能产业全貌、最新进展、发展趋势进行......一起来看看 《人工智能》 这本书的介绍吧!