前提・実現したいこと
現在、Vue.jsとjsonを用いてWebアプリ(SPA)を作る練習をしています。
実装したい機能:簡単なフリマアプリのようなものを作ろうとしています。もともとJSONのデータに商品の情報が格納されていて、購入ボタンをクリックするとJSONからその商品の情報が削除される機能です。
発生している問題・エラーメッセージ
JSONのデータを書き換える(削除)方法がわかりません。
該当のソースコード
HTML
1<div class="dispArea"> 2 <div class="good" v-for="(good, index) in goods" v-bind:key="good.id"> 3 <div class="card bg-light mb-3" style="width: 20rem; float:left"> 4 <img v-bind:src="good.image" class="card-img-top" style="height: 200px;"> 5 <div class="card-body"> 6 <h5 class="card-title">{{ good.title }}</h5> 7 <p class="card-text">{{ good.price }}</p> 8 <p class="card-text">{{ good.explanation }}</p> 9 <p class="card-text">{{ good.category }}</p> 10 <div class="text-right"> 11 <a href="buy.html"><button class="btn btn-primary" v-on:click="deleteEvent(index)">購入する</button></a> 12 </div> 13 </div> 14 </div> 15 </div> 16 </div>
javascript
1function Main() { 2 goodsApp = new Vue({ 3 el: "#goodsApp", 4 data: { 5 goods: [] 6 }, 7 methods: { 8 deleteEvent: function(index) { 9 this.goods.splice(index, 1); 10 },
json
1{ 2 "goods": [ 3 { 4 "id": 1, 5 "title": "macbook", 6 "image": "images/macbook.jpg", 7 "price": "¥19,800", 8 "category": "家電", 9 "explanation": "高性能なノートパソコン" 10 }, 11 { 12 "id": 2, 13 "title": "腕時計", 14 "image": "images/armClock.jpg", 15 "price": "¥1,800", 16 "category": "その他", 17 "explanation": "どこにいても時間を確認できる" 18 },
試したこと
https://qiita.com/watsuyo_2/items/e66c4f5986f9ffd7cf57
https://www.paveway.info/entry/2020/02/23/vue_deletelist
こちらのサイトを真似したらwebページから一時的に削除することはできましたが、JSONのデータには残ったままになってしまいます。(ページの再読み込みで元に戻ってしまう)
補足情報(FW/ツールのバージョンなど)
Vue.jsのバージョン : 2.6.11
Bootstrapのバージョン : 4.5.0
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。