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

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

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

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

Laravel 5

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

受付中

vue.jsを使う人の思想を知りたいです(できればサーバーサイドメインの開発者目線の意見で)

退会済みユーザー

退会済みユーザー

総合スコア0

Vue.js

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

Laravel 5

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

3回答

1評価

0クリップ

7478閲覧

投稿2018/11/23 20:22

現在開発中のプロダクトで、ユーザーの種類が大きく分けて「個人ユーザー」と「企業ユーザー」があります。
ユーザー登録すると、個人ユーザーの権限が割り当てられます。
ログイン後に「企業成申請」という機能があり今作っている部分でもあるのですが、企業成申請画面では企業形態のセレクトボックスがあり、は大きく分けて、「株式会社」「有限会社」「個人事業主」があります。

企業形態によって入力する内容が異なります。

私はサーバーサイドエンジニアなのですが、いつものやり方だと、セレクトボックスにid指定しておいて、外部jsファイルで対象のidの要素が変更されたらajax通信でセレクトボックスの項目が現在何であるかをサーバー側で判定して、それに応じたhtmlをサーバー側で生成してhtmlを返してappendして動的に要素を生成しています。

最近vue.jsを使っている現場も増えてきているので、試しにやってみようと思ってtyrしてみたのですが正直メリットがよくわかりません。

ネット記事で、「vue メリット」で検索しても、効率よく開発したいならvueを使うべきということをよく見かけますが、どれも抽象的な内容で具体的なメリットがわかりません。

laravelを使っていて、今回vueを実際試して思ったことですが、controllerからbladeに渡った変数がvueファイル内で使えないので、例えばバリデーションエラーなどもわざわざvueのcomponentに渡さなければならないですし、$errors->hasなどのヘルパー関数も使えないのでむしろ非効率だと思ってしまいます。

バリデーションに関してはこういう記事もあるみたいですが、uniqueやexistsなどのバリデーションルールを使いたいときもajax通信走らせないといけないし、結構手間だと思いました。(vueを否定しているわけではないです。)

vueを使わず、普通にajax処理を分業でするパターンを想定してみても、フロントエンジニアには、「これとこれとこれの項目が必要でname属性は~~~で実装お願いします」で分業できますし、vueを使うことで分業が効率化するという結論には至らないのです。

csrfトークンもformが必要なcomponentには毎回dataセットしなければならないし、、、

<input id="csrf" name="_token" type="hidden" :value="csrfToken"> <script> export default { data() { return { csrfToken: document.querySelector('meta[name="csrf-token"]').getAttribute('content'), } }, } </script>

componentを集めてビューを作り込んでいくのがvueみたいですが、cakephpでいうところのelementと同じだと思っています。

それでもvueを使うメリットを知りたいのです。

唯一いいなぁ〜と思ったのがJqueryをラップしているらしいaxiosです。

これはvueを使うしかない!と思うような例があればvueを好きになれるかもしれません。

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Vue.js

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

Laravel 5

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