Vue3 中 Element-Plus 引入 ElLoading 并修改颜色

Vue3 中 Element-Plus 引入 ElLoading 并修改颜色

安装:

# NPM
$ npm install element-plus --save

# Yarn
$ yarn add element-plus

# pnpm
$ pnpm install element-plus

引入:

// main.ts
import { createApp } from 'vue'
import ElementPlus from 'element-plus' // 引入 ElementPlus
import 'element-plus/dist/index.css' // 引入 ElementPlus 核心 css
import App from './App.vue'

const app = createApp(App)

app.use(ElementPlus) // 挂载 app
app.mount('#app')

使用:

<template>
  <el-table
    v-loading="loading"
    element-loading-text="Loading..."
    :element-loading-spinner="svg"
    element-loading-svg-view-box="-10, -10, 50, 50"
    element-loading-background="rgba(122, 122, 122, 0.8)"
    :data="tableData"
    style="width: 100%"
  >
    <el-table-column prop="date" label="Date" width="180" />
    <el-table-column prop="name" label="Name" width="180" />
    <el-table-column prop="address" label="Address" />
  </el-table>
  <el-table
    v-loading="loading"
    :element-loading-svg="svg"
    class="custom-loading-svg"
    element-loading-svg-view-box="-10, -10, 50, 50"
    :data="tableData"
    style="width: 100%"
  >
    <el-table-column prop="date" label="Date" width="180" />
    <el-table-column prop="name" label="Name" width="180" />
    <el-table-column prop="address" label="Address" />
  </el-table>
</template>

<script lang="ts" setup>
import { ref } from 'vue'

const loading = ref(true)
const svg = `
        <path class="path" d="
          M 30 15
          L 28 17
          M 25.61 25.61
          A 15 15, 0, 0, 1, 15 30
          A 15 15, 0, 1, 1, 27.99 7.5
          L 15 15
        " style="stroke-width: 4px; fill: rgba(0, 0, 0, 0)"/>
      `
const tableData = [
  {
    date: '2016-05-02',
    name: 'John Smith',
    address: 'No.1518,  Jinshajiang Road, Putuo District',
  }
]
</script>
<style>
.example-showcase .el-loading-mask {
  z-index: 9;
}
</style>

修改颜色(Icon 和 文字):

建议写到 App.vue 全局更换 Loading 加载样式。也可以单页面使用。本人写到了 App.vue 中

// App.vue

<style lang="less" scoped>
.el-loading-spinner .path {
  -webkit-animation: loading-dash 1.5s ease-in-out infinite;
  animation: loading-dash 1.5s ease-in-out infinite;
  stroke-dasharray: 90, 150;
  stroke-dashoffset: 0;
  stroke-width: 4;
  stroke-linecap: round;
  stroke:#fd2957!important;
}
.el-loading-spinner .el-loading-text {
  color: #fd2957!important;
  margin: 3px 0;
  font-size: 14px;
}
</style>
  • 12
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Vue3可以通过以下步骤引入element-plus: 1. 安装element-plus:可以使用npm或yarn进行安装,例如: ``` npm install element-plus --save ``` 2. 在main.js引入element-plus: ``` import { createApp } from 'vue' import App from './App.vue' import ElementPlus from 'element-plus' import 'element-plus/lib/theme-chalk/index.css' const app = createApp(App) app.use(ElementPlus) app.mount('#app') ``` 3. 在组件使用element-plus的组件,例如: ``` <template> <el-button>按钮</el-button> </template> <script> export default { name: 'MyComponent' } </script> ``` 在这个例子,我们使用了element-plus的按钮组件。 ### 回答2: Vue 3是当前最新的Vue版本,它带来了一些新的变化和改进。随着新版本的发布,许多Vue的插件也相继更新和升级,其最受欢迎的莫过于Element-UI。今天我们要讨论的是,Vue 3引入Element-Plus的原因以及它的特点和优势。 Element-UI是Vue社区最著名的开源UI库之一,它提供了许多符合人性化的组件,例如按钮、表格、表单等等。Element-UI在Vue 2的时代广受欢迎,许多开发者都喜欢使用Element-UI来构建他们的应用程序界面。随着Vue 3的发布,很多开发者非常期待Element-UI能够尽快推出Vue 3的版本,以便使用最新的Vue特性来提高应用程序的性能。 Element-Plus的出现正是为了满足这个需求,它是Element-UI的升级版,支持Vue 3和Composition API。它保留了Element-UI的所有优点,同时呈现新的特性和改进。下面是介绍Element-Plus的主要特点: 1. 支持Vue 3和Composition API:Element-Plus在设计时考虑了Vue 3的新特性,并支持全新的Composition API,可以帮助开发者更好地组织他们的代码。 2. 更好的性能:通过使用Vue 3的新特性,例如Proxy和Tree-shaking,Element-Plus实现了更好的性能和更小的代码体积。 3. 规模化扩展:Element-Plus提供了许多新的组件,例如Avatar、Badge、Loading等等,这使得在大型项目使用Element-Plus变得更加容易。 4. 更好的主题支持:Element-Plus提供了更加灵活的主题和色彩方案,可以帮助开发者更好地自定义他们的应用程序。 5. 全局组件注册:Element-Plus在设计时考虑到了Vue 3的新特性,可以通过defineAsyncComponent、defineComponent等全局API来注册组件,从而提高了性能和维护性。 总的来说,Vue 3引入Element-Plus是件好事。Element-Plus既保留了Element-UI的所有优点,同时采用了许多Vue 3的新特性,从而提供了更好的性能和更好的可扩展性。对于Vue 3的开发者而言,使用Element-Plus可以简化他们的开发任务,提高效率。 ### 回答3: Vue 3引入Element Plus,这是一个非常值得期待的举措。Element Plus是一个非常受欢迎的Vue 2组件库,拥有丰富的UI组件和强大的功能,这使得Element Plus不仅在国内,更在全球范围内受到开发者的喜爱,并且广泛应用于各种应用。随着Vue 3的发布,Element Plus也随之进行了升级,并补充了与Vue 3相容的新特性。Vue 3的发布具有向下兼容性,这使得为Vue 2设计的组件库需要进行适配,而引入Element Plus则可以省略这一步,因为它已经在Vue 3下进行了优化适配,这将使得开发者更加方便快捷的开发出基于Vue 3的应用。 除此之外,Element Plus支持TypeScript,这是一种强类型语言。TypeScript提供了许多语言特性,例如类型推导、装饰器等,这些都可以使开发人员更加轻松地编写代码和进行调试,降低了代码的错误率,从而提高了开发效率。 另外,由于Vue 3的性能优化和响应式系统的升级,Element Plus具有更快的渲染速度和更小的组件体积,这为开发者提供了更好的用户体验。此外,Element Plus也为Vue 3提供了更多的选择,使得开发人员拥有更多的选择来构建一个高品质的Web应用程序。 总而言之,Vue 3引入Element Plus是一个非常好的决策。通过这样的操作,使得Element Plus得以兼容Vue 3,并添加新特性,同时也提供了更好的性能和更好的用户体验。这将为开发人员提供更好的开发体验和更好的组件选择,使得开发人员更容易地构建出优质的Web应用程序。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值