一、前言

node从v0.10.26升级(为了匹配autoprefixer)到v5.3.0后出现了gulp插件兼容问题,在nodejs下各种新的插件出现问题,需要重新配置。livereload实现chrome自动刷新需要安装插件,偶尔被墙不是很方便。用webserver搭配livereload,可以实现本地(不需要apache服务器)服务器式文件自动刷新预览,所见即所得,so酷~!配合sublime text3 (大量的最新插件已经开始以3为基准)简直是神器

二、下载

现在很多插件描写的博文都是很久以前的,并不是很适合现在的新版本,so,最好去看官网插件的使用文档,那是最权威最新的,看不懂英语不要紧,看懂代码即可(英语可百度谷歌在线翻译)。nodejs可在官网下也可在中文网下 插件官网有使用文档。但是:最好不要下载nodejs的最新的版本,有些插件可能不支持

https://nodejs.org

http://nodejs.cn/  

http://gulpjs.com/plugins/

https://www.npmjs.com/

三、配置

使用的node版本

确保安装插件,部分gulpfile.js

/*加载插件*/
var gulp = require('gulp'),
autoprefixer = require('gulp-autoprefixer'), //自动处理浏览器前缀
cache = require('gulp-cache'), //缓存
clean = require('gulp-clean'), //清空文件夹
concat = require('gulp-concat'), //合并文件
htmlmin = require('gulp-htmlmin'), //压缩html
imagemin = require('gulp-imagemin'), //图片压缩
pngquant = require('imagemin-pngquant'), //png压缩
less = require('gulp-less'),
livereload = require('gulp-livereload'), //服务器<-->文件自动更新
minifyCss = require('gulp-minify-css'), //缩小化(minify)CSS
rename = require('gulp-rename'), //重命名
rev = require('gulp-rev'),//md5
revCollector = require('gulp-rev-collector'),//替换md5后文件名
sass = require('gulp-sass'),
uglify = require('gulp-uglify'), //js压缩
watch = require('gulp-watch'), //监听
webserver = require('gulp-webserver'); // 本地服务器
zip = require('gulp-zip'); //打包前的压缩
//源码路径
var srcPath = {
css: "./src/css/*.css"
};
//输出目录
var distPath = {,
css: "./web/css"
}; gulp.task('css', function(){
return gulp.src(srcPath.css)
.pipe(autoprefixer('last 2 version', 'safari 5', 'ie 8', 'ie 9', 'opera 12.1', 'ios 6', 'android 4'))
.pipe(rename({suffix: '.min'}))
.pipe(minifyCss())
.pipe(gulp.dest(distPath.mincss));
}); gulp.task('clean', function() {
return gulp.src([distPath.html,distPath.css,distPath.js], {read: false})
.pipe(clean({force: true}));
});
gulp.task('webserver', function() {
gulp.src( './' ) // 服务器目录(代表根目录)
.pipe(webserver({
livereload: true,
}));
});
gulp.task('watch', function() {
gulp.watch(srcPath.html, ['html']);
gulp.watch(srcPath.js, ['js']);
gulp.watch(srcPath.css, ['css']);
gulp.watch(srcPath.less, ['less']);
gulp.watch(srcPath.sass, ['sass']);
gulp.watch(srcPath.img, ['img']);
});
gulp.task('default', ['clean'], function(){
gulp.start( 'webserver','css','img','watch');
});

  

三、常见报错处理 

1、被墙:vpn稳定的要钱,不要钱的不稳定,可以使用github(可以正常访问)上的免费插件或是提供的各种工具 比如   https://github.com/racaljk/hosts  修改hosts即可,官网定期更新

2、cmd安装莫名其妙报错:淡定,关掉重新安装或是换个文件夹cd进入再次安装可以搞定。最终版确定后压缩打包备份

3、node_modules不能正常复制删除?打包压缩zip既可复制也可移动;删除使用360强制搞定

4、插件太久不兼容?重新npm安装

5、cmd下无权限?以管理员身份运行 or 使用sudo or 使用淘宝的 cnpm 镜像安装

gulp下livereload和webserver实现本地服务器下文件自动刷新的更多相关文章

  1. 外网访问本地服务器下的web应用

    让本地服务器可以在外网访问的方式有很多,介绍其中一种: 由于本人是在自己电脑上装了一个虚拟机, 测试环境为:虚拟机作为服务器,服务器中装了一个禅道,虚拟机IP192.168.2.221,本人通过tpl ...

  2. js获取base64格式图片预览上传并用php保存到本地服务器指定文件夹

    html: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF ...

  3. MacOS搭建本地服务器

    MacOS搭建本地服务器 一,需求分析 1.1,开发app(ios android)时通常需往app中切入web页面,直接导入不行,故需搭建本地的测试网站服务,通过IP嵌入访问页面. 1.2,开发小程 ...

  4. 使用node.js搭建本地服务器

    第一步安装node:https://nodejs.org/zh-cn/download/ 接下来就需要安装http的镜像文件 打开cmd:输入以下命令 npm install http-server ...

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

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

  6. 利用gulp搭建本地服务器,并能模拟ajax

    工作中可能会用到的小工具,在此记录一下.可以实现的功能有: 本地http服务器 页面实时刷新 可以模拟ajax请求 第一步,新建package.json文件.用到了gulp.gulp-webserve ...

  7. linux下搭建svn本地服务器

    在linux下搭建svn本地服务器可以很好的管理自己的代码,具体过程如下: # mkdir svn_local # cd svn_local  # svnadmin create led_diplay ...

  8. 本地windows下搭建git的本地服务器

    本地windows下搭建git的本地服务器 准备工作: 本地安装java环境,配置环境变量(略) 下载gitblit文件,百度一大堆 开始第一步: 减压gitblit压缩包到某个目录下,比如我在:H: ...

  9. 服务器--远程桌面选择"本地资源"下不显示"本地磁盘"的解决办法(转)

    转自:http://blog.sina.com.cn/s/blog_4cd978f90102wsvc.html “远程连接桌面”,每次连接候,我都选择了“本地资源”下面的“磁盘驱动器”,都会在远程电脑 ...

随机推荐

  1. 如何更改Json.NET的序列化规则

    我想要使序列化出来的JSON都是小写,可以通过建立 LowercaseContractResolver:DefaultContractResolver 来实现, 创建Custom ContractRe ...

  2. 【风马一族_git_github】git的工作流程

    git有三个区域(如图): 基本信息设置 1)设置用户名   git config --global user.name  "帐号名" 2)设置用户名邮箱  git config ...

  3. 《Linux系统free命令的使用》学习笔记

    free命令用于显示当前系统的内存空闲和使用情况,其中包括物理内存,交换分区内存,内核缓冲区内存以及高速缓存,free的参数报错一下: -b ——字节的方式显示内存使用情况 [root@redhat ...

  4. 8款实用的Jquery瀑布流插件

    1.网友Null分享Jquery响应式瀑布流布局插件 首先非常感谢网友Null的无私分享,此作品是一款响应式瀑布流布局Jquery插件,网友Null增加了一个屏幕自适应和响应式,响应式就是支持智能手机 ...

  5. Apache,添加虚拟目录

    这几天在自己的虚拟机里面安装了2003,有人说window陪iis较好,但是对iis无兴趣,就自己装了apache,下面介绍如何配置自己的虚拟目录. 想配置自己的虚拟目录,那必须要知道点apache的 ...

  6. C++ socket编程

    源代码项目下载:http://download.csdn.net/detail/mmyzlinyingjie/7049499 TCP类的: TcpServer.cpp //WSAStartup soc ...

  7. sql中的系统表sysobjects以及如何查看sql语句的执行时间

    使用sysobjects可以快速查看数据库中表.视图.存储过程.触发器.约束等的信息. 大牛文章:http://www.cnblogs.com/atree/p/SQL-Server-sysobject ...

  8. mac os使用homebrew来管理后台服务

    在linux下我们经常通过 service 或者 /etc/init.d/来管理我们的后台服务软件,并使用包管理器安装这些软件. 在mac下有homebrew这个好用的工具来安装软件,但是一直没有找到 ...

  9. 每日一“酷”之array

    array--国定类型数据序列 array模块定义一个序列数据结构,看起来和list非常相似,只不过所有成员都必须是相同的基本类型. 1.初始化 array实例化时可以提高一个参数来描述允许哪个种数据 ...

  10. java之classpath到底是什么

    如果你输入一个命令,比如java那么系统是如何找到这个命令的呢?按照顺序,系统先在当前目录搜索是否有java.exe, java.bat 等. 如果没有,就得到系统的PATH(不区分大小写)里面查找. ...