1 快速输入 #+BEGIN_SRC … #+END_SRC

用org-mode写文章的的时候,经常需要引用代码片段或者程序输出,这就需要输入 #+BEGIN_SRC ... #+END_SRC 或者 #+BEGIN_EXAMPLE ... #+END_EXAMPLE 。输入的次数多了,就会想办法自动化,要么是用宏,要么是手工写 elisp函数,要么是借助 yasnippets 或者 skeleton 框架来写代码片段(比如 Emacs中文网 就发过一篇 《GNU Emacs Org-mode 写作的几个快捷方式》 ,那是借助 skeleton 来实现的)。

但其实,org-mode已经内置了快速输入的方法: 输入 <s 再按TAB键 ,就会自动展开为 #+BEGIN_SRC ... #+END_SRC 。类似地,输入 <e 再按TAB键,就会自动展开为 #+BEGIN_EXAMPLE ... #+END_EXAMPLE

参考:

2 代码按语法高亮

org-mode在导出成HTML时,可以对代码按照各自的语法进行高亮(只要在 #+begin_src 后面声明的语言是emacs所 支持的,其实也就是对应的major mode存在,比如声明为 #+begin_src js2 就要求 js2-mode 是存在的)。

但能不能在编辑的时候,就可以在org-mode里面看到语法高亮的效果呢?答案是肯定的!

(setq org-src-fontify-natively t)

不过没有看到这个设置的更详细说明(我也没来看代码),在org-mode的文档中仅仅在Editing source code这一节 看到一句: To turn on native code fontification in the Org buffer, configure the variable org-src-fontify-natively. 另外,Pretty fontification of source code blocks这篇文档里有效果图:

3 导出成HTML时的一些问题和技巧

3.1 生成目录表

如果想在导出成HTML时在文档前面生成一个章节目录表(Table of Contents),那么可以在文件头部的 OPTIONS 里面添加 toc:t 参数

#+OPTIONS: toc:t  ^:nil author:nil num:2

也可以设置 org-export-with-toc 这个变量

(setq org-export-with-toc t)

如果只想针对前面两个级别生成目录表,可以设置该值为相应的数字

#+OPTIONS: toc:2  ^:nil author:nil num:2

3.2 为每个分节的标题添加标号

导出成HTML时,如果不自定义css(这个高级话题留待下次再说),那么h1, h2, h3各个级别的标题只会字体大小有 点不同,不会呈现不同颜色,不会有缩进,于是阅读起来各节之间的关系就搞不清楚了。可以设置 org-export-with-section-numbers 让导出时为各章节的标题添加 1.2.3 这样的

比如:

  * header foobar

  ** header hello

  ** header welcome

  * header hehe
some text here ** header haha *** low level

导出时会变成:

1 header foobar

1.1 header hello

1.2 header welcome

2 header hehe
some text here 2.1 header haha 2.1.1 low level

如果只想针对前面两个级别生成分节号,可以设置该值为相应的数字。比如上面的例子如果设置 org-export-with-section-numbers2 ,导出时就变成了:

1 header foobar

1.1 header hello

1.2 header welcome

2 header hehe
some text here 2.1 header haha *low level*

3.3 禁用下划线转义

org-mode的文档在导出到html时,有一个挺烦人的问题就是 abc_def 会变成 abcdef,这其实是一种类似TeX的 写法,主要也就是在少数场景下有意义(其实与之相伴的还有一个 10^24 会变成 1024,不过这个对我影响不 大,因为我很少会用到这种写法)。

关闭这个功能的方法是在org文件头部的 OPTIONS 里面添加 ^:nil:

#+OPTIONS: ^:nil

参考: Export settings - The Org Manual

上面的方法是针对当前文件的,如果想针对所有文件缺省关闭这个功能,需要在 ~/.emacs 中设置:

(setq-default org-use-sub-superscripts nil)

4 让不同级别的标题采用不同大小的字体

我从vim转到Emacs的其中一个原因是Emacs的GUI版本支持同时使用多种字体,比如上面的截图中就可以看到标题采 用了较大的字体。而以前对Emacs不太熟悉时,试用 color-theme-tangotango 期间无意中发现它能让 org-mode 的各种标题用不同大小的字体显示,还以为是比较神奇的功能,而不愿意切换到其他的theme去。

其实定制一下 org-level-1, org-level-2 等face的 height 属性就可以了(不过如果你用了其它theme的话, 要在加载这些theme之后再执行一遍下面这些配置,或者你把它们放在 org-mode-hook 中去执行):

(set-face-attribute 'org-level-1 nil :height 1.6 :bold t)
(set-face-attribute 'org-level-2 nil :height 1.4 :bold t)
(set-face-attribute 'org-level-3 nil :height 1.2 :bold t)))

5 org-mode与CUA的兼容性问题

https://github.com/mlf176f2/org-cua-dwim.el

虽然我不喜欢 cua-mode 里面的 C-c, C-x, C-v 等键,但 cua-mode 里面的 shift 选中,cua rectangle这些功能我还是比较喜欢的,所以我默认还是打开 cua-mode

不过 org-modecua-mode 不兼容,主要的问题是无法按住 Shift 来选择文本了( <S-up> <S-home> <S-prior> S-M-b 等)。

安装 org-cua-dwim 这个包即可解决这个问题。不过对于章节标题等特殊的地方,还是org-mode自己控制的。

6 两个与中文相关的问题

6.1 不关闭中文输入法,输入章节标题里面的星号

频繁打开/关闭输入法还是挺翻的,比如在连续输入章节或者列表项时,输入章节前面的 * 或者 列表项 前面的 * 或者 - 号,都要先关闭输入法,否则输入的是 ×

不过可以用下面的方法解决:

(defun org-mode-my-init ()
; ......
(define-key org-mode-map (kbd "×") (kbd "*"))
(define-key org-mode-map (kbd "-") (kbd "-"))
) (add-hook 'org-mode-hook 'org-mode-my-init)

6.2 中英文字体混排时的表格对齐问题

org-mode的表格功能还是比较酷的,用起来相当方便(比较大的缺点是不支持跨列或者跨行合并单元格,甚至简单 一点,表格的某一行实际两行来存放内容(就是类似html编辑器里面那种单元格自动折行的显示方式)也不行)。

对于中文用户来说,最容易碰到的一个问题是一旦表格中同时有中英文的话,表格会无法对齐,中文比较少的时候 还好,只会有一点点错位,但当中文比较多时,这个表格就乱成一团,没法看了。

(本图非本人制作,摘自: 让中英混杂的orgmode table对齐

这个问题困扰了很多人,大家也 折腾了各种方法。

首先是有人留意到,其实不仅仅是org-mode里面有问题,emacs本身在中英文混排时一个中文字符就跟两个英文字符 不是同样宽度的,除非有时碰巧了(比如当初我在Ubuntu下用Ubuntu Mono作为emacs默认字体时)。所以最开始我 一直在尝试各种字体,看哪种可以解决这个问题——但一直没有满意的方案,在一个机器上试验出来的结果在另外一 个系统上却不好使。最后发现是搞错了方向。

对于大部分的编辑器而言,我们只能选择一种字体(比如写代码常用的DejaVu Sans Mono, Inconsolata, Consolas),但这个字体中可能仅包含英文字符(或者也包含了其它拉丁字符),但大部分情况下不包含CJK字符, 对这种情况下对CJK字符的显示都是由系统来处理的,编辑器自己一般都不管。

不过Emacs毕竟是神的编辑器啊,它可以做到对不同体系的字符指定具体的字体,所以解决这个问题的办法是: 针 对中英文指定不同大小的字体,英文用小字,中文用大字 (别问我为什么,我是没去仔细研究。下面有一堆链接, 有兴趣的自己去看吧)。

(set-default-font "DejaVu Sans Mono 10")
(set-fontset-font "fontset-default" 'unicode"WenQuanYi Bitmap Song 12") ;;for linux
(set-fontset-font "fontset-default" 'unicode "宋体 12") ;; for windows

在你的环境上,你可能得对针对自己喜欢的编程字体去试验一下,看配哪个字号的中文字体(以及字号大小)可以 解决这个问题(或者可以试试下面的font.pl)。如果你还有日文、韩文什么的,可以详细地针对各种charset设定 字体(而不是像上面笼统地用 'unicode 来制定),详情请参看 折腾Emacs: 中文字体配置 | Emacs中文网

参考:

 

[emacs] org-mode的一些小技巧的更多相关文章

  1. mercurial的几个易用性小技巧

    其实这两年,能够采用mercurial的项目我都尽量用,甚至有些上游是git的,或者需要托管到公司内gitlab上与别人协作的,我都装上hg-git.无它,只是因为mercurial易用性比git好得 ...

  2. Visual Studio实用小技巧

    有一个有关微软Office的笑话,说的是它的特性太多: 当你觉得自己发现了一个Office的新特性时,它已经存在很多年了. 本文将介绍一些在Visual Studio(免费下载)中很实用却被忽略的小技 ...

  3. 前端网络、JavaScript优化以及开发小技巧

    一.网络优化 YSlow有23条规则,中文可以参考这里.这几十条规则最主要是在做消除或减少不必要的网络延迟,将需要传输的数据压缩至最少. 1)合并压缩CSS.JavaScript.图片,静态资源CDN ...

  4. Git小技巧 - 指令别名及使用Beyond Compare作为差异比较工具

    前言 本文主要写给使用命令行来操作Git的用户,用于提高Git使用的效率.至于使用命令还是GUI(Tortoise Git或VS的Git插件)就不在此讨论了,大家根据自己的的喜好选择就好.我个人是比较 ...

  5. 分享两个BPM配置小技巧

    1.小技巧 流程图修改后发布的话版本号会+1,修改次数多了之后可能会导致版本号很高,这个时候可以将流程导出,然后删除对应的流程包再导入,发布数据模型和流程图之后,版本清零 2.小技巧 有的同事入职后使 ...

  6. linux系统维护时的一些小技巧,包括系统挂载新磁盘的方法!可收藏!

    这里发布一些平时所用到的小技巧,不多,不过会持续更新.... 1.需要将history创建硬链接ln 全盘需要备份硬链接 ln /etc/xxx /home/xxx 2.root用户不可以远程 /et ...

  7. JS处理事件小技巧

    今天,就分享一下我自己总结的一些JS的小技巧: ①防止鼠标选中事件 <div class="mask" onselectstart="return false&qu ...

  8. iOS:小技巧(不断更新)

    记录下一些不常用技巧,以防忘记,复制用. 1.获取当前的View在Window的frame: UIWindow * window=[[[UIApplication sharedApplication] ...

  9. css小技巧(1)

    1.-webkit-overflow-scrolling: touch; 解决ios滑动时无缓冲问题 2.::-webkit-scrollbar 设置ios滑动时是否显示滚动条 3.::selecti ...

  10. 最强 Android Studio 使用小技巧和快捷键

    写在前面 本文翻译自 Android Studio Tips by Philippe Breault,一共收集了62个 Android Studio 使用小技巧和快捷键. 根据这些小技巧的使用场景,本 ...

随机推荐

  1. NET MVC全局异常处理(一) 【转载】网站遭遇DDoS攻击怎么办 使用 HttpRequester 更方便的发起 HTTP 请求 C#文件流。 Url的Base64编码以及解码 C#计算字符串长度,汉字算两个字符 2019周笔记(2.18-2.23) Mysql语句中当前时间不能直接使用C#中的Date.Now传输 Mysql中Count函数的正确使用

    NET MVC全局异常处理(一)   目录 .NET MVC全局异常处理 IIS配置 静态错误页配置 .NET错误页配置 程序设置 全局异常配置 .NET MVC全局异常处理 一直知道有.NET有相关 ...

  2. C++中的Thunk技术 / 非静态类成员函数作为回调函数 的实现方法

    原文:https://blog.twofei.com/616/ 用我的理解通俗地解释一下什么是C++中的Thunk技术吧! Thunk技术就是申请一段可执行的内存, 并通过手动构造CPU指令的形式来生 ...

  3. Android Studio 遇到 No Debuggable Applications 的解决方案

    一.在菜单的Tools -> Android -> 勾选 Enable ADB Integration 二.在工程的build.gradle(Module:app)里加上一行代码

  4. nginx location 配置详解 【转载,整理】

    http://www.nginx.cn/115.html NGINX location 配置参考:http://www.cnblogs.com/zlingh/p/6288994.html https: ...

  5. 增加一条新记录,同时返回其自增id

    方法一.是在Insert或Update触发器中用select来返回需要的字段值.默认情况下,当insert时,触发其insert触发器,它的默认返回值是影响到的行数,语句是:select @@rowc ...

  6. BUG处理流程说明

    一.        BUG处理流程图: 流程描述: 1.  测试人员发现bug提交给开发. 2.  开发人员判断是否是bug. 3.  如果是bug,进行修改,修改完成后更改bug状态为已解决. 4. ...

  7. django -- 为模式增加方法

    在django中模式中的方法是行级的.也就是说它操作是表里的行.不是整个表 一.模式定义: from django.db import models # Create your models here ...

  8. Feign请求中报错:Request header is too large 的解决方案。

    现在我们项目中都已迁入spring boot和spring cloud. 服务间调用现在都改成feign的调用方式,但是上次在实际使用过程中出现过:Request header is too larg ...

  9. js评价五星

    js评价五星 1.图片(star.png): 2.图片和html文件在同级目录 <html> <head> <script src="http://libs.b ...

  10. Java常考面试题(二)

    序言 昨天刚开始的”每日5题面试“这类文章,感觉还不错,把一些平常看似懂了的东西,弄清楚了.就像什么是虚拟机?这个问题,看起来知道,但是要说出个所以然来,又懵逼了,经常回过头来看看做过的面试题,试着用 ...