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

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

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

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

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

Blade

Bladeとは、 PHPフレームワークのLaravelで使用することができるテンプレートエンジンです。テンプレートの継承とエスケープ機能を提供します。

Q&A

1回答

1318閲覧

vueでformを書く際に引数を入れたい

tenlife

総合スコア70

Vue.js

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

Laravel

LaravelとはTaylor Otwellによって開発された、オープンソースなPHPフレームワークです。Laravelはシンプルで表現的なシンタックスを持ち合わせており、ウェブアプリケーション開発の手助けをしてくれます。

Blade

Bladeとは、 PHPフレームワークのLaravelで使用することができるテンプレートエンジンです。テンプレートの継承とエスケープ機能を提供します。

0グッド

0クリップ

投稿2020/08/28 21:54

編集2020/08/29 22:06

axiosをいつも使用しているのですが、axiosを使わずにするにはformの部分をどのように書くんだろう?と言うところにいます。

解決したいこと: vue内でformを書くときに引数を渡したいです。1の部分にpropsで受け取っているuser_idを入れたいと考えています。

現状: user_idをうまく持ってこれてない。

blade

1bladeで書くとしたら以下、これをvueで表したいです。 2<form action="{{route('follow', ['user' => $user->id])}}">
<template> <div> <form action="/user/1/follow"> <button type="button" class="btn btn-success btn-sm">Follow</button> </form> </div> </template> <script> export default { props: ['user_id'] } </script>

試した書き方

1, bladeと似ている書き方? -> エラー <form action="{{route('follow', ['user' => user_id])}}"> Errors compiling template: action="{{route('follow', ['user' => user_id])}}": Interpolation inside attributes has been removed. Use v-bind or the colon shorthand instead. For example, instead of <div id="{{ val }}">, use <div :id="val">. 2, urlに入れてしまえばどうだろう? -> actionの書き方がわからず文字列で表示されてしまいます。 <form action="url"> data() { return { url: '', } }, props: ['user_id'], created() { let id = this.user_id // パスを作成 var array = ["http://127.0.0.1:8000/user/", id, "/follow"]; // パスをjoinで結合 this.url = array.join('') }

axiosでいつも書いていたので、formで書く場合はどうなるんだろうと言う興味本位が大きいです。

お分かりになる方いましたら、ご教授いただきたいです。
よろしくお願いします。

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

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

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

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

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

dameo

2020/08/31 10:45

ajaxとは全然違います。通信した内容を元に自分で部分的にページを書き換えたり、historyを元にアドレスバーを誤魔化す遷移をするのではなく、 本当にURLを遷移させてページ全体を書き換えます。 https://developer.mozilla.org/ja/docs/Learn/Forms
guest

回答1

0

vueをあまり知らないので検討違いかもしれませんが…

「2, urlに入れてしまえばどうだろう? -> actionの書き方がわからず文字列で表示されてしまいます。」の案に対して、mustache記法で記述するのはどうでしょうか。

<form action="url"> ↓ <form action="{{ url }}">

投稿2020/09/02 05:00

meshi_s

総合スコア276

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

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

tenlife

2020/09/03 08:04

回答ありがとうございます! 提示された方法でも上手く表示できませんでした。エラーになってしまいました。 似ているなと思い下記も試したのですが上手くいかずでした。。 <form :action="url"> 書けないものなんですかね。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問