이 글에서는 Vue의 글로벌 프롬프트 박스 컴포넌트의 예제 코드를 주로 소개하고 있으니, 필요하신 분들은 참고하시면 됩니다.
이 글에서는 Vue 글로벌 프롬프트 박스 컴포넌트에 대한 구체적인 코드를 소개합니다.
<template> <!-- 全局提示框 --> <p v-show="visible" class="dialog-tips dialog-center"> <p>{{message}}</p> </p> </template> <script> export default { data() { return { visible: false, message: "" }; } }; </script> <style lang="scss"> .dialog-tips{ position: fixed; z-index: 100; min-width: 220px; padding: 40px 22px; white-space: nowrap; background-color: #fff; box-shadow: 0px 8px 15px 0 rgba(0, 0, 0, 0.1); text-align: center; .dialog-tips-icon{ width: 54px; height: 54px; @extend %bg-contain; display: inline-block; margin-bottom: 13px; } } .dialog-center { top: 50%; left: 50%; transform: translate(-50%, -50%) } </style>
toast.js
import ToastComponent from './toast.vue' const Toast = {}; // 注册Toast Toast.install = function (Vue) { // 生成一个Vue的子类 // 同时这个子类也就是组件 const ToastConstructor = Vue.extend(ToastComponent) // 生成一个该子类的实例 const instance = new ToastConstructor(); // 将这个实例挂载在我创建的p上 // 并将此p加入全局挂载点内部 instance.$mount(document.createElement('p')) document.body.appendChild(instance.$el) // 通过Vue的原型注册一个方法 // 让所有实例共享这个方法 Vue.prototype.$toast = (msg, duration = 1500) => { instance.message = msg; instance.visible = true; setTimeout(() => { instance.visible = false; }, duration); } } export default Toast
을 사용하는 방법은 무엇입니까?
main.js
import Vue from 'vue' import Toast from './toast' Vue.use(Toast);
In 컴포넌트
this.$toast("XXXXXXXXX");
위 내용은 앞으로 모두에게 도움이 되기를 바랍니다.
관련글:
Vue에서 컴포넌트 외부를 클릭하여 컴포넌트를 닫는 방법에 대해(상세 튜토리얼)
vue 빌드 패키징 후 홈페이지에 흰색 화면이 나타나는 문제를 해결하기 위한 자세한 솔루션( 자세한 튜토리얼)
vue2.0에서는 Router-view 방식이 표시되지 않습니다. (상세 튜토리얼)
위 내용은 vue에서 전역 프롬프트 상자 구성 요소를 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!