投稿したデータが1つのテーブルにのみどんどん追加されていくようにしたい。
- ※現状は投稿すればするほど、テーブルも投稿した数、生成されてしまいます。(多重表示?)
- 現在は投稿数は2つにしてあります。
発生している問題・エラーメッセージ
https://note.com/siberun/n/n4a19ad99cf87#Mo1KQ 上記サイトを参考にToDoアプリを練習用に作っております。 目次の15番目(indexアクションのビューにElement UIのテーブルを表示する)の部分を実装しているのですが、 サイトのようにうまく表示されず、私の場合投稿したデータの数、テーブルも生成されてしまいます。
該当のソースコード
Javascript
1<template> 2 <el-table 3 :data="tableData" 4 style="width: 100%"> 5 <el-table-column 6 prop="date" 7 label="Date" 8 width="180"> 9 </el-table-column> 10 <el-table-column 11 prop="name" 12 label="Name" 13 width="180"> 14 </el-table-column> 15 <el-table-column 16 prop="address" 17 label="Address"> 18 </el-table-column> 19 </el-table> 20</template> 21<script> 22 export default { 23 data() { 24 return { 25 tableData: [{ 26 date: '2016-05-03', 27 name: 'Tom', 28 address: 'No. 189, Grove St, Los Angeles' 29 }, { 30 date: '2016-05-02', 31 name: 'Tom', 32 address: 'No. 189, Grove St, Los Angeles' 33 }, { 34 date: '2016-05-04', 35 name: 'Tom', 36 address: 'No. 189, Grove St, Los Angeles' 37 }, { 38 date: '2016-05-01', 39 name: 'Tom', 40 address: 'No. 189, Grove St, Los Angeles' 41 }] 42 } 43 } 44 } 45</script>
Javascript
1import Vue from 'vue' 2import ToDoIndex from '../../to_dos/index.vue' 3import ElementUI from 'element-ui' 4import locale from 'element-ui/lib/locale/lang/ja' 5import 'element-ui/lib/theme-chalk/index.css' 6Vue.use(ElementUI, { locale }) 7document.addEventListener('DOMContentLoaded', () => { 8 const app = new Vue({ 9 render: h => h(ToDoIndex) 10 }).$mount() 11 document.body.appendChild(app.$el) 12})
html
1<% @to_dos.each do |to_do| %> 2 <%= link_to to_do.title, to_do_path(to_do), method: :delete, data: { confirm: '本当に削除してもよろしいですか?' } %> 3 <%= to_do.expired_at&.to_s %> 4 <%= javascript_pack_tag 'to_dos/index' %> 5<% end %>
試したこと
デベロッパーツールを使うと、全く同じ名前の要素が投稿した分、生成されていました。
おそらくVueのファイルのどこかに多重で表示されてしまう原因があると推測。
そこまではわかったのですが、何を修正すればよいか分からなく、考えが尽きてしましました。
補足情報(FW/ツールのバージョンなど)
原因がわかりましたら、ご教授いただけると幸いです。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。