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

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

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

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

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

Q&A

解決済

2回答

297閲覧

laravelとvueの連携について

yamamoto_1121

総合スコア13

Vue.js

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

Laravel 5

Laravel 5は、PHPフレームワークLaravelの最新バージョンで、2014年11月に発表予定です。ディレクトリ構造がが現行版より大幅に変更されるほか、メソッドインジェクションやFormRequestの利用が可能になります。

0グッド

0クリップ

投稿2018/12/09 14:36

前提・実現したいこと

laravelベースのwebアプリを作っているのですが、動的に入力値を増やせるようにform部分をvue.jsで作成しようと思っています。
###問題点
そのためにまずvueをblade上で使おうと思ったのですが、いくつかうまくいかないことがあります。一つはv-onやv-bindを使った変数の操作が出来ない事で、もう一つはmethodsのaddが動いてくれません。numの0は正常に表示されます。

該当のソースコード

blade

1//略 2 <script src="{{ asset('js/dist/test.js') }}"></script> 3 <div id="app"> 4 <p>@{{ num }}</p> 5 <button v-on:click="add">add button</button> 6 </div> 7//略

js

1 import Vue from 'vue'; 2 new Vue({ 3 el: '#app', 4 data() { 5 return { 6 num:0, 7 } 8 }, 9 methods: { 10 add(){ 11 this.num++; 12 } 13 } 14 });

現状

larave、vue間での値の受け渡しがblade上で出来るため楽だと思い、test.jsを別でコンパイルし読み込んでいます。
laravelとvueの経験が浅いため連携の方法がこれでいいのかも不安があります。
axiosを利用した方法でデータのやり取りができることは調べているときに分かったのですが、わざわざapiを通す利点がわかりません...

初投稿であるため質問自体に不備もあると思いますが、どうか詳しい方よろしくお願いします。

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

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

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

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

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

guest

回答2

0

解決しているかもしれないですが、Laravel側にvueコンポーネントを埋め込めば動作します。

Btn.vue

<template> <div> <p>@{{ num }}</p> <button v-on:click="add">add button</button> </div> </template> <script> export default { data() { return { num:0, } }, methods: { add(){ this.num++; } } } </script>

app.js

Vue.component('btn', require('./components/Btn.vue')); ※パスはローカルに合わせてください

blade

<div id="app"> <btn></btn> </div>

投稿2018/12/17 06:49

yappi_tengen

総合スコア23

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

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

0

ベストアンサー

テンプレのような間違った使い方。
LaravelでVue使うなら必ずVueコンポーネントを使う。

一人で考えた良し悪しよりもフレームワークが用意してる普通の使い方のほうが正しい。

投稿2018/12/09 16:01

kawax

総合スコア10377

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

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

yamamoto_1121

2018/12/21 02:38

回答ありがとうございます。 お二方が答えてくれた通りにコンポーネントを使った実装をやってみようと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問