中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue如何封裝全局toast組件

發布時間:2022-03-24 10:36:49 來源:億速云 閱讀:309 作者:iii 欄目:web開發

本篇內容主要講解“Vue如何封裝全局toast組件”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Vue如何封裝全局toast組件”吧!

一. 借助 vue-cli

1. 定義 Toast 組件

// components/Toast

<template>
  <transition name="fade">
    <div v-show="visible">{{message}}</div>
  </transition>
</template>

<script>
export default {
  data () {
    return {
      visible: false,
      message: ""
    }
  }
}
</script>

<style scoped>
div {
  position: fixed;
  top: 30%;
  left: 50%;
  padding: 5px 20px;
  color: #fff;
  background-color: #424242;
  border-radius: 5px;
  text-align: center;
  transform: translate(-50%, -50%);
}
/* vue動畫過渡效果設置 */
.fade-enter-active,
.fade-leave-active {
  transition: opacity .5s;
}
.fade-enter, .fade-leave-to {
  opacity: 0;
}
</style>

2. 在 main.js 里面配置

import Vue from "vue"
import App from "./App.vue"
import Toast from "./components/Toast"

// 定義插件對象
const ToastObj = {
  install: function (Vue) {
    // 創建一個Vue的“子類”組件
    const ToastConstructor = Vue.extend(Toast)
    // 創建一個該子類的實例,并掛載到一個元素上
    const instance = new ToastConstructor()
    console.log(instance)
    // 將這個實例掛載到動態創建的元素上,并將元素添加到全局結構中
    instance.$mount(document.createElement("div"))
    document.body.appendChild(instance.$el)

    // 在Vue的原型鏈上注冊方法,控制組件
    Vue.prototype.$toast = (msg, duration = 1500) => {
      instance.message = msg
      instance.visible = true
      setTimeout(() => {
        instance.visible = false
      }, duration)
    }
  }
}
Vue.use(ToastObj)

Vue.config.productionTip = false

new Vue({
  render: h => h(App),
}).$mount("#app")

3. 在其他組件內使用

<template>
  <div>
    <h1>{{ msg }}</h1>
  </div>
</template>

<script>
export default {
  name: "HelloWorld",
  data: () => {
    return {
      msg: "HelloWord"
    }
  },
  mounted () {
   // 使用 toast 組件
    this.$toast("組件掛載成功")
  }
}
</script>

二、不借助 vue-cli

 在借助 vue-cli 的情況下,可以方便實現組件的導入導出,但是在不借助構建工具的情況下,就需要使用其他方法了

1. 注冊 toast 組件

<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <script src="./static/vue/vue.min.js"></script>
</head>
<body>
  <div id="app">
    <my-button></my-button>
  </div>
  <div id="toast"></div>
  <script>
    // 定義 toast 全局組件
    const Toast = Vue.component("toast", {
      data() {
        return {
          isShow: false,
          message: "全局提示",
          wrapperStyle: {
            position: "fixed",
            top: "20%",
            left: "50%",
            zIndex: 10000,
            padding: "6px 12px",
            backgroundColor: "#424242",
            borderRadius: "5px",
            transform: "translate(-50%, -50%)"
          },
          textStyle: {
            color: "#fff",
            fontSize: "14px"
          }
        }
      },
      template: `<div v-show="isShow" :style="wrapperStyle">
                  <span :style="textStyle">{{ message }}</span>
                </div>`
    })

2. 注冊 toast 插件

// 定義插件對象
const ToastObj = {
  install: function (Vue) {
    // 創建一個 toast 組件實例,并掛載到一個元素上
    const instance = new Toast()
    // 將這個實例掛載到DOM中
    instance.$mount("#toast")

    // 在Vue的原型鏈上注冊方法,控制組件
    Vue.prototype.$toast = ({message, duration = 2000} = {}) => {
      instance.message = message
      instance.isShow = true

      setTimeout(() => {
        instance.isShow = false
      }, duration)
    }
  }
}
// 注冊 toast 插件
Vue.use(ToastObj)

3. 在其他組件內使用

Vue.component("my-button", {
      data() {
        return {
          wrapperStyle: {
            width: "70px",
            padding: "20px",
            backgroundColor: "green"
          },
          textStyle: {
            color: "#fff",
            fontSize: "16px"
          }
        }
      },
      methods: {
        handleClick() {
          this.$toast({
            message: "我點擊了"
          })
        }
      },
      template: `<div :style="wrapperStyle" @click="handleClick">
                  <span :style="textStyle">點擊提示</span>
                </div>`
    })

    const vm = new Vue({
      el: "#app"
    })
  </script>
</body>
</html>

到此,相信大家對“Vue如何封裝全局toast組件”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

石柱| 平安县| 星子县| 嘉峪关市| 定西市| 区。| 壤塘县| 全南县| 娱乐| 宜春市| 东乡族自治县| 郯城县| 洛南县| 定远县| 册亨县| 青河县| 石林| 化隆| 资中县| 花莲市| 宣威市| 蒲城县| 桦南县| 榆社县| 万全县| 疏勒县| 大竹县| 小金县| 温州市| 且末县| 广州市| 墨江| 金溪县| 合作市| 湖口县| 华亭县| 新疆| 易门县| 抚松县| 南阳市| 林周县|