~~~ L O A D I N G ~~~~~ L O A D I N G ~~~~~ L O A D I N G ~~~

資視就是力量 - Highcharts / Vue 做個記帳本 (下)

Oct 13, 2020 Max Lee

昨天已經將記帳本打造出一個基本雛形了,但似乎功能並不是很多,純粹就只是看到消費的金額和走向而已,所以我們今天來利用圖表的「事件屬性」搭配 Vue 的 emit 來為記帳本新增一個查看明細的功能吧。


記帳本實作

就像下圖所示,這次要做到的功能是希望能點擊「數據列」時,在下方顯示當天的消費明細以及總金額,讓我們的記帳本有更完整的功能。

而開發的邏輯是透過點擊拿到數據點的日期時間戳,然後利用父子層的溝通來將這個時間戳傳遞到一個新的「清單元件」中,清單元件會拿這個時間戳去打 Json-Server 的 API,取得該日期的帳目定顯示於畫面上。那就馬上動手開發吧!


1.設定事件屬性

我們在圖表元件 LedgerChart.vue 中新增一個 Method,並將它作為圖表 click 事件的回呼函式,而由於回呼函式可以接到 Highcharts 的 event 物件,我們就可以拿到時間戳,並利用 $emit 來傳至 App.vue

methods: {
  selectDate() {
    this.$emit("selectDate", event.point.category)
  }
}
// computed
options() {
  let options = Object.assign(this.chartOptions, {});
  options.series = this.seriesData;
  options.xAxis.categories = this.xAxisCategories;
  options.plotOptions.series.events = {
    click: this.selectDate
  };
  return options;
}

2.父層監聽自定義事件

剛剛在 LedgerChart.vueemit 了自定義事件,現在要在父層來監聽接收這事件,這樣每次點擊數據列就都會更新 date 了。

<template>
  <div id="app">
    <LedgerForm />
    <LedgerChart @selectDate="selectDate" />
  </div>
</template>

<script>
import LedgerForm from "./components/LedgerForm"
import LedgerChart from "./components/LedgerChart"

export default {
  name: "App",
  components: {
    LedgerForm,
    LedgerChart
  },
  data() {
    return {
      date: 0
    }
  },
  methods: {
    selectDate(val) {
      this.date = val;
    }
  }
}
</script>

3.清單元件 - LedgerList.vue

再來就是下方要顯示的明細清單了,檔案內容如下,主要是透過接收一個 date 的 Prop,每當它更新時就會觸發 watch,然後利用 Json-Server 的 Filter 功能來抓出「當天」的資料,如此就能將消費明細顯示在畫面上了。

明細上方的日期和總金額透過 computed 計算即可得到,因為不是重點,這邊就將程式碼省略了。

<template>
  <div v-if="date">
    <div class="ledger-item" v-for="item in fetchData" :key="item.id">
      <div>{{ item.category }}</div>
      <div>{{ item.description }}</div>
      <div>NT$ {{ item.amount }}</div>
    </div>
  </div>
</template>

<script>
  export default {
    props: {
      date: {
        type: Number,
        default: 0
      }
    },
    data() {
      return {
        fetchData: []
      }
    },
    watch: {
      date(val) {
        this.axios.get(`http://localhost:3000/accounts?date=${val}`)
          .then((response) => {
            this.fetchData = response.data;
          });
      }
    }
  }
</script>

4.掛載元件並傳入 Prop

清單元件完成後就將他掛到 App.vue 上了,並且記得要把剛剛的 date 傳進清單元件中。如此一來我們就成功增加了查看明細的新功能囉!

<template>
  <div id="app">
    <LedgerForm />
    <LedgerChart @selectDate="selectDate" />
    <LedgerList :date="date" />
  </div>
</template>

花了四天的時間我們從熟悉 Highcharts-Vue 的使用到最後開發出一個小作品,相信大家應該有感受到 Highcharts 與前端框架的配合是多麼的方便好用。不過隨著記帳本的完成,這個系列文章也即將告一段落了,明天最後一篇文章則會做個系列的總結,並講講我的參賽心得。


- 此篇文章為「iT邦幫忙鐵人賽」參賽文章,同步發表於 iT邦幫忙 -

Prev
Next