资讯专栏INFORMATION COLUMN

基于gulp,webpack实现灵活的 livereload 服务

vboy1010 / 2251人阅读

摘要:假设后台使用端口,我们使用模式需要如下配置现在可以启动服务了,但同时请求也要修改为这样才能进行热加载。

webpack 提供了 webpack-dev-server 可以实现高效的页面自动刷新,但是这个 server 有一点局限性:

虽然可以做为 server 中间件使用,但本身不提供其它资源的静态服务

对于打包文件以外的变化它是无知的,也就无法去刷新

如果是自己的页面需要引入 script,修改配置 entry,自己另外提供文件服务,步骤繁琐

现在假设我们有自己的 html 页面,页面引入了本地的 css,但是 js 是由 webpack 打包的,需要实现文件修改自动刷新的页面的话我们需要以下几个模块:

文件监视 - gulp.watch()

静态资源服务 - gulp-serve 模块

livereload服务 (负责接受变化请求并通知页面刷新) - gulp-livereload 模块

自动添加 livereload 前端脚本 - connect-livereload 模块 (或者使用livereload浏览器插件)

代码如下:

</>复制代码

  1. // npm i gulp-serve gulp-livereload webpack gulp-util gulp connect-livereload -D
  2. var serve = require("gulp-serve")
  3. var livereload = require("gulp-livereload")
  4. var webpack = require("webpack")
  5. var gutil = require("gulp-util")
  6. var gulp = require("gulp")
  7. var webpackConfig = require("./webpack.config.js")
  8. var inject = require("connect-livereload")()
  9. var path = require("path")
  10. var myConfig = Object.create(webpackConfig)
  11. // for debugging
  12. myConfig.devtool = "sourcemap"
  13. myConfig.debug = true
  14. var paths = {
  15. scripts: ["index.js"],
  16. // file list for watching
  17. asserts: ["*.css", "index.html"]
  18. }
  19. gulp.task("default", ["build-dev"])
  20. gulp.task("build-dev", ["webpack:build-dev", "serve"], function () {
  21. livereload.listen({
  22. start: true
  23. })
  24. // build js files on change
  25. gulp.watch(paths.scripts, ["webpack:build-dev"])
  26. var watcher = gulp.watch(paths.asserts)
  27. watcher.on("change", function (e) {
  28. livereload.changed(e.path)
  29. })
  30. })
  31. // static server
  32. gulp.task("serve", serve({
  33. root: [__dirname],
  34. // inject livereload script ot html
  35. middleware: inject
  36. }))
  37. var devCompiler = webpack(myConfig)
  38. var outputFile = path.resolve(myConfig.output.path, myConfig.output.filename)
  39. gulp.task("webpack:build-dev", function (callback) {
  40. devCompiler.run(function (err, stats) {
  41. if (err) throw new gutil.pluginError("webpack:build-dev", err) //eslint-disable-line
  42. gutil.log("[webpack:build-dev]", stats.toString({
  43. colors: true
  44. }))
  45. livereload.changed(outputFile)
  46. callback()
  47. })
  48. })

这种做法最大的好处就是 html 和 css 不用都让 webpack 去处理也能做到自动刷新,但是相比 webpack-dev-server, 它是JS全部重新打包的,所以性能会差很多,此时我们可以使用 webpack-dev-server 实现打包文件的监听,同时让原来后台提供其它文件服务。假设后台使用 3000 端口,我们使用 webpack-dev-server inline模式需要如下配置:

</>复制代码

  1. gulp.task("webpack:dev-server", function () {
  2. var devServerConfig = Object.create(myConfig)
  3. // webpack need this to send request to webpack-dev-server
  4. devServerConfig.output.publicPath = "http://localhost:8080/"
  5. devServerConfig.plugins = devServerConfig.plugins || []
  6. devServerConfig.plugins.push(new webpack.HotModuleReplacementPlugin())
  7. // inline mode
  8. devServerConfig.entry.unshift("webpack-dev-server/client?http://localhost:8080", "webpack/hot/dev-server")
  9. var compiler = webpack(devServerConfig)
  10. new WebpackDevServer(compiler, {
  11. contentBase: "http://localhost:3000/",
  12. // Set this as true if you want to access dev server from arbitrary url.
  13. // This is handy if you are using a html5 router.
  14. historyApiFallback: false,
  15. // Don"t forget this for dev-server
  16. publicPath: "/build/",
  17. lazy: false,
  18. hot: true
  19. }).listen(8080, "localhost", function (err) {
  20. if (err) throw new gutil.PluginError("webpack-dev-server", err)
  21. // Server listening
  22. gutil.log("[webpack-dev-server]", "http://localhost:8080/")
  23. })
  24. })

gulp webpack:dev-server 现在可以启动服务了,但同时请求 bundle.js script也要修改为:

</>复制代码

这样 webpack-dev-server 才能进行热加载。

还有一种看起来更好的方式是使用 proxy 来代理,此时你访问 webpack-dev-server时它无法处理的请求都会转发给你的后台服务,配置起来相比上面要简单一些:

html 页面无需修改

config.output.publicPath 使用原来的相对路径

webpack-dev-server 配置 proxy 选项

</>复制代码

  1. gulp.task("webpack:dev-server", function () {
  2. var devServerConfig = Object.create(myConfig)
  3. // webpack need this to send request to webpack-dev-server
  4. devServerConfig.plugins = devServerConfig.plugins || []
  5. devServerConfig.plugins.push(new webpack.HotModuleReplacementPlugin())
  6. // inline mode
  7. devServerConfig.entry.unshift("webpack-dev-server/client?http://localhost:8080", "webpack/hot/dev-server")
  8. var compiler = webpack(devServerConfig)
  9. new WebpackDevServer(compiler, {
  10. // contentBase: {target: "http://localhost:3000/"},
  11. // Set this as true if you want to access dev server from arbitrary url.
  12. // This is handy if you are using a html5 router.
  13. historyApiFallback: false,
  14. proxy: {
  15. "*": "http://localhost:3000"
  16. },
  17. publicPath: "/build/",
  18. lazy: false,
  19. hot: true
  20. }).listen(8080, "localhost", function (err) {
  21. if (err) throw new gutil.PluginError("webpack-dev-server", err)
  22. // Server listening
  23. gutil.log("[webpack-dev-server]", "http://localhost:8080/")
  24. })
  25. })

这么做只需要访问 webpack-dev-server 就可以直接访问页面,其它设备通过 ip 也能直接访问到,免去了修改的麻烦。其实 webpack-dev-server 如果可以直接添加静态文件服务的功能,我们有时就不必折腾的这么麻烦了,大概是作者不想破坏它功能上的简洁以及避免滥用导致不良的后果吧。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/86085.html

相关文章

  • javascript 迁移 typescript 实践

    摘要:但是,从长远来看,尤其是多人协作的项目,还是很有必要的。第二参数为了某些场景下要大写强调,只需要传入即可自动将结果转成大写。这个有可能是业务上线了之后才发生,直接导致业务不可用。而这也被证明是个好的编码方式。 只是抱着尝试的心态对项目进行了迁移,体验了一番typeScript的强大,当然,习惯了JavaScript的灵活,弱类型,刚用上typeScript时会很不适应,犹如懒散惯了的人...

    niceforbear 评论0 收藏0
  • gulp管理自己前端开发任务及需要注意

    摘要:但是频繁的关闭服务与重启服务,这样就造成了很多时间浪费,所以我们需要利用来监视文件的改动,并将这些改动重新发布到生产目录,并重启服务非手动。三预处理器文件编译暂时没用到,后面用到再增加,可以参考其他人的 关于gulp,grunt,webpack,刚走前端模块化的我,真的是傻傻分不清楚,幸好有大神各种答疑解惑,使我略知一二,你也想知道的,也许还想知道点啥,资源罗列:1、中文官方文档;2、...

    gplane 评论0 收藏0
  • gulp组织小型项目小记

    摘要:目前正在开发一个系统,对于前端模块化与打包这块出现了一些选择。采用模块化及打包由于项目比较小,稍微了解后,觉得没必要采用。组件化,目前比较流行的如等。项目较小需要交互更新页面的并不多,没有采用。 目前正在开发一个python markdown wiki系统,对于前端模块化与打包这块出现了一些选择。1、采用webpack模块化及打包由于项目比较小,稍微了解后,觉得没必要采用webpack...

    2json 评论0 收藏0
  • gulp组织小型项目小记

    摘要:目前正在开发一个系统,对于前端模块化与打包这块出现了一些选择。采用模块化及打包由于项目比较小,稍微了解后,觉得没必要采用。组件化,目前比较流行的如等。项目较小需要交互更新页面的并不多,没有采用。 目前正在开发一个python markdown wiki系统,对于前端模块化与打包这块出现了一些选择。1、采用webpack模块化及打包由于项目比较小,稍微了解后,觉得没必要采用webpack...

    Heier 评论0 收藏0
  • 前端工程化篇之 Gulp

    摘要:是一个构建工具,基于的平台运行,使用的是的模块化语法。我们使用需要用到的包一个任务,对应一个包,对应一个处理逻辑对应的是同步任务,从左到右,依次执行任务。时间长对应的是异步任务,效率高,时间短。 gulp 是一个构建工具,基于Node.js的平台运行,使用的是commonJs的模块化语法。 我们使用gulp需要用到的包 一个TASK任务,对应一个包,对应一个处理逻辑、 gulp.s...

    Donald 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<