質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

1回答

2447閲覧

Vue.jsを使って、jsonのデータを書き換えたい

Jetson_Pose

総合スコア1

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2020/08/02 06:58

前提・実現したいこと

現在、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

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

以下のようなメソッドを設けて解決しました。

javascript

1deleteEvent: function() { 2 fetch(baseURL+'/'+this.number, { 3 method: 'DELETE' 4 }).then(function(res){ 5 fetch(baseURL, { method: 'GET' }) 6 .then(function(response){ 7 return response.json(); 8 }) 9 .then(function(res) { 10 if(Array.isArray(res)) { 11 goodsApp.goods = res; 12 console.log(goodsApp.goods); 13 } 14 else { 15 goodsApp.goods = [res]; 16 } 17 }); 18 }); 19 }

投稿2020/08/05 07:03

Jetson_Pose

総合スコア1

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問