17
15

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

NJC Advent Calendar 2019

Day 23

Vue.js+element uiでTableUIを遊び倒す

Last updated at Posted at 2019-12-22

この記事は、「NJC Advent Calendar 2019」 12月23日の記事です。

はじめに

Vue.js+element uiで開発をした際、element uiのTableコンポーネントを色々触ったので備忘録として書きます。備忘録ですみません。正直な話良いネタが思いつかなかったです
また、実現したいことが日本のドキュメントであまりなかったので記事で残してたら需要あるかなと。。。

環境

Vue.js 2.6.10
element-ui 2.13.0

#環境構築
今回は、Codepenで作成していくのでそちらの環境作成手順です。
①Settingsを開きます。
②JavaScriptタブで設定をします。
③Add External Scripts/Pensで以下のワードで検索して追加します。
 ・vue
 ・element-ui
⑤以下画面になっていればsave & Closeを押して設定を保存します。
image.png

実際の開発環境については先人の方々の資料を参考にしてください。
・Vue.js環境構築参考
https://qiita.com/yoshi0518/items/76195d52b794c4b81816
・Elemnt UI環境構築参考
https://qiita.com/Sa2Knight/items/7386a83c2058e53f0eef

実際に作成してみる

今回は以下二種類の機能を実装する。
・①RowクリックイベントでRowの詳細を出す機能
・②各Rowの文字が改行しないで「...」にする機能
##簡単なTable
Basic tableをそのまま作成する。公式サイト参考Table

html
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
<div id="app">
  <template>
    <el-table
      :data="tableData"
      style="width: 100%"
  >
      <el-table-column
        prop="date"
        label="Date"
        width="180">
      </el-table-column>
      <el-table-column
        prop="name"
        label="Name"
        width="180">
      </el-table-column>
      <el-table-column
        prop="address"
        label="Address">
      </el-table-column>
    </el-table>
  </template>
</div>
CSS
#app{
  width: 600px;
}
main.js
Vue.config.devtools = true;

new Vue({
  el: '#app',
   data() {
        return {
          tableData: [{
            date: '2016-05-03',
            name: 'Tom',
            address: 'No. 189, Grove St, Los Angeles'
          }, {
            date: '2016-05-02',
            name: 'Tom',
            address: 'No. 189, Grove St, Los Angeles'
          }, {
            date: '2016-05-04',
            name: 'Tom',
            address: 'No. 189, Grove St, Los Angeles'
          }, {
            date: '2016-05-01',
            name: 'Tom',
            address: 'No. 189, Grove St, Los Angeles'
          }]
        }
      }
});

①RowクリックイベントでRowの詳細を出す

###やりたいこと
expandable-rowを用いることで以下画像のように各Rowに詳細の表示切替ができる。しかし、公式サイトの情報は赤枠部分のクリックで実現している情報のみである。
これを各Row全体がクリックされても表示切替ができるようにする。
image.png

###実装

html
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
<div id="app">
  <template>
    <el-table
      :data="tableData"
      style="width: 100%"
      @row-click="rowClicked"
      ref="tableData"
      id="clickable-rows"
    >
      <el-table-column type="expand">
        <template slot-scope="props">
          Old: {{ props.row.details.old }}<br>
          Like: {{ props.row.details.like }}<br>
          DisLike: {{ props.row.details.dislike }}<br>
        </template>
      </el-table-column>
      <el-table-column
        prop="date"
        label="Date"
        width="180">
      </el-table-column>
      <el-table-column
        prop="name"
        label="Name"
        width="180">
      </el-table-column>
      <el-table-column
        prop="address"
        label="Address">
      </el-table-column>
    </el-table>
  </template>
</div>
css
#app{
  width: 600px;
}
.clickable-rows {
  tbody tr td {
    cursor: pointer;
  }
}
.el-table__expanded-cell {
    cursor: default;
  }
}
main.js
Vue.config.devtools = true;

new Vue({
  el: '#app',
  methods: {
      rowClicked(row) {
        this.$refs.tableData.toggleRowExpansion(row);
      }
   },
   data() {
        return {
          tableData: [{
            date: '2016-05-03',
            name: 'Tom',
            address: 'No. 189, Grove St, Los Angeles',
            details: {
              old: '16 years old',
              like: 'play Baseball',
              dislike: 'Math'
            }
          }, {
            date: '2016-05-02',
            name: 'Tom',
            address: 'No. 189, Grove St, Los Angeles',
            details: {
              old: '16 years old',
              like: 'play Baseball',
              dislike:'Math'
            }
          }, {
            date: '2016-05-04',
            name: 'Tom',
            address: 'No. 189, Grove St, Los Angeles'
          }, {
            date: '2016-05-01',
            name: 'Tom',
            address: 'No. 189, Grove St, Los Angeles',
            details: {
              old: '16 years old',
              like: 'play Baseball',
              dislike: 'Math'
            }
          }]
        }
      }
});

###解説
<el-table-column type="expand">でexpandを設定して、そのタグ内に<template slot-scope="props">を記載することで、Rowクリック時に下に表示させる部分を準備する。実際はこの時点でtype="expand"を設定したカラムに詳細行の表示切替実装できているが、Row全体のクリックイベントではない。
Row全体に表示切替機能を実装するには、<el-table>で設定した@row-click="rowClicked"ref="tableData"を用いる。
@row-click="rowClicked"イベントで呼び出される際にメソッド側で選択したRow情報が引数として使用することができる。
メソッド内でthis.$refs.tableData.toggleRowExpansion(row);を実行することによりクリックしたRowの詳細切替を実装することができる。

##②各Rowの文字が改行させないで「・・・」にする
###やりたいこと
以下画像のように文字数がカラムの幅を超えた場合に、改行せずに「・・・」と省略するように実装する。
image.png
###実装
htmlとCSSを変更していく。

html
<link rel="stylesheet" href="https://unpkg.com/element-ui/lib/theme-chalk/index.css">
<div id="app">
  <template>
    <el-table
      :data="tableData"
      style="width: 100%"
      @row-click="rowClicked"
      ref="tableData"
      id="clickable-rows"
    >
      <el-table-column type="expand">
        <template slot-scope="props">
          Old: {{ props.row.details.old }}<br>
          Like: {{ props.row.details.like }}<br>
          DisLike: {{ props.row.details.dislike }}<br>
        </template>
      </el-table-column>
      <el-table-column
        prop="date"
        label="Date"
        width="180">
      </el-table-column>
      <el-table-column
        prop="name"
        label="Name"
        width="180">
      </el-table-column>
      <el-table-column
        label="Address">
        <template slot-scope="scope">
          <div id="textOver">
              {{ scope.row.address }}
          </div>
        </template>
      </el-table-column>
    </el-table>
  </template>
</div>
css
#app{
  width: 600px;
  list-style: none;
}
#textOver {
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
}
.clickable-rows {
  tbody tr td {
    cursor: pointer;
  }
}
.el-table__expanded-cell {
    cursor: default;
  }
}

###解説
CSSで設定する。#textOverの設定で「・・・」を実装できる。
※「・・・」のやり方は調べれば結構情報落ちてます。
cssで設定した#textOverをhtmlに反映させるために、以下のようにel-table-columnを変更します。
template slot-scope="scope"とすることによりel-tableで渡された:data="tableData"をscopeとして受け取ることでtemplateタグ内で様々なデザインを可能にすることができます。

変更部分
<el-table-column
    prop="address"
    label="Address">
</el-table-column>

↓↓↓下記のように変更↓↓↓
 <el-table-column label="Address">
  <template slot-scope="scope">
    <div id="textOver">
      {{ scope.row.address }}
   </div>
  </template>
</el-table-column>

#成果物

See the Pen qBEmaVJ by Kento_tj (@Kento-GREEN) on CodePen.

#最後に
Element UIは部品が豊富な印象を受けました。
また、実装のやりやすさであまり工数をかけたくないとか、簡単なフロントの作成に向いているなと感じました。
ただ、ちょっとしたデザインを実装する際は日本のドキュメントは少ないなと。。。
実装の方法とか忘れそうなんで、他のElement UIの部品も備忘録として残そうかと思います!!
批判、アドバイス等大歓迎です。
お手柔らかにお願いします。

#おまけ
**「②各Rowの文字が改行させないで「・・・」にする」**に関して補足。
今回の実装では、Safariで確認すると文字省略、改行せずに文字がカラムを抜きぬけて表示されるみたいです。
なぜかはわからないですが、、、
回避方法としては、それぞれのel-table-columnにwidthをpxで設定してあげることが必要みたいです。

17
15
3

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
17
15

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?