Vue3导入Elementplus时组件无法加载的情况

在使用Vue3结合Elementplus做组件导入时,出现了组件无法显示,只在网页中出现了组建template中涉及ui中的相关字符串,或者页面中完全没有显示的情况。

经排错,是由于main.js文件中完整导入时,自作主张将Vue3自带的生成段和ElementPlus提供的部分注册段结合了。

app.use(ElementPlus)
createApp(App).mount('#app')

严格按照ElementPlus提供的写法

const app = createApp(App)

app.use(ElementPlus)
app.mount('#app')

 即可顺利显示组件。

倒推后提出猜想:

上面一种写法中app的声明是ElementPlus注册之后才创建的,也就是说Element注册被调用时,注册到了一个还没有产生,并不存在的“app”上,这样的注册显然是空的无效的。而后产生的app也不会被之前的注册影响。

后一种写法,在创建完app后,先将Element注册于其上,再mount进App.vue中,这就保证了app注册进Vue主文件中时,一定是注册好Element的。

这个案例提供的思考应该不仅限于此,可以说,Vue3 CLI自带的main.js虽然简化了app全局注册的写法,但是在需要注册其他绑定app的依赖时,都需要采用后者的写法。

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
好的,关于ElementPlus的拖拽组件问题,我可以为您提供一些帮助。 首先,ElementPlus提供了Draggable 拖拽组件,它可以让你轻松实现拖拽效果。使用Draggable组件,你需要在父组件中引入它并设置需要拖拽的子组件,如下所示: ```html <template> <el-container> <el-header>Header</el-header> <el-main> <draggable v-model="list"> <el-card v-for="item in list" :key="item.id">{{ item.name }}</el-card> </draggable> </el-main> </el-container> </template> <script> import { Draggable } from 'element-plus'; export default { components: { Draggable, }, data() { return { list: [ { id: 1, name: 'Card 1' }, { id: 2, name: 'Card 2' }, { id: 3, name: 'Card 3' }, { id: 4, name: 'Card 4' }, ], }; }, }; </script> ``` 上述代码中,我们使用了ElementPlus的el-card组件作为需要拖拽的子组件,然后使用v-for指令渲染了list数组中的数据。使用Draggable组件,我们需要将要拖拽的子组件放在Draggable组件的内部。 另外,为了能够进行拖拽,我们需要给需要拖拽的子组件添加一个class,如下所示: ```html <el-card v-for="item in list" :key="item.id" class="draggable-item">{{ item.name }}</el-card> ``` 然后,在CSS中为这个class设置一个cursor属性,如下所示: ```css .draggable-item { cursor: move; } ``` 这样,用户鼠标移动到该组件,就会显示出一个可拖拽的图标。 以上是ElementPlus拖拽组件的基本使用方法,希望对您有所帮助。如果您还有其他问题,请随提出。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值