vue中cdn引入element-ui 如何在其他js中引入element-ui

vue-cli

index.html中采用 cdn 引入 element

<link rel="stylesheet" href="https://unpkg.com/element-ui@2.3.7/lib/theme-chalk/index.css">
<script src="https://cdn.bootcss.com/vue/2.5.2/vue.min.js"></script>
<script src="https://cdn.bootcss.com/vue-router/3.0.1/vue-router.min.js"></script>
<script src="https://cdn.bootcss.com/axios/0.18.0/axios.min.js"></script>
<script src="https://cdn.bootcss.com/vue-i18n/7.6.0/vue-i18n.min.js"></script>
<script src="https://unpkg.com/element-ui@2.3.7/lib/index.js"></script>

webpack.base.conf.js 中代码如下

externals: {
    'vue': 'Vue',
    'vue-router': 'VueRouter',
    'axios': 'axios',
    'element-ui': 'element-ui',
    'i18n': 'i18n',
},

现在想在自己写的js中使用element组件该怎么引用

import {Message} from 'element-ui'
Message(123);

这样用Message会报external "element-ui"?c60b:1 Uncaught ReferenceError: element is not defined错误

谢谢

阅读 35.3k
9 个回答

cdn 版本的 element-ui 设置的全局变量是 ELEMENT

externals: {
  'element-ui': 'ELEMENT',
}

修改配置后还是提示Element未定义,是因为Element依赖Vue,vue.js需要在element-ui之前引入,所以vue.js也要改为cnd的引入方式

请问大佬解决了吗

新手上路,请多包涵

您好,为什么这样改完之后还是会报错呢?

ELEMENT is not defined
新手上路,请多包涵

使用cdn引入vue 和 element-ui 后,main.js中应该是什么样?

webpack.base.conf.js

externals:{

'vue': 'Vue',
'vue-router': 'VueRouter',
'axios':'axios',
'element-ui': 'ELEMENT'

},

//你要用的js
ELEMENT.Message({

showClose: true,
message: response.data.msg,
type: "error"

});

 externals: {
    vue: 'Vue',
    'element': 'element-ui'
  },

请问一下,在externals中定义的都会报undefined,是需要在webpack.base.conf.js引入定义的那些吗?

新手上路,请多包涵
externals: {
    'vue': 'Vue',
    'vue-router': 'VueRouter',
    'vuex': 'Vuex',
    'element-ui': 'ELEMENT',
   },
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
1 篇内容引用
推荐问题
宣传栏