🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Vue.js

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

Vuetify.js

Vuetify.jsは、マテリアルデザインを基本とするVue.jsのCSSフレームワークです。多くのマテリアルデザインのコンポーネントを提供しており、あらゆるアプリケーションに対応可能。vue-cli用テンプレートがあり、簡単にページを作成できます。

Vue CLI

Vue CLIは、Vue.jsでアプリケーション開発を行うためのコマンドラインインタフェース(CLI)に基づいた開発ツールです。インタラクティブなプロジェクトの雛形や設定なしで使用できるプロトタイプの作成など、さまざまな機能が用意されています。

Q&A

解決済

2回答

1892閲覧

vue-cli 再読み込みすると入力した内容が全てのフォームに反映してしまう。

MasatofromMGSV

総合スコア21

Vue.js

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

Vuetify.js

Vuetify.jsは、マテリアルデザインを基本とするVue.jsのCSSフレームワークです。多くのマテリアルデザインのコンポーネントを提供しており、あらゆるアプリケーションに対応可能。vue-cli用テンプレートがあり、簡単にページを作成できます。

Vue CLI

Vue CLIは、Vue.jsでアプリケーション開発を行うためのコマンドラインインタフェース(CLI)に基づいた開発ツールです。インタラクティブなプロジェクトの雛形や設定なしで使用できるプロトタイプの作成など、さまざまな機能が用意されています。

0グッド

0クリップ

投稿2019/11/09 11:44

編集2019/11/09 11:59

環境

windows10(64)
"vue": "^2.6.10",
"vuetify": "^2.1.0",
"vue-cli":"3.11.0",
"node":"v11.13.0"
プログラミング歴 4か月ほど

# 苦戦しているところ
vuetify+vue-cliでtodoアプリ(講義さぼり回数カウントアプリ)を作っています。
サイトのURL
授業名(タスク)を2つ以上登録して状態でメモ(フォーム)を入力し、ページロードすると後から入力した内容に全て書き換わってしまいます。

➀上の経済学にメモ(ええええ)を入力して![イメージ説明

➁ページロードすると・・・・
イメージ説明

➂下のタスク(スポーツ科学)にもそのメモの内容(ええええ)が反映してしまう。
イメージ説明

ソースコード

Count.vue(必要な部分のみ)

@@ -11,7 +11,7 @@ <v-card card_id max-width="344" class="mx-auto"> <v-card-title>{{todo.name}}</v-card-title> <v-card-text> + <Field /> </v-card-text> <v-card-actions> <v-btn @click="increment(todo)" color="primary">さぼり回数</v-btn> <span>{{ todo.count }}</span> <v-btn @click="decrement(todo)" color="error">間違い(-)</v-btn> <v-btn @click="deleteItem(index)">削除</v-btn> </v-card-actions> </v-card> </div> </v-container> </v-content> </v-app> </template> <script> + import Field from "./Field"; export default { data() { return { count: 0, name: "", todos: [] }; }, + components: { + Field + }, mounted() { this.todos = JSON.parse(localStorage.getItem("todos")) || []; }, methods: { addTodo() {

Count.vueの全コード

Field.vue ↓

<template> <v-text-field label="メモ" v-model="memo"></v-text-field> </template> <script> export default { data() { return { memo: "" }; }, mounted() { if (localStorage.memo) this.memo = localStorage.memo; }, watch: { memo(newMemo) { localStorage.memo = newMemo; } } }; </script>

この問題を解決するにはどうすれば良いでしょうか?あるいはこの問題を解決するにあたって必要な知識がありますでしょうか?

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

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

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

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

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

guest

回答2

0

自己解決

つまりこの問題を解決するには設計を根本から変えないと無理ってことですかね?

投稿2019/11/09 15:31

MasatofromMGSV

総合スコア21

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

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

R.Mizukami

2019/11/10 01:11

解決したみたいですけど一応。 Field の memo だけ保存するのではなく、 Count の todos を JSON 文字列等に変換してまとめて保存、起動時に復元とやれば目的は達成できると思います。todos のループ部分のコード等がないので、推測ですが……。 尚、回答に対するコメントは「回答する」 からではなく、「コメント投稿」からお願いします。
MasatofromMGSV

2019/11/10 04:30

ありがとうございます????、試してみます。
guest

0

localStorage の同じキー (memo) にメモの内容を保存し、そこから復元しているからではないでしょうか。

localStorage は vuejs の機能ではなく、ブラウザの javascript に備わっている機能です。当然、アプリケーション内でストレージを共有しているため、すべてのメモに対する変更が同じ memo フィールドに書き込まれています。

投稿2019/11/09 13:56

R.Mizukami

総合スコア1086

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問