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

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

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

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

JavaScript

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

解決済

2回答

563閲覧

FormData()で数を追加するときにできない理由について。

con2319

総合スコア52

Vue.js

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

JavaScript

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

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2021/09/07 09:57

編集2021/09/07 10:14

・やりたい事
FormData()で作ったインスタンスに要素を追加する。

・ダメなところ
下記のようなコードで要素を追加したところ実際表示されたアウトプットが想定と異なる。

・出力方法
vue.jsで設定したbook_detilリストにformDataの値を入れてhtmlの変数設定場所でそのまま公開。

想定している出力結果 [{"id":"20"}]
実際の出力結果 [ {} ]

html

1<div > 2   {{book_detil}} 3</div>

javascript

1let clicked_id = '20'; 2let formData = new FormData(); 3formData.append("id",this.clicked_id); 4this.book_detil = [formData];

わかる方がいれば教えていただけると嬉しいです。
宜しくお願い致します。

修正点
・formDataを[]で囲んだら出力結果が少し変わったが追加はされていない。

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

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

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

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

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

int32_t

2021/09/07 10:01

どんなコードで表示して、どのような想定でしたか?
guest

回答2

0

Vue.js

Vue.jsのコードが誤っている為に期待通りに動いていません。
公式サイトを確認しましょう。

Vue.jsのサンプルコード

HTML

1<div id="sample1">{{message}}</div> 2<div id="sample2">{{book_detil}}</div> 3 4<form> 5 <input type="hidden" name="foo" value="123" /> 6 <input type="hidden" name="bar" value="abc" /> 7 <input type="hidden" name="baz" value="xyz" /> 8</form> 9 10<script> 11'use strict'; 12new Vue({ 13 el: '#sample1', 14 data: { 15 message: 'Hello Vue!' 16 } 17}); 18 19new Vue({ 20 el: '#sample2', 21 data: { 22 book_detil: JSON.stringify(Array.from(new FormData(document.querySelector('form')))) 23 } 24}); 25</script>

Re: con2319 さん

投稿2021/09/07 11:10

think49

総合スコア18189

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

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

con2319

2021/09/07 12:49

ありがとうございます。参考にさせていただきます。
guest

0

ベストアンサー

FormDataから値を回収するには、entrieskeysvaluesといったメソッドでIteratorを得て、それをスプレッドやfor-ofなどを使って回収する必要があります。

ふつうのオブジェクトのように参照しようとしても結果は得られません。

投稿2021/09/07 10:38

maisumakun

総合スコア146063

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

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

con2319

2021/09/07 12:48

なるほど~FormDataからデータを取得するのはめんどくさそうですね。 ちなみにformdataをデータの送信以外で使用する場面は結構多いですか?
maisumakun

2021/09/07 12:57

> formdataをデータの送信以外で使用する場面は結構多いですか? 送信と無関係な場面で、そんなに引き回すものでもない気はします。
con2319

2021/09/07 13:45

でしたらよかったです。 値がどんな感じで格納されているかの一時的な確認での表示なので常用するつもりはありませんでした。 色々教えていただきましてありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問