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

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

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

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

Laravel

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

SEO

SEO(Search Engine Optimization)は、検索エンジンでウェブページがランキング上位に上がるように工夫する様々なテクニックの事です。

Q&A

解決済

2回答

1971閲覧

Vue.jsの速度改善について質問

s15ak071

総合スコア13

Vue.js

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

Laravel

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

SEO

SEO(Search Engine Optimization)は、検索エンジンでウェブページがランキング上位に上がるように工夫する様々なテクニックの事です。

0グッド

1クリップ

投稿2019/12/18 03:44

編集2019/12/18 03:46

##質問
Laravel5.x系でJavaScriptの標準フレームワークであるVue.jsを利用しているのですが
バンドル後のJSファイルが(app.js)肥大化して重いです。SEO的にかなりペナルティーを受けているのですが
以下の設計レベルで詳しい方、参考までに速度改善案の意見がほしいです!

##現状
LaravelのVue.jsを利用しており、スマホtopの単一ローカルコンポーネントでページ丸ごとVue.jsのコンポーネント化を行っています。

##課題
SEOで得点が最低、app.jsの肥大化3万行近く。
バンドルJSに複数の利用ライブラリが存在(vuex,dayjs等々)。

##既にやったこと
・Dynamic Import
・Lazyloadで画像の遅延読み込み
・laravelmix のwebpack.mix.jsでextract指定でライブラリ分割

##やりたかったこと
・まるまる1ページをVue.jsのコンポーネント化を行う
・AtomicDesignのOrganismsとMoleculeレベルで.vueファイル作成
・ヘッダーやフッター、検索ボックスをカスタムタグで呼び出したい。Ex. <header></header>, <searchbox></searchbox>..
・Vue-routerやvue-cliの利用はしない、nuxt.jsも利用無し
・cssやhtmlのdom、そしてjsの記述までもすべて.vueファイルの中に含んでエラーが起きたら、その中だけみればいいようにしたい。(脱スパゲッティーコード)

Javascript

1import HeaderComponent from "{ディレクトリ省略}/HeaderComponent.vue"; 2import FooterComponent from "{ディレクトリ省略}/FooterComponent.vue"; 3import GlobalNaviComponent from "{ディレクトリ省略}/GlobalNaviComponent.vue"; 4import SearchBoxComponent from "{ディレクトリ省略}/SearchBoxComponent.vue"; 5 6 7require("./bootstrap"); 8 9var app = new Vue({ 10 el: "#app", 11 components: { 12 "header-componet" : HeaderComponent, 13 "footer-component" : FooterComponent, 14 "globalnavi-component" : GlobalNaviComponent, 15 "searchbox-component" : SearchBoxComponent, 16 } 17});

質問にご不明点があれば、追加で回答したいと思います。
初心者で全然わからないので、企業レベルでどうしたらいいか詳しいひと、実務で使ったことある人に質問できればと思います!

そもそもLaravelのサンプルにあるファイルの拡張でVue.jsを動かすのはありなのかという悩みです

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

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

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

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

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

guest

回答2

0

resources=>GlobalComponents.js

import AppIndex from "Components/**/AppIndex"

const GlobalComponents = {
install(Vue) {
Vue.component('appIndex', AppIndex);
// appIndexの中身は必要に応じてダイナミックで外部ファイル読み込む
// const title = ()=> import('');
}
}

export default GlobalComponents

resources=>app.js
// global components
import GlobalComponents from './globalComponents'
Vue.use(GlobalComponents);

new Vue({
//必要に応じて
}).$mount('#app')

webpack
mix.webpackConfig({
output: {
chunkFilename: mix.inProduction()
? "prod/chunks/[name]?id=[chunkhash].js"
: "dev/chunks/[name].js"
}
})
.js("resources/js/main.js", "public/js")
.sass("resources/js/assets/scss/_style.scss", "public/css/style.css");

投稿2020/02/13 15:06

_makoto

総合スコア38

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

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

0

ベストアンサー

バンドルサイズが問題ということであれば、webpack-bundle-analyzerを使って解析するところから初めて見ると良いと思います。

投稿2020/01/01 11:16

gyarasu

総合スコア148

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

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

s15ak071

2020/01/06 02:00

解答ありがとうございます
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問