【区分vue2和vue3下的element UI Result 结果组件,分别详细介绍属性,事件,方法如何使用,并举例】

在 Vue 2 中,Element UI 并没有直接提供名为 Result 的组件。但是,在 Vue 3 的 Element Plus 中,Result 组件是用来展示操作结果或状态信息的。

以下是 Element Plus 中 Result 组件的详细介绍,以及如何在 Vue 3 中使用它。由于 Vue 2 没有该组件,我将只介绍 Vue 3 下的使用。

Vue 3 + Element Plus 中的 Result 组件

属性 (Attributes)
  • title: 标题文本,可选。
  • subTitle: 副标题文本,可选。
  • icon: 图标名称或图片 URL,可选。
  • iconClass: 图标类名,可选,当使用自定义图标时使用。
  • status: 结果状态,可选值有 'success', 'error', 'warning', 'info',不同状态会有不同的默认图标和颜色。
  • extra: 额外的内容,通常是一个按钮或者链接,可选。
插槽 (Slots)
  • default: 默认插槽,用于插入自定义内容。
事件 (Events)

Element Plus 的 Result 组件通常不直接触发事件,因为它主要用于展示信息,而不是与用户交互。但是,你可以在其 extra 插槽中添加按钮或其他可交互组件,并为这些组件添加事件监听器。

方法 (Methods)

Result 组件不直接提供方法,因为它是一个静态的展示组件。但是,你可以通过 Vue 的响应式数据来动态控制其内容。

示例
vue 复制代码
<template>
  <el-result
    :title="title"
    :subTitle="subTitle"
    :status="status"
    icon="el-icon-success"
  >
    <template #extra>
      <el-button type="primary" @click="handleAction">返回首页</el-button>
    </template>
  </el-result>
</template>

<script>
import { ref } from 'vue';
import { ElResult, ElButton } from 'element-plus';

export default {
  components: {
    ElResult,
    ElButton
  },
  setup() {
    const title = ref('操作成功');
    const subTitle = ref('请求已经发送成功');
    const status = ref('success');

    const handleAction = () => {
      // 处理点击事件,比如跳转到首页
      console.log('点击了返回首页按钮');
    };

    return {
      title,
      subTitle,
      status,
      handleAction
    };
  }
};
</script>

在这个示例中,我们使用了 Vue 3 的 Composition API (setup 函数) 来定义响应式数据和方法。我们为 Result 组件提供了 titlesubTitlestatusicon 属性,并在 extra 插槽中添加了一个 el-button 组件,为其添加了点击事件监听器 handleAction。当用户点击按钮时,控制台将输出一条消息。

相关推荐
陈陈爱java16 小时前
Spring八股文
开发语言·javascript·数据库
@大迁世界17 小时前
用 popover=“hint“ 打造友好的 HTML 提示:一招让界面更“懂人”
开发语言·前端·javascript·css·html
烛阴17 小时前
【TS 设计模式完全指南】用工厂方法模式打造你的“对象生产线”
javascript·设计模式·typescript
定栓17 小时前
Typescript入门-类型断言讲解
前端·javascript·typescript
xiaominlaopodaren17 小时前
“UI里就可以请求数据库”,让你陌生的 React 特性
前端·javascript·react.js
薛定谔的算法17 小时前
JavaScript数组操作完全指南:从基础到高级
前端·javascript·算法
用户221520442780017 小时前
Promise实例方法和async、await语法糖
前端·javascript
前端开发爱好者17 小时前
下一代全栈框架:Deno + Vite 的结合体!
前端·javascript·后端
CUGGZ18 小时前
前端部署,又有新花样?
前端·javascript
Zz_waiting.18 小时前
Javaweb 14.4 Vue3 视图渲染技术
前端·javascript·vue.js