Browsersync能让浏览器实时、快速响应你的文件更改(html、js、css、sass、less等)并自动刷新页面。更重要的是 Browsersync可以同时在PC、平板、手机等设备下进项调试。你的任何一次代码保存,以上的设备都会同时显示你的改动”。

  Browsersync可以单独使用,也可以集成到gulp和grunt这样的构建工具中使用,在node.js项目中还能结合gulp-nodemon实现全栈的自动刷新,而在移动端设备上同步调试的功能对移动web开发显然是很有帮助的。

  相关网站查看 :

Browsersync中文网 - 省时的浏览器同步测试工具  http://www.browsersync.cn/

Browsersync + Gulp.js - Browsersync中文网       http://www.browsersync.cn/docs/gulp/

  一、单独使用Browersync官网都讲得很详细,在此不做赘述.

    二、结合gulp使用Browsersync.

   1..全局安装gulp:$ npm install -g gulp

   2..初始化项目生产package.json : $ npm init

   3..安装项目依赖 : $ npm install --save-dev gulp browser-sync

   4..在项目的gulpfile.js中新建任务 :

  1. var gulp = require('gulp');
  2.  
  3. // 调用 .create() 意味着你得到一个唯一的实例并允许您创建多个服务器或代理。
  4. var browserSync = require('browser-sync').create();
  5.  
  6. // 定义一个任务,任务的名字,该任务所要执行的一些操作
  7. gulp.task('watch', function() {
  8.  
  9. // 启动Browsersync服务。代理服务器(proxy)或静态服务器(server)
  10. browserSync.init({
  11.  
  12. // 设置监听的文件,以gulpfile.js所在的根目录为起点,如果不在根目录要加上路径,单个文件就用字符串,多个文件就用数组
  13. files: ["*.html", "css/*.css", "js/*.js"],
  14.  
  15. // 启动静态服务器,默认监听3000端口,设置启动时打开的index.html的路径
  16. server: { baseDir: "./" },
  17.  
  18. // 在不同浏览器上镜像点击、滚动和表单,即所有浏览器都会同步
  19. ghostMode: { clicks: true, scroll: true },
  20.  
  21. // 更改控制台日志前缀
  22. logPrefix: "learning browser-sync in gulp",
  23.  
  24. // 设置监听时打开的浏览器,下面的设置会同时打开chrome, firefox和IE
  25. browser: ["chrome", "firefox", "iexplore"],
  26.  
  27. // 设置服务器监听的端口号
  28. port: 8080 });
  29. }); 

    5..命令行中执行gulp watch任务即可启动browserSync监听.

  

    三、Browsersync结合nodemon实现node.js项目的全栈刷新.

   1..supervisor修改代码时可以自动重启服务器但不更更新浏览器,类似supervior工具的有nodemon(推荐)、node-dev、hotnode.

     2.. 使用gulp+browersync+nodemon结合全战刷新express项目分两步 :

      (1),使用gulp-nodemon插件代替nodemon,使用gulp-nodemon启动node服务

      (2),启动node服务之后启动Browersync任务,监听相关文件

      

  1. var gulp = require('gulp');
  2. // 调用 .create() 意味着你得到一个唯一的实例并允许您创建多个服务器或代理。
  3. var browserSync = require('browser-sync').create();
  4.  
  5. // 这里reload不加括号,只引用不调用
  6. // var reload = browserSync.reload;
  7. var nodemon = require('gulp-nodemon');
  8. gulp.task('server', function() {
  9. nodemon({
  10. script: 'app.js',
  11. // 忽略部分对程序运行无影响的文件的改动,nodemon只监视js文件,可用ext项来扩展别的文件类型
  12. ignore: ["gulpfile.js", "node_modules/", "public/**/*.*"],
  13. env: { 'NODE_ENV': 'development' } }).on('start', function() {
  14. browserSync.init({
  15. proxy: 'http://localhost:3000',
  16. files: ["public/**/*.*", "views/**", "routes/**"],
  17. port:8080 },
  18. function() {
  19. console.log("browser refreshed.");
  20. });
  21. });
  22. });

    

Browsersync结合gulp和nodemon实现express全栈自动刷新的更多相关文章

  1. gulp配置(编译压缩转码自动刷新注释全)

    参考自:http://www.sheyilin.com/2016/02/gulp_introduce/ 在原先基础上增加了less编译 es6转码资源地图等,修改了一部分的热刷新. gulpfile. ...

  2. 详解如何使用gulp实现项目在浏览器中的自动刷新

    情况描述: 我们很容易遇到这样一种情况: 我们并不是一开始就规划好了整个项目,比如可能接手别人的项目或者工程已经手动创建好了,现在要想利用gulp来实现浏览器自动刷新,那么如何做呢? 其实非常简单,本 ...

  3. gulp+browserSync+nodemon 实现express 全端自动刷新的实践

    学习过程宝宝心里苦,不能怨政府.. 兴趣所致,一直放不下nodejs的学习,时隔多日,又把express捡起来打算重新再学学,一直没什么太大的长进,和实际的项目经验.真的醉了,太懒了. 今天在重新研究 ...

  4. nodejs里的express自动刷新高级篇【转载】

    搬运自[简书:http://www.jianshu.com/p/2f923c8782c8]亲测可用哦! 最近在使用express框架及mongodb,由于前端和后端代码修改后都需要实现自动刷新功能,刚 ...

  5. express+gulp+gulp-nodemon+browser-sync自动刷新

    express自动生成项目.不在赘述 1.在项目根目录下新建终端,依次运行如下命令 npm install gulp --save-dev npm install gulp-nodemon --sav ...

  6. 一个 "开箱即用" 个人博客全栈系统项目!vue+node+express+mysql+sequlize+uniapp

    " MG'Blog " 一个 "开箱即用" 个人博客全栈系统项目! 探索本项目的源码 » 前台预览 · 管理端预览 v1.0.2 小程序预览 v1.0.2 介绍 ...

  7. 使用gulp+browser-sync搭建前端项目自动化以及自动刷新

    前段时间使用了gulp+browser-sync才发现这个东西真的很好用. 准备工作:(1).安装nodejs.gulp是基于nodejs使用的,所以先安装nodejs,https://nodejs. ...

  8. gulp browser-sync自动刷新插件

    很久没弄gulp了,都快忘了,今天又来温习下browser-sync 自动刷新插件,在安装的时候出现以下提示: $ npm install browser-sync --save-dev> ws ...

  9. gulp+browserSync自动刷新页面

    BrowserSync “Browsersync能让浏览器实时.快速响应您的文件更改(html.js.css.sass.less等)并自动刷新页面.更重要的是 Browsersync可以同时在PC.平 ...

随机推荐

  1. vue中的provide/inject的学习

    在 Vue.js 的 2.2.0+ 版本中添加加了 provide 和 inject 选项.用于父级组件向下传递数据.provide/inject:简单的来说就是在父组件(或者曾祖父组件)中通过pro ...

  2. php安全

    1.会话安全性 会话固化 一种获取有效回话标识符的方法,他将运行恶意用户通过强制使用回话ID来轻松模拟一个真实用户 攻击方法:<a href="http://a.com/index.p ...

  3. mysql学习【第3篇】:使用DQL查询数据

    狂神声明 : 文章均为自己的学习笔记 , 转载一定注明出处 ; 编辑不易 , 防君子不防小人~共勉 ! mysql学习[第3篇]:使用DQL查询数据 DQL语言 DQL( Data Query Lan ...

  4. python fabric实现远程操作和部署示例

    https://www.jb51.net/article/48434.htm 近期接手越来越多的东西,发布和运维的工作相当机械,加上频率还蛮高,导致时间浪费还是优点多.修复bug什么的,测试,提交版本 ...

  5. LeetCode 811 Subdomain Visit Count 解题报告

    题目要求 A website domain like "discuss.leetcode.com" consists of various subdomains. At the t ...

  6. python编码类型互转总结

    1.只有在unicode下才能将utf-8与gbk互转2.unicode是在内存中使用,bytes是文件存储和网络传输时使用-------------------------------------- ...

  7. GIt如何进行代码管理

    一:Git账号设置(仅第一次需设置): 1.首先打开GIt  Bash  界面

  8. Spring JPA实现逻辑源码分析总结

    1.SharedEntityManagerCreator: entitymanager的创建入口 该类被EntityManagerBeanDefinitionRegistrarPostProcesso ...

  9. centos7安装webmin

    安装webmin准备centos7系统1.下载http://download.webmin.com/download/yum/选择:webmin-1.700-1.noarch.rpm 安装包 wget ...

  10. OC仿QQ侧滑

    之前做侧滑用的控件的DDMenu,总感觉好像差了点什么,自己尝试写了一个,三层叠加,感觉效果不理想,偶然间看到了一篇博客,与大家分享,再次申明,该代码不是我写的,只是为了给自己留一个查找资料的机会 下 ...