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

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

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

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

Vuex

Vuexは、Vue.js アプリケーションのための状態管理ライブラリです。アプリケーション内で使用するコンポーネントのための集中データストアを提供。コンポーネント同士でデータをやり取りし、処理のフローを一貫させたり、データの見通しを良くすることができます。

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

Q&A

解決済

1回答

1179閲覧

【Vue.js】vuexのstoreにおいてアクションからミューテーションに値を渡せない

nomu_lui

総合スコア11

Vue.js

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

Vuex

Vuexは、Vue.js アプリケーションのための状態管理ライブラリです。アプリケーション内で使用するコンポーネントのための集中データストアを提供。コンポーネント同士でデータをやり取りし、処理のフローを一貫させたり、データの見通しを良くすることができます。

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

0グッド

0クリップ

投稿2021/01/09 07:38

前提・実現したいこと

Vueでvuexを使っており、store内のactionで楽天商品検索APIを叩き、返ってきた値をmutation経由でstateに渡したい。

API自体はうまく叩けていることを確認済み。

どなたかアドバイスを頂けますと幸いです。

発生している問題・エラーメッセージ

Uncaught (in promise) ReferenceError: data is not defined

該当のソースコード

store/index.js

javascript

1import Vue from 'vue' 2import Vuex from 'vuex' 3import axios from '../plugins/axios' 4import { 5 CHANGE_KEYWORD, 6 SEARCH 7} from './mutation-types' 8 9Vue.use(Vuex) 10 11const state = { 12 keyword: '', 13 items: [] 14} 15 16const getters = { 17 items: state => state.items 18} 19 20const mutations = { 21 [CHANGE_KEYWORD] (state, keyword) { 22 state.keyword = keyword 23 }, 24 [SEARCH] (state, items) { 25 state.items = data.Items 26 } 27} 28 29function searchItem(keyword) { 30 return axios.get('https://app.rakuten.co.jp/services/api/IchibaItem/Search/20170706', { 31 params: { 32 applicationId: "XXXXXXXXXXXXXXXXX", 33 keyword: keyword, 34 giftFlag: 1, 35 } 36 }) 37} 38 39const actions = { 40 [CHANGE_KEYWORD] ({ commit }, keyword) { 41 commit(CHANGE_KEYWORD, keyword) 42 }, 43 44 [SEARCH] ({ commit, state }) { 45 searchItem(state.keyword) 46 .then(data => { 47 commit(SEARCH, data.Items) 48 }) 49 } 50} 51 52export default new Vuex.Store({ 53 namespaced: true, 54 state, 55 getters, 56 mutations, 57 actions 58}) 59

mutaionsのこの部分でうまく渡せてない。

[SEARCH] (state, items) { state.items = data.Items }

推測

state.itemsに代入する値の形式が間違っているのかも?と推測し色々試しましたが、正しい書き方が分からなかったので、difindのままでした。

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

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

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

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

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

guest

回答1

0

ベストアンサー

js

1 [SEARCH] (state, items) { 2 state.items = items 3 }

で良いのではないかと思います。

投稿2021/01/10 00:01

plasticgrammer

総合スコア629

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問