自定义命名空间 2.2.0
TIP
我们提供了 setaria-components-vite-starter 模版。 查看代码了解使用方法。
Element Plus 提供的默认命名空间为 el
。 在特殊情况下,我们需要自定义命名空间。
由于我们使用 sass 书写样式,如果您需要自定义所有命名空间, 我们假定用户使用了 sass 书写样式。
您必须同时设置 ElConfigProvider
和 scss $namespace
。
设置 ElConfigProvider
使用 ElConfigProvider
包装您的根组件。
<!-- App.vue -->
<template>
<el-config-provider namespace="ep">
<!-- ... -->
</el-config-provider>
</template>
设置 SCSS 和 CSS 变量
创建 styles/element/index.scss
:
// styles/element/index.scss
// we can add this to custom namespace, default is 'el'
@forward 'setaria-components/theme-chalk/src/mixins/config.scss' with (
$namespace: 'ep'
);
// ...
在 vite.config.ts
中导入 styles/element/index.scss
:
Webpack也是如此,它需要在
preprocessorOptions
中设置。
import { defineConfig } from 'vite'
// https://vitejs.dev/config/
export default defineConfig({
// ...
css: {
preprocessorOptions: {
scss: {
additionalData: `@use "~/styles/element/index.scss" as *;`,
},
},
},
// ...
})
就这么简单。