LaTeX2e类和包的设计(三)

简介: LaTeX2e类和包的设计(三) 1)User-defined commands用户自定义命令 可以在LaTeX下用命令定义新命令或重定义命令。 定义新命令: /newcommand{/com_name}[narg][opt]{def} 重新定义命令: /renewcommand{/com_name}[narg][opt]{def} 命令/newcommand用来定义一条新命令;命令/renewcommand用来重定义一条已存在的命令。

LaTeX2e类和包的设计(三)


1)User-defined commands用户自定义命令
可以在LaTeX下用命令定义新命令或重定义命令。
定义新命令:
/newcommand{/com_name}[narg][opt]{def}
重新定义命令:
/renewcommand{/com_name}[narg][opt]{def}
命令/newcommand用来定义一条新命令;命令/renewcommand用来重定义一条已存在的命令。
narg:指定新命令或重定义的命令带有多少个参数,从1到9取值;
如果调用了不正确的变量,会产生一个错误。
opt:给出了新命令在缺省情况下带有的可选参数。
def:是命令的实际定义。

1.1)Commands without arguments不带参数的命令
我们先来说明/newcommand不带参数的情况。当LaTeX有一个固定的组合或用户命令经常用它自身的名字重复使用时,应用它。
例如:X1,...,Xn的结构,我们可以定义一条命令来表示这种结构。
/newcommand{/xvec}{x_1,/ldots,x_n}
当调用/xvec时,将插入已定义的命令和文本序列来处理。
要注意的是,实际使用是$/xvec$,它需要在数学环境中。故我们可以这样定义它,
/newcommand{/xvec}{$x_1,/ldots,x_n$}
就能在一般场合下使用了。
还可以这样定义,
/newcommand{/xvec}{/ensuremath{x_1,/ldots,x_n}}
它同时允许/xvec和$/xvec$使用,产生同样的结果。
如果想在/xvec使用后输出一个空格,以便跟其它内容分隔开,则命令可以这样定义:
/newcommand{/xvec}{/ensuremath{x_1,/ldots,x_n}/xspace}
xspace包专门用来产生一个空格。
如果不清楚一个命令的名字是否已经存在时,可以用如下的定义:
/providecommand{/com_name}[narg][opt]{def}
它的语法与/newcommand和/renewcommand的语法相同。不同的是,如果命令存在的话,此新定义将会被忽略。
例子:
/newcommand{/thechapter}{/arabic{chapter}}
/newcommand{/thesection}{/thechapter./arabic{section}}
/newcommand{/thesubsection}{/thesection./arabic{subsection}}

1.2)Commands with arguments带参数的命令
在上例中,如果有Y1,...,Yn或者Z1,...,Zn的组合时,又该如何定义命令让它满足呢?我们可以定义/yvec和/zvec,但是这过于麻烦。我们可以考虑用一个参数来实现它。这个参数可以代表字母x,y,z等等。如下:
/newcommand{/avec}[1]{/ensuremath{#1_1,/ldots,#1_n}}
这样,我们想输入X1,...,Xn的结构时可以用/avec{X},想输入y1,...,yn的结构时可以用/avec{y}等等。#1就是那个参数的替代。
如果要输入U1,...,Um的结构时,可以用两个参数,如下:
/newcommand{/anvec}[2]{/ensuremath{#1_1,/ldots,#1_#2}}
同理,三个参数的情况:
/newcommand{/subvec}[3]{/ensuremath{#1_#2,/ldots,#1_#3}}
则我们通过调用/subvec{a}{i}{j}可以产生ai,...,aj。
注:当超过一个参数时,参数必须被封装在{}内。

1.3)Commands with an optional argument带一个可选参数的命令
正如我们所见,许多LaTeX命令带有一个可选参数,包括/newcommand命令。如下:
/renewcommand{/subvec}[3][x]{/ensuremath{#1_{#2},/ldots,#1_{#3}}}
即,它默认第一个参数为x,当你输入/subvec{i}{j}将打印xi,...,xj;当你输入/subvec{a}{i}{j}时,将打印ai,...,aj。

1.4)附加的一些例子
example 1:
/newcommand{/latop}[2]{{#1} /atop {#2}}
/newcommand{/lchoose}[2]{{#1} /choose {#2}}
example 2:
/newlength{/wdth}
/newcommand{/defbox}[1]{/settowidth{/wdth}{#1}}
/newcommand{/textbox}[1]{/framebox[/wdth]{#1}}
example 3:
/newcounter{myfn}[page]
/renewcommand{/thefootnote}{/fnsymbol{footnote}}
/newcommand{/myftnote}[1]{/setcounter{footnote}{/value{myfn}}%
 /footnote{#1}/stepcounter{myfn}}
example 4:
建立命令/alpheqn,一旦它被调用,等式序列将保持同样的数,但是它紧跟的字母a,b将不断增加,且用-符号隔开。命令/reseteqn保存初始的数字。因此产生的序列可以为4,5,6-a,6-b,7。
/newcounter{saveeqn}
/newcommand{/alpheqn}{/setcounter{saveeqn}{/value{equation}}%
 /stepcounter{saveeqn}/setcounter{equation}{0}%
 /renewcommand{/theequation}%
  {/mbox{/arabix{saveeqn}-/alph{equation}}}}
/newcommand{/reseteqn}{/setcounter{equation}{/value{saveeqn}}%
 /renewcommand{/theequation}{/arabic{equation}}}

1.5)Conditional text带条件的文本
我们引入ifthen宏包,如下:
/usepackage{ifthen}
它带有两条命令,如下:
/ifthenelse{test}{then_text}{else_text}
测试test,如果为真,执行then_text语句;如果为假,执行else_text。
/whiledo{test}{do_text}
测试test,为真则执行do_text语句,为假则不执行。
例子:
/newcommand{/three}{3}
/ifthenelse{/three =3}{OK}{what?}
/ifthenelse{/value{page}

2)User-defined environments用户自定义环境
可以用命令来创建或改变环境
/newenvirenment{env-name}[narg][opt]{beg_def}{end_def}
/renewenvirenment{env-name}[narg][opt]{beg_def}{end_def}
env-name: 环境的名称,在/newenvirenment中,它不同于任何已存在的环境名或命令名;而在/renewenvirenment;它必须是已经存在的环境名。
narg:从1到9的一个数,用于声明环境带有多少个参数;如果省略的话,默认为0个参数。
opt:默认为第一个可选项的名字。
beg_def:当/begin{env-name}开始时要调用的插入内容;如果带参数,则环境开始时,调入/begin{env-name}{arg_1}...{arg_n}
end_def:环境结束时的插入内容。

4)Envirenments without arguments
正如用户自定义命令一样,我们先来解释不带参数的环境。用以下命令创建:
/newenvirenment{sitquote}{/begin{quote}/small/itshape}{/end{quote}}
它设置了文本在/begin{sitquote}和/end{sitquote}之间以规定的/small/itshape形式显示。
注意:/small/itshape会在整个环境中持续生效。
看下面的例子:
/newcounter{com}
/newenvironment{comment}
{/noindent/slshape Comment: /begin{quote}/small/itshape}
{/stepcounter{com}/hfill(/arabic{com})/end{quote}}

目录
相关文章
C++奥特曼打怪兽系列
C++奥特曼打怪兽系列
377 0
|
小程序
【亲测有效】支持横竖屏 微信小程序video禁止进度条拖动,微信小程序遮罩进度条,
【亲测有效】支持横竖屏 微信小程序video禁止进度条拖动,微信小程序遮罩进度条,
496 1
【亲测有效】支持横竖屏 微信小程序video禁止进度条拖动,微信小程序遮罩进度条,
|
TensorFlow 算法框架/工具 Python
识别图像
【7月更文挑战第29天】识别图像。
250 8
|
XML JSON 安全
【电子数据交换EDI】AS2协议
云捷易EDI是基于开源Mule内核、预置对接主流内部系统适配器的电子数据交换系统,为企业用户提供上下游企业间安全数据交换的服务。
1474 0
【电子数据交换EDI】AS2协议
|
前端开发 Java 中间件
OpenFeign 服务调用过程中实现 header 数据透传 | Java Debug笔记
OpenFeign 服务调用过程中实现 header 数据透传 | Java Debug笔记
2080 0
|
消息中间件 分布式计算 NoSQL
数据处理平台架构中的SMACK组合:Spark、Mesos、Akka、Cassandra以及Kafka
在今天的文章中,我们将着重探讨如何利用SMACK(即Spark、Mesos、Akka、Cassandra以及Kafka)堆栈构建可扩展数据处理平台。虽然这套堆栈仅由数个简单部分组成,但其能够实现大量不同系统设计。除了纯粹的批量或者流处理机制之外,我们亦可借此实现复杂的Lambda以及Kappa架构。
9003 0
|
网络协议
协议森林10 魔鬼细节 (TCP滑窗管理)
作者:Vamei 出处:http://www.cnblogs.com/vamei 严禁任何形式转载。   在TCP协议与"流"通信中,我们建立了滑窗(sliding window)的基本概念。通过滑窗与ACK的配合,我们一方面实现了TCP传输的可靠性,另一方面也一定程度上提高了效率。
969 0
|
2天前
|
云安全 人工智能 自然语言处理
AI说的每一句话,都靠谱吗?
阿里云提供AI全栈安全能力,其中针对AI输入与输出环节的安全合规挑战,我们构建了“开箱即用”与“按需增强”相结合的多层次、可配置的内容安全机制。