以前介绍了 webpack在多页项目中的探索那篇有极大得不住,还有极大得改善空间,并不完美,不建议用在生产环境,实际上是如今不想去优化,懒 :)
javascript
thinkjs + vue + vueRouter + webpack 的 SPA配置html
(其实能够看个人一个repo thinkjs+vue的单页blog尝试 )前端
因为后台使用了 thinkjs
框架的ES6模式vue
src
为后台编写文件, app
则为后台编译后的文件java
线上的页面须要放在 view/home
下webpack
静态资源文件全放在 www/static
下git
前端开发目录为 source
github
- source - common // 公用.vue - components // 对应controller下的组件 - static // 第三方静态资源 - unitTest // 数据测试json - views // 页面 index.html // 主站入口html index.sass // 主站全局sass main.js // 主站入口js router.js // 主站路由
output要好好设置,这涉及到开发环境下,你的路径去哪里找js.以及build后线上环境又是怎么样的个路径去找jsweb
有的人可能有疑问,vue-cli生成的项目.为何直接 npm run dev
就能够开始跑了呢?明明连js文件都没有,浏览器怎么还能找到文件呢?vue-cli
其实这就是webpack的一个强大之处,在dev过程当中,js的确有编译,可是仅仅是编译在内存中,你的确看不见那个文件,因此同样可使用 (能够看看这个:http://www.meckodo.com/?p=721)
了解这一点后,咱们的output就很明白到底要如何设置了
output: { path: path.resolve(__dirname, './www/static'), publicPath: '/static/', chunkFilename: 'js/[id].js', filename: '[name].build.js' }
文字表达的确很难能感觉到是为何,建议你们clone我这个repo,而后感觉下具体是怎么样的过程.
在SPA中,咱们就能够用webpack插件来为咱们生成html模板到所对应的目录了.
//webpack的plugin里加入如下插件 new HtmlWebpackPlugin({ //为了配合thinkjs的目录定义 须要输出在view/home/[controller]/index.html 下 filename : "../../view/home/index/index.html", template : "./source/index.html", inject:false })
别的基本大同小异,我就不具体再介绍一次了
npm run dev
主站 http://localhost:8200/source/index.html
npm run build
npm run start