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

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

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

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

JSON

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

JavaScript

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

Q&A

解決済

1回答

4052閲覧

axiosを用いたjsonデータの取得について

hiropo

総合スコア21

Vue.js

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

JSON

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

JavaScript

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

0グッド

0クリップ

投稿2018/02/27 01:23

axiosを使用して、jsonファイルを取得しようとしています。
現在「118.json」(id.json)としているところをparamsのIDに応じてデータを取得してきたいのですが、
paramsの値を特定した書き方がわからない状況です。

わかる方がいらっしゃいましたらご教授お願いします。

created() { axios.get(`/jobs/118.json`) .then(response => { this.job = response.data }) .catch(e => { this.errors.push(e) })

参考にしたサイト
参考サイト
試したこと

axios.get(`/jobs`, { params: { id: 'id' } }) Jsonファイルを特定するPathの書き方がわからない状況です。

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

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

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

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

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

guest

回答1

0

ベストアンサー

こんな感じでどうでしょうか?
インデント汚くてすみません><

js

1 data: function () { 2 return { 3 id: '118' 4 } 5}, 6methods: { 7fetch: function (e) { 8 axios.get(`/jobs/${this.id}.json`) 9 .then(response => { 10 this.job = response.data 11 }) 12 .catch(e => { 13 this.errors.push(e) 14 }) 15} 16}, 17mounted: function () { 18this.fetch() 19}

投稿2018/02/27 02:05

編集2018/02/27 02:07
pokkur

総合スコア76

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

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

pokkur

2018/02/27 02:31

その場合はvue-routerを利用を使用するのが良いと思います。 ```js axios.get(`/jobs/${this.$route.params.id}.json`) ```
hiropo

2018/02/27 03:17

ご回答ありがとうございます。 vue-routerについて調べているとSPAで作成する例が多数出てきまたした。 現在私は、Rails5にて「jobを編集する」を押すとhttp://localhost:3000/jobs/10/edit に飛ぶようにコントローラで設定しています。(id:10) 私のようなケースでもvue-routerを使用することが望ましいのでしょうか。 他の方法などありましたらご教授いただければ幸いです。
pokkur

2018/02/27 03:29

なるほどです、普通にURLからdataを作成する方法ではどうでしょうか? ``` let id = location.pathname.split('/')[2] // http://localhost:3000/jobs/10/edit でしたら 10 を取得します ```
hiropo

2018/02/27 03:53

ご丁寧なご回答ありがとうございました。 ご指摘の通り行ったところ期待の動作が確認できました。 無事解決しました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問