アプリみたいに通知数を表示できるライブラリ「vue-notification-bell」

アプリみたいに通知数を表示できるライブラリ「vue-notification-bell」

vue-notification-bellとは

vue-notification-bellは、スマホのアプリみたいに通知の数を表示することができるコンポーネントライブラリです。

通知のサイズを変えたり、通知が大量に溜まった場合は「50+」みたいな表記にすることも可能です。

 

アプリみたいに通知数を表示できるライブラリ「vue-notification-bell」

 

環境

Vue 2.6.10
vue-notification-bell 0.8.14

 

インストール

以下のnpmCDNを使ってインストールします。

npm

npm install vue-notification-bell --save

CDN

<script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/NotificationBell.umd.min.js"></script>

 

gitリポジトリは以下から取得できます。

https://github.com/mrastiak/vue-notification-bell

 

導入手順

1. ライブラリの取り込み

(1)webpack等の場合 [注意]モジュール版は未検証です。

import NotificationBell from 'vue-notification-bell'

(2)WEBページの場合

const NotificationBell = window['NotificationBell'].default;

2.メソッドを設定

上記で取得したNotificationBellcomponentsに取り込みます。

カウント数が動的に変化することを確認できるようにサンプルには、deleteItemでリストの削除機能を持たせます。

new Vue({
  el: '#app',
  components: {
    'notification-bell':NotificationBell 
  },
  data: {
    list: [
      {no:1},
      {no:2},
      {no:3},
      {no:4},
      {no:5},
    ]
  },
  methods: {
    deleteItem: function(index){
      this.list.splice(index, 1);
    }
  }
});

3. テンプレートを準備

<notification-bell> を設置します。

ベルのアイコンのサイズカウント数や今回はアニメーションをプロパティに設定します。

プロパティの説明はこちらを参照

 

[注意] サンプルはケバブケースで記載しています。

<div id="app">
  <notification-bell
    :size="100"
    :count="list.length"
    upper-limit="50"
    counter-location="upperRight"
    counter-style="roundRectangle"
    counter-background-color="#FF0000"
    counter-text-color="#FFFFFF"
    icon-color="#000000"
    font-size="25px"
    :animated="true"
  ></notification-bell>
  <ul class="list-group">
    <li class="list-group-item" v-for="(item, index) in list" :key="index">{{'item-'+item.no}} - <button class="btn btn-danger" type="button" @click="deleteItem(index)">削除する</button></li>
  </ul>
</div>

 

サンプル

>>専用ページで確認する

 

さいごに

スマホのアプリみたいに通知の数を表示することができるコンポーネントライブラリでした。

 

今日はこの辺でー

 

  • この記事を書いた人

カバノキ

印刷会社のWEB部隊に所属してます。 WEB制作に携わってから、もう時期10年になります。 普段の業務では、PHPをメインにサーバーサイドの言語を扱っています。 最近のお気に入りはJavascriptです。 Vue.jsを狂喜乱舞しながら、社内に布教中です。

-Notification, UI Components, vue.js, ライブラリ
-, ,