Vue按需引入Ant Design的一些问题(采坑)

无道 2020-05-20 0 条评论 编程相关 阅读105 手机阅读

1. 前言

为什么就不能友好点呢?程序员就到出采坑...

关于Element UI的按需引入请看这(也是坑):https://www.misiai.com/articles/16.html

安装ant design就不说了:

npm i --save ant-design-vue

2. 正文

2.1. 安装less

npm install less less-loader # ant design for vue使用less,所以需要安装less less-loader的相关配置

不然会报错找不到less模块和loader

2.2. 提取出引入模块

言下之意就是把引入这些组件写到专门的一个js配置文件里面:

config\AntDesign.js

import {Button, message} from 'ant-design-vue';

const ant = {
    install: function (Vue) {
        Vue.use(message);
        Vue.component(Button.name, Button);
        Vue.prototype.$message = message;
    }
};
export default ant

然后在main.js中引入:

// 引入vue ant design
import ant from "./config/AntDesign";
Vue.use(ant);

2.3. babel设置

1、安装按需引入的插件:

npm install babel-plugin-import --dev

2、配置

babel.config.js文件中:

module.exports = {
    presets: [
        '@vue/cli-plugin-babel/preset'
    ],
    plugins: [
        [
            "import",
            {libraryName: "ant-design-vue", libraryDirectory: "es", style: true}
        ]
    ]
}

2.4. 需要开启javascriptEnabled

不然会报错:

Inline JavaScript is not enabled. Is it set in your options?

vue-cli3.x解决办法是:新建vue.config.js文件,写入:

module.exports = {
    css: {
        loaderOptions: {
            less: {
                javascriptEnabled: true
            }
        }
    }
}
全文完 [
有帮助?打赏
支付宝打赏
微信打赏
]
标签: vue ant design
修改: 05月20日 09:31
这篇文章还没有评论呢~
点击刷新/生成验证码