欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ElementUI?$notify通知方法中渲染自定義組件實(shí)現(xiàn)

 更新時(shí)間:2023年06月13日 14:16:43   作者:天問  
這篇文章主要為大家介紹了ElementUI?$notify通知方法中渲染自定義組件實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

一、背景

ElementUINotification 組件通常用于全局的通知提醒消息,其中展示內(nèi)容默認(rèn)是文本字符串,當(dāng)然也可以設(shè)置 dangerouslyUseHTMLString: true 后傳入 HTML 片段。

如果要展示比較復(fù)雜的動(dòng)態(tài)內(nèi)容,一般會(huì)把傳入的內(nèi)容封裝成組件,而直接傳入組件是無法渲染的,本文就是解決 $notify 中怎么渲染自定義組件的問題。

Vue && Notification

最近開發(fā)項(xiàng)目遇到一個(gè)數(shù)據(jù)同步延遲的問題,就是在提交表單后,創(chuàng)建或編輯的操作不能馬上同步更新。最后討論的解決辦法就是在提交表單之后,前端輪詢一個(gè)獲取狀態(tài)的接口,并在全局展示一個(gè)進(jìn)度條,實(shí)時(shí)更新進(jìn)度,所以就使用了 Notification 組件。

二、問題解析

this.$notify 方法中有一個(gè) message 參數(shù),類型為 string/Vue.VNode。要想渲染一個(gè)自定義組件,關(guān)鍵就是要把自定義組件轉(zhuǎn)化為 Vue.VNode。

Vue全局提供了一個(gè) this.$createElement 方法就是專門干這個(gè)的,用法和 render 函數(shù)中參數(shù) createElement 一致 (createElement: () => VNode) => VNode。

三、具體實(shí)現(xiàn)

  • 根組件 App.vue
<template>
  <div>content</div>
</template>
<script>
  import ProgressBar from '@/components/ProgressBar'
  export default {
    // 注冊自定義組件
    components: {
      ProgressBar,
    },
    data() {
      return {
        progress: 1,
        hiveData: {},
      }
    },
    methods: {
      showProgress () {
        const h = this.$createElement
        this.notifyInstance = this.$notify({
          title: '數(shù)據(jù)處理進(jìn)度',
          duration: 0,
          dangerouslyUseHTMLString: true,
          message: h('ProgressBar', { // 使用自定義組件
            ref: 'progressBar',
            props: {
              progress: this.progress,
              ...this.hiveData,
            },
          }),
        })
      },
      setProgressVal() {
        this.$refs.progressBar &&
        this.$refs.progressBar.setProgress(this.progress)
      },
    }
  }
</script>
  • 自定義組件 ProgressBar.vue
<template>
  <div class="global-bar">
    <div class="global-bar-label">庫名:【{{ dbName }}】</div>
    <div class="global-bar-label">表名:【{{ tableName }}】</div>
    <el-progress
      :text-inside="true"
      :stroke-width="16"
      :percentage="progress"
      :color="colors"
    ></el-progress>
    <br />
    <el-alert
      title="關(guān)閉或刷新后不再顯示提交進(jìn)展,請勿關(guān)閉或刷新。"
      type="warning"
      :closable="false"
      show-icon
    >
    </el-alert>
  </div>
</template>
<script>
export default {
  props: {
    dbName: {
      type: String,
      default: '',
    },
    tableName: {
      type: String,
      default: '',
    },
  },
  data() {
    return {
      progress: 1,
      colors: [
        { color: '#f56c6c', percentage: 20 },
        { color: '#e6a23c', percentage: 40 },
        { color: '#6f7ad3', percentage: 60 },
        { color: '#1989fa', percentage: 80 },
        { color: '#5cb87a', percentage: 100 },
      ],
      hiveData: {},
    }
  },
  methods: {
    setProgress(progress) {
      this.progress = progress
    },
  },
}
</script>
  • 注意h() 方法的第一個(gè)參數(shù)要么是原生標(biāo)簽名,如:div、p、span、h1等,要么就是 components 中注冊過的自定義組件名,否則無法正常渲染。

以上就是ElementUI $notify通知方法中渲染自定義組件實(shí)現(xiàn)的詳細(xì)內(nèi)容,更多關(guān)于ElementUI $notify自定義組件的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評論