From 7823eb8fd364a801cd57a4d5fe4f00b4c9c562e8 Mon Sep 17 00:00:00 2001 From: Sebastian Frank Date: Fri, 1 Sep 2017 17:49:37 +0200 Subject: [PATCH] separate views bundle --- index.html | 2 +- package-lock.json | 6 +++ package.json | 1 + src/main.js | 96 ++++++++++++++++++++++++----------------------- webpack.config.js | 10 ++--- 5 files changed, 62 insertions(+), 53 deletions(-) diff --git a/index.html b/index.html index 0974e38..16f76a3 100644 --- a/index.html +++ b/index.html @@ -21,7 +21,7 @@
- + \ No newline at end of file diff --git a/package-lock.json b/package-lock.json index 912fdc2..41cb31c 100644 --- a/package-lock.json +++ b/package-lock.json @@ -530,6 +530,12 @@ "babel-runtime": "6.26.0" } }, + "babel-plugin-syntax-dynamic-import": { + "version": "6.18.0", + "resolved": "https://registry.npmjs.org/babel-plugin-syntax-dynamic-import/-/babel-plugin-syntax-dynamic-import-6.18.0.tgz", + "integrity": "sha1-jWomIpyDdFqZgqRBBRVyyqF5sdo=", + "dev": true + }, "babel-plugin-transform-es2015-arrow-functions": { "version": "6.22.0", "resolved": "https://registry.npmjs.org/babel-plugin-transform-es2015-arrow-functions/-/babel-plugin-transform-es2015-arrow-functions-6.22.0.tgz", diff --git a/package.json b/package.json index 9b2c92d..5ebb81b 100644 --- a/package.json +++ b/package.json @@ -19,6 +19,7 @@ "babel-core": "^6.26.0", "babel-eslint": "^7.2.3", "babel-loader": "^7.1.2", + "babel-plugin-syntax-dynamic-import": "^6.18.0", "babel-preset-es2015": "^6.24.1", "css-loader": "^0.28.5", "eslint": "^4.5.0", diff --git a/src/main.js b/src/main.js index 5199f84..39df3a3 100644 --- a/src/main.js +++ b/src/main.js @@ -5,7 +5,7 @@ import Axios from 'axios'; import JwtDecode from 'jwt-decode'; import App from './app.vue'; -import Views from './views/views.js'; +// import Views from './views/views.js'; Vue.use(VueRouter); Vue.use(Vuex); @@ -163,52 +163,56 @@ if (persist) { store.state.persist = persist; } -// load init -Axios.get('conf/init.json') - .then(results => { + +// load views +import(/* webpackChunkName: "views" */ './views/views.js').then(Views => { + // load init + Axios.get('conf/init.json') + .then(results => { // set navigation - if (!Array.isArray(results.data.routes)) { - alert('invalid data in init.json, no routes'); - return; - } + if (!Array.isArray(results.data.routes)) { + alert('invalid data in init.json, no routes'); + return; + } - // set ui config in store - store.commit("setUI", results.data.ui); + // set ui config in store + store.commit("setUI", results.data.ui); - // add routes - let routes = []; - let rIdx = 0; - results.data.routes.forEach(({name, to, content, data}) => routes.push({ - name: name, - path: to, - meta: { - title: name - }, - component: Vue.component(name + rIdx++, { - template: '
' + content + '
', - components: Views, - data: function(data) { - if (typeof data != 'object') { - return () => { return {}; }; - } - return () => { return data; }; - }(data) - }) - })); - router.addRoutes(routes); - router.beforeEach((to, from, next) => { - document.title = (to.meta && to.meta.title) ? results.data.title + ': ' + to.meta.title : results.data.title; - next(); + // add routes + let routes = []; + let rIdx = 0; + results.data.routes.forEach(({name, to, content, data}) => routes.push({ + name: name, + path: to, + meta: { + title: name + }, + component: { + template: '
' + content + '
', + components: Views.default, + data: function(data) { + if (typeof data != 'object') { + return () => { return {}; }; + } + return () => { return data; }; + }(data) + } + })); + router.addRoutes(routes); + router.beforeEach((to, from, next) => { + document.title = (to.meta && to.meta.title) ? results.data.title + ': ' + to.meta.title : results.data.title; + next(); + }); + + // load app, when init finishs + new Vue({ + el: '#vue-app', + render: h => h(App), + router, + store + }); + }) + .catch(error => { + alert('error loading: ' + error.message); }); - - // load app, when init finishs - new Vue({ - el: '#vue-app', - render: h => h(App), - router, - store - }); - }) - .catch(error => { - alert('error loading: ' + error.message); - }); \ No newline at end of file +}); \ No newline at end of file diff --git a/webpack.config.js b/webpack.config.js index 5cafa3b..5e5f065 100644 --- a/webpack.config.js +++ b/webpack.config.js @@ -3,7 +3,6 @@ var path = require('path'); // Naming and path settings -var appName = 'app'; var entryPoint = './src/main.js'; var exportPath = path.resolve(__dirname, './build'); @@ -27,9 +26,6 @@ if (env === 'production') { } )); - appName = appName + '.js'; -} else { - appName = appName + '.js'; } // Main Settings config @@ -43,7 +39,8 @@ module.exports = { output: { path: exportPath, publicPath: 'build/', - filename: appName + filename: '[name].bundle.js', + chunkFilename: '[name].bundle.js' }, module: { loaders: [{ @@ -65,7 +62,8 @@ module.exports = { exclude: /(node_modules|bower_components)/, loader: 'babel-loader', query: { - presets: ['es2015'] + presets: ['es2015'], + plugins: ['syntax-dynamic-import'] } }] },