目录

以下内容为caii根据namespaces翻译。

命名空间

DokuWiki中,你可以使用命名空间对你的页面进行分类。

创建命名空间

你不需要独立地创建命名空间,只需简单地在页面名中使用冒号就可以创建。在最后一个冒号之后的语言符号(token)就是页面本身的名字,其他的语言符号都是命名空间。DokuWiki会自动创建页面用到的、不存在的所有命名空间。

例子:
example表示当前命名空间的“example”页面。
:example表示根部命名空间的“example”页面。
wiki:example表示命名空间“wiki”中的页面“example”。命名空间“wiki”位于根部命名空间之下。
ns1:ns2:example表示命名空间ns2中的“example”页面。命名空间ns2位于命名空间ns1下面;命名空间ns1位于根部命名空间下。
:ns1:ns2:example同上。
.ns1:ns2:example表示名命名空间ns2下的“example”页面。命名空间ns2位于命名空间ns1下面;命名空间ns1位于当前命名空间下。
.ns1:ns2:表示命名空间ns2的“开始”页面。命名空间ns2位于命名空间ns1下面;命名空间ns1位于当前命名空间下。

FIXME: 同样,[..namespace:] – 表示上级命名空间,——这应该记载在文档中。

删除命名空间

命名空间内的所有页面都被移除之时,该命名空间逻辑上不再存在。DokuWiki通常也会删除这个刚清空的文件夹。

如何重命名命名空间

你可以使用PageMove插件将每个页面从旧的命名空间移动到新的命名空间。请参考相关文档了解这是否满足你的需要。

手动的方式稍困难些:

例如,在Unix主机上,你可以:

要注意,对于非拉丁字符设置(例如希腊语、俄语等),需要编码 old_namespace 和/或 new_namespace 等词语。

但是,你依然留下大量无用信息,例如data/changes.log中、cache下的各种文件(包括.idx文件等)。如何困难,你可以按照下面的方法从空白状态开始(同样,在Unix下),要注意的时,这意味着丢失所有的历史信息(也就是最近修改):

我知道这很费解(可能我忘记/弄乱一些你认为应该做的事情)。所有的都是PITA。你可以使用一些可重建整个wiki的搜索索引、删除整个cache和/或旧版wiki从而避免手动操作的插件

命名空间默认链接

对于以冒号结尾的链接ID(linked)[[foo:bar:]],可能指向命名空间下的默认文件。 链接指向哪个页面,取决于所存在的特定名字的文件。对于[[foo:bar:]],会检测以下页面:

foo:bar:$conf['start']
foo:bar:bar
foo:bar

系统按照上面的顺序检测页面,并会链接到最先找到的页面。对于这些链接,不会在链接中检查多种格式(autoplural linking)。

:!: 这个特征仅在2006-09-28 RC1版或更新版上可用。