ホームページ  >  記事  >  ウェブフロントエンド  >  Vueでグローバルプロンプトボックスコンポーネントを使用するにはどうすればよいですか?

Vueでグローバルプロンプトボックスコンポーネントを使用するにはどうすればよいですか?

亚连
亚连オリジナル
2018-06-04 14:20:222531ブラウズ

この記事では主に vue のグローバル プロンプト ボックス コンポーネントのサンプル コードを紹介します。必要な方は参考にしてください。

具体的なコードは次のとおりです。

トースト.jsの使い方

<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>

?

main.js内

import ToastComponent from &#39;./toast.vue&#39;
const Toast = {};
// 注册Toast
Toast.install = function (Vue) {
  // 生成一个Vue的子类
  // 同时这个子类也就是组件
  const ToastConstructor = Vue.extend(ToastComponent)
  // 生成一个该子类的实例
  const instance = new ToastConstructor();
  // 将这个实例挂载在我创建的p上
  // 并将此p加入全局挂载点内部
  instance.$mount(document.createElement(&#39;p&#39;))
  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

component.js内

 import Vue from &#39;vue&#39;
  import Toast from &#39;./toast&#39; 
  Vue.use(Toast);

以上、皆さんの参考になれば幸いです。

関連記事:

Vueでコンポーネントの外側をクリックしてコンポーネントを閉じる方法について(詳細なチュートリアル)

vueビルドパッケージ化後のホームページで白い画面が表示される問題を解決するための詳細な解決策(詳細チュートリアル)

vue2.0ではRouter-viewメソッドが表示されない(詳細チュートリアル)


以上がVueでグローバルプロンプトボックスコンポーネントを使用するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。