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

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

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

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

Nuxt.js

Nuxt.jsは、ユニバーサルなSPAが開発可能なVue.jsベースのフレームワーク。UIの描画サポートに特化しており、SSRにおけるサーバーサイドとクライアントサイドのUIレンダリングなどさまざまな機能を持ちます。

JavaScript

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

Q&A

解決済

1回答

1636閲覧

[Nuxt.js]URLから取得したidと同じkeyをもつオブジェクトの、別の要素を表示させたい

noliiiiii

総合スコア13

Vue.js

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

Nuxt.js

Nuxt.jsは、ユニバーサルなSPAが開発可能なVue.jsベースのフレームワーク。UIの描画サポートに特化しており、SSRにおけるサーバーサイドとクライアントサイドのUIレンダリングなどさまざまな機能を持ちます。

JavaScript

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

0グッド

0クリップ

投稿2021/07/13 04:42

編集2021/07/13 04:50

こんにちは。Nuxt.js初学者です。

こちらの記事・箇所を参考に、Nuxt.jsでURLの数値に応じた要素を表示させたいともがいています。

あらかじめ用意しておいたデータ(users)から、URLの末尾の数字(1〜3)と一致するidを持つオブジェクトのnameを取り出してresultに代入、URLの数値に応じて表示させるnameを動的に変える…ということをしたいはずでした。

見本では下記のようになっていたのですが同じようにしても動かず、というかconputedはデフォルトではgetterなので代入はできないのでは?と自分なりに調べて書いてみたのですが、何時間も悩んだ末ギブアップしました。
もしわかる方がいらっしゃれば、ご教示いただけないでしょうか。

バージョン: @nuxt/cli v2.15.6

初心者ゆえ、言葉足らずな箇所などあったらすみません。

よろしくお願いします。


▼見本のコード

javascript

1<template> 2 <h1>ユーザID: {{ user.name }}</h1> 3</template> 4 5<script> 6export default { 7 data(){ 8 return { 9 id: this.$route.params.id, 10 users: [ 11 { 12 id: 1, name: 'John Doe' 13 }, 14 { 15 id: 2, name: 'Kevin Smith', 16 }, 17 { 18 id: 3, name: 'Harry Bosch' 19 }, 20 ], 21 } 22 }, 23 computed:{ 24 user(){ 25 return this.users.find(user => user.id == this.id); 26 } 27 } 28} 29</script>

▼自分のコード

javascript

1<template> 2 <div> 3 <v-container> 4 <h1>User ID: {{ result }}</h1> 5 </v-container> 6 </div> 7</template> 8 9<script> 10export default { 11 data() { 12 return { 13 id: this.$route.params.id, 14 users: [ 15 { 16 id: 1, 17 name: 'Joe', 18 }, 19 { 20 id: 2, 21 name: 'Ryo', 22 }, 23 { 24 id: 3, 25 name: 'Momo', 26 }, 27 ], 28 result: '', 29 } 30 }, 31 computed: { 32 user: { 33 get() { 34 console.log(this.result) 35 return this.result 36 }, 37 set(v) { 38 const result = '' 39 const key = '' 40 let i = 0 41 for (i in this.users) { 42 if (this.id === i.id) { 43 this.result = i.name 44 } 45 } 46 }, 47 }, 48 }, 49} 50</script> 51

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

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

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

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

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

guest

回答1

0

ベストアンサー

result自体をcomputedにしてやれば動的に切り替わるはずです。
またparamsidのユーザーが存在しない場合は、findの返り値はundefinedになるのでそこも考慮する必要があるかと思います。

JavaScript

1<template> 2 <div> 3 <v-container> 4 <h1>User ID: {{ result }}</h1> 5 </v-container> 6 </div> 7</template> 8 9<script> 10export default { 11 data() { 12 return { 13 id: this.$route.params.id, 14 users: [ 15 { 16 id: 1, 17 name: 'Joe', 18 }, 19 { 20 id: 2, 21 name: 'Ryo', 22 }, 23 { 24 id: 3, 25 name: 'Momo', 26 } 27 ] 28 } 29 }, 30 computed: { 31 result () { 32 const targetUser = this.users.find(({ id }) => String(id) === this.id) 33 return targetUser?.name ?? 'ユーザーが存在しません' 34 } 35 } 36} 37</script>

投稿2021/07/13 05:06

編集2021/07/13 05:17
taku-hu

総合スコア176

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

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

k4a

2021/07/13 05:13

`this.$route.params`はstring型なので、toStringをつける、もしくは定義をstring型にしないとだめなような気がします。 ``` this.users.find(({ id }) => id.toString() === this.id) ``` or ``` { id: '1', name: 'Joe', } ```
taku-hu

2021/07/13 05:15

ご指摘ありがとうございます。 確かにその通りでした、回答を修正させていただきます。
noliiiiii

2021/07/13 08:03

どうも、ありがとうございます。動きました!まだ全て消化しきれていませんが、色々試して動きを確かめてみます。本当にありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問