Vue插件之ElementPlus

标签: 无 分类: 未分类 创建时间:2021-10-18 14:12:19 更新时间:2023-10-20 11:23:26

ElementPlus 是element团队,基于Vue3.0重写的element组件

1.安装

1
2
3
4
5
6
## yarn
yarn add element-plus


# pnpm
$ pnpm install element-plus
参考文章:
1.安装

1.Can’t resolve ‘fonts/element-icons.woff’

在我第一次使用vue3.0和ElementPlus时,遇到了这个问题。

当我找到 node_modules\element-plus\dist\fonts 路径下的时候,发现还真是没有element-icons.woff 这个文件,文件在下一层了,因为fonts文件夹下,还有一层fonts文件

所以才会找不到这个woff文件。不知道是不是bug,这么明显的错误看不出来吗?难道是我的安装方法不对吗?

2.无法渲染组件

我用最简单的全局引入的方式进行element plus 的引入,最后即便是写了下面的简单的代码,还是没有东西渲染出来。

1
2
3
<template>
<el-button type="danger" icon="el-icon-delete" circle></el-button>
</template>

我的代码其实特别的简单,就是使用 yarn 安装了element-plus

1
2
## 安装
yarn add element-plus -S

然后在main里面引入全局 ElementPlus ,最后随便在一个页面中,加入上面的代码el-button,结果就是各种出不来,最后渲染html的地方都被用 — 注释掉了,实在不知道为什么啊。

1
2
3
4
5
6
7
8
9
10
11
12
13
import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'
/** 引入element组件 */
import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'

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

3.Component is missing template or render function

组件渲染不出来,但是提示了这个警告。

后来找到了,这个 1.1.0-beta.21 版本,应该是一个 bug 版本。

4.滚动条

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
<template>
<div class="info-wrap">
<div class="name">{{currAttr.JZMC}}</div>
<el-scrollbar style="height: 200px;" class="scroll-wrap" ref="scrollbar">
</el-scrollbar>
</div>
</template>

<script>

export default {
setup(){
const scrollbar = ref(); // scrollbar是页面ref后面对应的名字
// 组件挂载时执行
onMounted(()=>{
nextTick(()=>{
// 监听鼠标滚轮事件,禁止冒泡,解决高德info穿透的bug
let scrollWrap=scrollbar.value.scrollbar;
scrollWrap.addEventListener("wheel",function(e){
e.stopPropagation();
return false;
})
})
});

return {
scrollbar,
}
}
}

</script>

5.按需导入

实现自动引入组件和样式
1.安装插件

1
2
## 安装自动引入插件
pnpm add -D unplugin-vue-components unplugin-auto-import

2.配置vite

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
// vite.config.ts
import { defineConfig } from 'vite'
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { ElementPlusResolver } from 'unplugin-vue-components/resolvers'

export default defineConfig({
// ...
plugins: [
// ...
AutoImport({
resolvers: [ElementPlusResolver()],
}),
Components({
resolvers: [ElementPlusResolver()],
}),
],
})

3.引用
使用的时候,直接使用就可以了,不需要再import进行导入组件和样式

1
<el-button>

如果使用 import 手动导入,还需要手动导入相关的样式。

1
2
import { ElButton } from 'element-plus'
import 'element-plus/es/components/button/style/css'
参考文章:
1.Element Plus 如何按需引入和自动导入?解决非标签元素丢失样式的问题
2.快速开始
3.实现自动引入+按需引入element-plus原来如此简单 使用unplugin-vue-components后,可以实现按需引入,而且也不用再使用import引入需要的组件,直接使用等组件就可以。
4.unplugin-element-plus
小额赞助
本人提供免费与付费咨询服务,感谢您的支持!赞助请发邮件通知,方便公布您的善意!
**光 3.01 元
Sun 3.00 元
bibichuan 3.00 元
微信公众号
广告位
诚心邀请广大金主爸爸洽谈合作
每日一省
isNaN 和 Number.isNaN 函数的区别?

1.函数 isNaN 接收参数后,会尝试将这个参数转换为数值,任何不能被转换为数值的的值都会返回 true,因此非数字值传入也会返回 true ,会影响 NaN 的判断。

2.函数 Number.isNaN 会首先判断传入参数是否为数字,如果是数字再继续判断是否为 NaN ,不会进行数据类型的转换,这种方法对于 NaN 的判断更为准确。

每日二省
为什么0.1+0.2 ! == 0.3,如何让其相等?

一个直接的解决方法就是设置一个误差范围,通常称为“机器精度”。对JavaScript来说,这个值通常为2-52,在ES6中,提供了Number.EPSILON属性,而它的值就是2-52,只要判断0.1+0.2-0.3是否小于Number.EPSILON,如果小于,就可以判断为0.1+0.2 ===0.3。

每日三省
== 操作符的强制类型转换规则?

1.首先会判断两者类型是否**相同,**相同的话就比较两者的大小。

2.类型不相同的话,就会进行类型转换。

3.会先判断是否在对比 null 和 undefined,是的话就会返回 true。

4.判断两者类型是否为 string 和 number,是的话就会将字符串转换为 number。

5.判断其中一方是否为 boolean,是的话就会把 boolean 转为 number 再进行判断。

6.判断其中一方是否为 object 且另一方为 string、number 或者 symbol,是的话就会把 object 转为原始类型再进行判断。

每日英语
Happiness is time precipitation, smile is the lonely sad.
幸福是年华的沉淀,微笑是寂寞的悲伤。