npm script 的文件监听和自动刷新的命令详解

 更新时间:2020年05月14日 14:39:04   作者:前端也疯狂  
文件监听的作用是为了实现自动化,释放双手和精力,提高效率,让开发者更加关注于开发。这篇文章主要介绍了npm script 的文件监听和自动刷新,需要的朋友可以参考下

文件监听的作用是为了实现自动化,释放双手和精力,提高效率,让开发者更加关注于开发。npm script 文件监听和 grunt、gulp 功能类似。

自动刷新,意思就是改动文件保存后,页面自动刷新,减少日常开发的操作。

代码检查的监听和自动化

代码检查工具 stylelint、eslint、jsonlint 这些对 watch 支持很弱,所以就需要引入工具包 onchange

安装命令依赖包

npm i onchange -D
// 或
yarn add onchange -D

编写命令

"scripts": {
 "//watch": "# 监听", 
 "test": "# 单元测试 \n cross-env NODE_ENV=test mocha tests/",
 "watch:test": "npm test -- --watch",
 "watch:lint": "onchange -i \"**/*.js\" \"**/*.less\" -- npm run lint:css",
 "watch": "npm-run-all --parallel watch:*",
}

剖析命令

  • 使用 \" 是为了实现跨平台兼容;
  • 使用了 **/* 匹配通配符;
  • 参数 -i 是让 onchange 在启动时就运行一次 -- 之后的命令;

执行命令

npm run watch

实现自动刷新

本章主要说的是livereload。

安装命令依赖包

npm i livereload -D
// 或
yarn add livereload -D

编写命令

"scripts": {
 "//livereload": "# 自动刷新",
 "client": "npm-run-all --parallel client:*",
 "client:reload-server": "livereload src/",
 "client:static-server": "http-server src/"
}

页面添加连接 js 脚本

// src/index.html
<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <meta name="viewport" content="width=device-width, initial-scale=1.0">
 <meta http-equiv="X-UA-Compatible" content="ie=edge">
 <title>npm script</title>
 <link rel="stylesheet" href="./index.css" rel="external nofollow" >
</head>
<body>
 <h1>你好,npm script</h1>
 
 <script>
 var ctx = '<script src="http://' + (location.host || 'localhost').split(':')[0] +
 ':35729/livereload.js?snipver=1"></' + 'script>';
 document.write(ctx)
 </script>
</body>
</html>

/* src/index.css */
body {
 color: #fff;
 background-color: green;
}

总结

以上所述是小编给大家介绍的npm script 的文件监听和自动刷新的命令详解,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

相关文章

  • TCP协议详解_动力节点Java学院整理

    TCP协议详解_动力节点Java学院整理

    本文描述了TCP协议,首先简单介绍了TCP完成了一些什么功能;介绍了TCP报文格式,以及典型报文的数据格式。现在通过本文给大家详细介绍,感兴趣的的朋友一起看看吧
    2017-07-07
  • 树莓派安装mjpg-streamer使用摄像头的方法

    树莓派安装mjpg-streamer使用摄像头的方法

    这篇文章主要介绍了树莓派安装mjpg-streamer使用摄像头,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-03
  • 码云git图文使用详解教程

    码云git图文使用详解教程

    这篇文章主要介绍了码云git图文使用详解教程,需要的朋友可以参考下
    2020-11-11
  • Git Submodule使用完整教程(小结)

    Git Submodule使用完整教程(小结)

    这篇文章主要介绍了Git Submodule使用完整教程(小结),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • vscode检测到#include错误请更新includePath的解决方法

    vscode检测到#include错误请更新includePath的解决方法

    这篇文章主要介绍了vscode检测到#include错误请更新includePath的解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • 算法系列15天速成 第六天 五大经典查找【下】

    算法系列15天速成 第六天 五大经典查找【下】

    大家是否感觉到,树在数据结构中大行其道,什么领域都要沾一沾,碰一碰
    2013-11-11
  • 详解使用Postman模拟浏览器的HTTP请求并获取返回数据

    详解使用Postman模拟浏览器的HTTP请求并获取返回数据

    这篇文章主要为大家介绍了在浏览器中,获取网页中的某一个请求信息,并将其导入到Postman软件,并进行API请求测试的方法,需要的可以参考下
    2024-03-03
  • 不懂编程该如何使用AI 编程技巧详解

    不懂编程该如何使用AI 编程技巧详解

    在当今数字化时代,编程不再是专属于程序员的领域,通过人工智能(AI)的协助,甚至是非编程专业人士也能轻松涉足,对于那些没有编程基础却渴望利用 AI 进行编程的人来说,AI 就是你编程学习的得力伙伴
    2023-11-11
  • htaccess语法教程

    htaccess语法教程

    前些天不小心删除了原来的博客系统,问过godaddy的客服,恢复数据需要150美元,另外还需要提供不少信息,我于是放弃,注册了这个nunumick.me,打算从头再来。
    2011-09-09
  • Git中smart Checkout与force checkout的区别及说明

    Git中smart Checkout与force checkout的区别及说明

    这篇文章主要介绍了Git中smart Checkout与force checkout的区别及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08

最新评论