前提・実現したいこと
Vueで楽天APIを叩いて、検索結果を表示するようにしたいのですが、商品名が長すぎるため、文字列の切り出しをしたいです。
item.Item.itemPrice
はこちらの書き方で出力できることは確認済みです。
追加修正等、わかる方がいらっしゃいましたら、アドバイスをいただけないでしょうか。
よろしくお願いいたします。
発生している問題・エラーメッセージ
Error in data(): "ReferenceError: item is not defined" Error in render: "TypeError: Cannot read property 'length' of undefined"
該当のソースコード
RakutenApiResultItem.vue
Vue
1<template> 2 <div> 3 <div class="card"> 4 <a target="_blank" :href="item.Item.itemUrl"> 5 <div class="content"> 6 <p>{{ sliceItemName() }}</p> 7 <p>{{ item.Item.itemPrice }}円</p> 8 </div> 9 </a> 10 </div> 11 </div> 12</template> 13 14<script> 15export default { 16 name: "RakutenApiResultItem", 17 props: { 18 item: Object, 19 required: true, 20 }, 21 data() { 22 return { 23 itemName: item.Item.itemName, 24 }; 25 }, 26 computed: { 27 sliceItemName() { 28 if (this.itemName.length > 27) { 29 return this.itemName.slice(0, 27) + "..."; 30 } else { 31 return this.itemName; 32 } 33 }, 34 }, 35}; 36</script> 37<style scope></style> 38
RakutenApiResultList.vue
<template> <div> <div class="columns is-multiline"> <template v-for="item in items"> <div class="column is-3"> <RakutenApiResultItem :key="item.id" :item="item" /> </div> </template> </div> </div> </template> <script> import RakutenApiResultItem from "./RakutenApiResultItem"; import { mapGetters } from "vuex"; export default { name: "RakutenApiResultList", components: { RakutenApiResultItem, }, computed: { ...mapGetters(["items", "currentPage", "pageCount", "reviewCount", "reviewAverage"]), }, }; </script> <style scope></style>
試したこと
Vueの公式を確認すると、下記のようにすれば良いと載っていましたが、List(親)、Item(子)でコンポーネントを分けていますし、この書き方だとitemName
以外のitemPrice
まで切り出してしまうので、上手くいきません。
// html <p v-for="item in filteredItems">{{ item }}</p> // js computed: { filteredItems: function () { return this.items.slice(0, 10) } }
補足情報(FW/ツールのバージョンなど)
Vue 2.6.12
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/01/27 00:19
2021/01/27 00:24
2021/01/27 00:32
2021/01/27 00:36