热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用npm脚本同时启动多个监听服务的技巧

本文介绍了如何利用npm脚本和concurrently工具,实现本地开发环境中多个监听服务的同时启动,包括HTTP服务、自动刷新、Sass和ES6支持。

在构建一个以静态页面为主的网站时,如果使用Vue或React显得有些大材小用,而纯HTML/CSS/JS又不够灵活。因此,我们选择通过npm手动搭建一个简单的本地开发环境,以满足以下需求:

  • 启动HTTP服务,并自动打开浏览器;
  • 实现浏览器自动刷新,当源码发生变化时,浏览器内容自动更新;
  • 支持Sass语法,将Sass代码实时转换为CSS;
  • 支持ES6语法,使用Babel将ES6代码转换为ES5。

为了实现这些功能,我们可以在项目中安装并配置以下工具:

  • 通过live-server实现HTTP服务和自动浏览器刷新;
  • 通过node-sass实现Sass语法支持;
  • 通过babel-cli实现ES6语法支持。

接下来,我们将这些命令配置到package.json中的scripts字段中:

"scripts": {  "test": "echo \"Error: no test specified\" && exit 1",  "start": "sass --watch pc/static/scss:pc/static/css mobile/static/scss:mobile/static/css --sourcemap=none && live-server --port=1208 && babel pc/static/es6-js -d pc/static/js --watch && babel mobile/static/es6-js -d mobile/static/js --watch && echo 好好工作!"}

然而,在运行时发现了一个问题:使用&&连接的命令会按顺序执行,一旦遇到类似sass --watch这种“阻塞”命令,后续命令将无法执行。

为了解决这个问题,我们可以使用concurrently工具。它允许并发执行多个命令,确保所有服务都能正常启动。具体步骤如下:

  • 安装concurrentlynpm install concurrently --save-dev
  • 修改package.json中的scripts字段:
"scripts": {  "test": "echo \"Error: no test specified\" && exit 1",  "start": "concurrently \"sass --watch pc/static/scss:pc/static/css mobile/static/scss:mobile/static/css --sourcemap=none\" \"live-server --port=1208\" \"babel pc/static/es6-js -d pc/static/js --watch\" \"babel mobile/static/es6-js -d mobile/static/js --watch\" \"echo 好好工作!\""}

现在,只需在项目目录下运行npm start即可启动所有服务。这样不仅简化了操作流程,还提高了开发效率。

总结:
通过使用concurrently工具,我们能够轻松地在本地开发环境中并行启动多个监听服务,从而提升开发体验。希望本文能对您有所帮助,如果您有任何疑问,请随时留言交流。


推荐阅读
  • 基于Node.js、Express、MongoDB和Socket.io的实时聊天应用开发
    本文详细介绍了使用Node.js、Express、MongoDB和Socket.io构建的实时聊天应用程序。涵盖项目结构、技术栈选择及关键依赖项的配置。 ... [详细]
  • Symfony是一个功能强大的PHP框架,以其依赖注入(DI)特性著称。许多流行的PHP框架如Drupal和Laravel的核心组件都基于Symfony构建。本文将详细介绍Symfony的安装方法及其基本使用。 ... [详细]
  • Vue 开发与调试工具指南
    本文介绍了如何使用 Vue 调试工具,包括克隆仓库、安装依赖包、构建项目以及在 Chrome 浏览器中加载扩展的详细步骤。 ... [详细]
  • 本文探讨了2019年前端技术的发展趋势,包括工具化、配置化和泛前端化等方面,并提供了详细的学习路线和职业规划建议。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • 如何在WPS Office for Mac中调整Word文档的文字排列方向
    本文将详细介绍如何使用最新版WPS Office for Mac调整Word文档中的文字排列方向。通过这些步骤,用户可以轻松更改文本的水平或垂直排列方式,以满足不同的排版需求。 ... [详细]
  • 本文介绍如何通过Windows批处理脚本定期检查并重启Java应用程序,确保其持续稳定运行。脚本每30分钟检查一次,并在需要时重启Java程序。同时,它会将任务结果发送到Redis。 ... [详细]
  • 本文将深入探讨如何在不依赖第三方库的情况下,使用 React 处理表单输入和验证。我们将介绍一种高效且灵活的方法,涵盖表单提交、输入验证及错误处理等关键功能。 ... [详细]
  • 本文详细介绍了在企业级项目中如何优化 Webpack 配置,特别是在 React 移动端项目中的最佳实践。涵盖资源压缩、代码分割、构建范围缩小、缓存机制以及性能优化等多个方面。 ... [详细]
  • 程序员如何优雅应对35岁职业转型?这里有深度解析
    本文探讨了程序员在职业生涯中如何通过不断学习和技能提升,优雅地应对35岁左右的职业转型挑战。我们将深入分析当前热门技术趋势,并提供实用的学习路径。 ... [详细]
  • 本文将指导如何向ReactJS计算器应用添加必要的功能,使其能够响应用户操作并正确计算数学表达式。 ... [详细]
  • 本文深入探讨了JavaScript中实现继承的四种常见方法,包括原型链继承、构造函数继承、组合继承和寄生组合继承。对于正在学习或从事Web前端开发的技术人员来说,理解这些继承模式对于提高代码质量和维护性至关重要。 ... [详细]
author-avatar
koglum
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有