まず、親切にしてください。VueJSのテンプレートを入れ替えずにフォーム提出を処理する
私はVueJSを使って、フローティングヘッダーやフォームの提出などの簡単なことを行うために、VueJSを使用しています。私は、私の連絡フォームが自分のHTML(CMSによってレンダリングされたもの)に表示されるようにマークアップする必要があります.VueJSでフォームの送信を処理していただき、ありがとうございます。したがって、フォームの簡略版はこのようになります。
<contact-form>
<form class="contact-form_form">
...
<input name="emailaddress" type="text" />
...
<button></button>
</form>
<div class="contact-form_thanks">
Thanks for filling in this lovely form
</div>
</contact-form>
ので、行うには明白なことは、VueJSコンポーネントを作成することですが、私はAxiosを使用して(私はボタンが押されたとき、それはフォームを送信したい、それが新しいテンプレートを導入する必要はありません)フォームを非表示にして、ありがとうメッセージを表示します。
属性ディレクティブとng-show/hideなどを使用してすべての角度でこれを行う方法はわかっていますが、すべてのチュートリアルがSPAおよび単一ファイルコンポーネントに対応しているため、VueJSでこれを行う方法は実際は分かりませんテンプレート付き。
正しい方向へのどんなキックも感謝します。
こんにちはロイ、答えてくれてありがとう。これはうまくいくが、私は再利用できるようにしたいので、コンポーネントを作成して、コンタクトフォームがサイトで使用されている場所であれば、Vueのメインインスタンスにこれらのメソッドとデータを持たなくても動作するようにしたい。 – jon64digital
Ta-da!それはコンポーネントです。フォームの内容を[スロット](https://vuejs.org/v2/guide/components.html#Content-Distribution-with-Slots)にしますか? –