Skip to content
On this page

自动完成

UnoCSS 的自动完成工具:@unocss/autocomplete。这个工具已经嵌入到PlaygroundVS Code 扩展中。

使用方法

静态规则

像这样的静态规则不需要任何配置即可工作。

ts
rules: [['flex', { display: 'flex' }]]
rules: [['flex', { display: 'flex' }]]

动态规则

对于动态规则,您可以为规则提供额外的 meta 对象,并指定自动完成模板。

ts
rules: [
  [
    /^m-(\d)$/,
    ([, d]) => ({ margin: `${d / 4}rem` }),
    { autocomplete: 'm-<num>' } // <-- 这里
  ]
]
rules: [
  [
    /^m-(\d)$/,
    ([, d]) => ({ margin: `${d / 4}rem` }),
    { autocomplete: 'm-<num>' } // <-- 这里
  ]
]

模板使用简单的 DSL 来指定自动完成建议。语法如下:

  • (...|...):逻辑或组。使用 | 作为分隔符。当一些组匹配时将用作建议。
  • <...>:内置的快捷方式。目前支持 <num><percent><directions>
  • $...:主题推断。例如,$colors 将列出主题中 colors 对象的所有属性。

示例

示例 1

  • 模板(border|b)-(solid|dashed|dotted|double|hidden|none)
  • 输入b-do
  • 建议b-dottedb-double

示例 2

  • 模板m-<num>
  • 输入m-
  • 建议m-1m-2m-3...

示例 3

  • 模板text-$colors
  • 输入text-r
  • 建议text-redtext-rose...

示例 4

对于多个模板:

  • 模板['(border|b)-<num>', '(border|b)-<directions>-<num>']
  • 输入b-
  • 建议b-xb-yb-1b-2...
  • 输入b-x-
  • 建议b-x-1b-x-2...

License

Released under the MIT License.