最近做的前端项目中发现引用的js包太多,导致页面加载时反应很慢,所以首先想到的是将js和css压缩,提高加载速度。

  我们先来看看抓到的当前页面响应时间:

  

页面异步加载,需要响应时间 7.41秒,这也太慢了,实在受不了了。

下面我们引入gulp 对js做压缩,gulp是基于Node.js的前端构建工具。所以首先需要安装nodejs ,因为我的项目本身就是node项目,所以直接装gulp就好。全局安装gulp,命令如下

  1. npm install -g gulp

需要安装的依赖项下面这些,依次安装就好了:

安装好所有插件都会放到node_modules目录下。接下来我们准备压缩处理js

  在项目的本目录下新建gulpfile.js文件,并添加以下代码:

  1. var gulp = require('gulp'),
  2. cleanCSS = require('gulp-clean-css'),
  3. concat = require('gulp-concat'),
  4. uglify = require('gulp-uglify'),
  5. rename = require('gulp-rename'),
  6. jshint=require('gulp-jshint');
  7.  
  8. //语法检查
  9. gulp.task('jshint', function () {
  10. return gulp.src('client/assets/js/*.js')
  11. .pipe(jshint())
  12. .pipe(jshint.reporter('default'));
  13. });
  14.  
  15. //压缩,合并 js
  16. gulp.task('minifyjs', function() {
  17. return gulp.src([
  18. 'client/assets/js/angular-route.js',
  19. 'client/assets/js/angular-animate.js',
  20. 'client/assets/js/angular-cookies.js',
  21. 'client/assets/js/angular-touch.js',
  22. 'client/assets/js/ngStorage.js',
  23. 'client/assets/js/angular-ui-bootstrap.js',
  24. 'client/assets/js/angularui.js',
  25. 'client/assets/js/toaster/toaster.js',
  26. 'client/assets/js/iit/loading.js',
  27. 'client/assets/js/iit/router.js',
  28. 'client/assets/js/moment.js',
  29. 'client/assets/js/mbdatepicker.js',
  30. 'client/assets/js/jquery.js',
  31. 'client/assets/js/jquery-cookies.js',
  32. 'assets/js/bootstrap/js/bootstrap.min.js',
  33. ]) //需要操作的文件
  34. .pipe(concat('main.js')) //合并所有js到main.js
  35. .pipe(gulp.dest('client/assets/css/dist')) //输出到文件夹
  36. .pipe(rename({suffix: '.min'})) //rename压缩后的文件名
  37. .pipe(uglify()) //压缩
  38. .pipe(gulp.dest('client/assets/js/dist')); //输出
  39. });
  40.  
  41. //压缩css
  42. gulp.task('minifycss', function() {
  43. return gulp.src('client/assets/css/*.css') //需要操作的文件
  44. .pipe(rename({suffix: '.min'})) //rename压缩后的文件名
  45. .pipe(cleanCSS({compatibility: 'ie7'})) //执行压缩
  46. .pipe(gulp.dest('client/assets/css/dist')); //输出文件夹
  47. });
  48.  
  49. //默认命令,在cmd中输入gulp后,执行的就是这个任务(压缩js需要在检查js之后操作)
  50. gulp.task('default',['jshint'],function() {
  51. gulp.start('minifycss','minifyjs');
  52. });

  配置之后然后会到根目录执行cmd 命令 : gulp(gulp命令参考 : https://github.com/gulpjs/gulp/blob/master/docs/API.md

然后我们在指定的目录下就看到了已经压缩好的js文件

现在我们只需要将html中js引用的路径修改成压缩的新路径即可。

然后我们再次访问页面的时候就可以看到引用的js明显变少了,速度也快了不少

但是这个速度还是很慢的,影响用户体验的,但是我们发现目前影响速度的主要原因已经不是js的了,图片同样也比较大,影响页面加载速度。

gulp 对js,css,img等都是可以压缩的。

需要注意的是js相互之间有依赖,压缩之后依赖就没有了,所以的压缩的时候要注意,有些js是不能压缩到一起的,否则依赖找不到就报错了,所以上面的压缩中angularjs和其他的几个我并没有一起压进去。还有就是css压缩的时候因为命名规范的原因,压缩之后有些元素的样式id会重复,也会导致界面上样式乱掉的情况,很不幸我在做的就遇到了,所以这个地方我没有压缩css。

现在图片是影响加载的原因,但是因为目前我们的图片是放在阿里云上的,所以的即使我们想在服务端做压缩处理也没办法,后期迁到我们自己服务器的时候就可以考虑在服务端先做一次压缩,然后再返回。

欢迎关注微信公众平台:上帝派来改造世界的人

gulp 压缩js,css的更多相关文章

  1. 《Gulp 入门指南》 : 使用 gulp 压缩 JS

    <Gulp 入门指南> : 使用 gulp 压缩 JS 请务必理解如下章节后阅读此章节: 安装 Node 和 gulp 访问论坛获取帮助 压缩 js 代码可降低 js 文件大小,提高页面打 ...

  2. 使用 gulp 压缩 JS

    使用 gulp 压缩 JS 请务必理解如下章节后阅读此章节: 安装 Node 和 gulp 压缩 js 代码可降低 js 文件大小,提高页面打开速度.在不利用 gulp 时我们需要通过各种工具手动完成 ...

  3. PHP动态压缩js,css

    PHP动态压缩js,css 列表项 标签: PHP 正式发布产品时,我们希望将项目里的js,css合并压缩,以减少http请求.防止轻易查看源代码. 使用 只需要在头部引入一下代码即可: <me ...

  4. gulp 对js\css进行md5 加密

    有的服务器为了网站加载速度,会做服务器缓存,这样就会出现代码出现引用地址没变,新代码不生效,而我们又希望新代码可以及时生效,这样我们就需要避免缓存,当然也有很多方法,本文只介绍使用gulp-rev(对 ...

  5. gulp 压缩 js 和 css 代码

    我们在写出来的代码都是非常规范的,改换行的时候就换行,改tab 的时候就有tab,还有这样做是为了后期维护方便,但是这也导致了内存占用量的增大,当把把代码发到线上,如果网速慢一点,可能很久都加载不出来 ...

  6. gulp入门-压缩js/css文件(windows)

    类似于grunt,都是基于Node.js的前端构建工具.不过gulp压缩效率更高. 工具/原料 nodejs/npm 方法/步骤 首先要确保pc上装有node,然后在global环境和项目文件中都in ...

  7. gulp打包js/css时合并成一个文件时的顺序解决

    1.可以使用插进gulp-order. 2.可以这样的写法: return gulp.src(['js/common.js','js/**/*.js']) .pipe(concat('build.js ...

  8. ASP.NET MVC 4使用Bundle的打包压缩JS/CSS

    打包(Bundling)及压缩(Minification)指的是将多个js文件或css文件打包成单一文件并压缩的做法,如此可减少浏览器需下载多个文件案才能完成网页显示的延迟感,同时通过移除JS/CSS ...

  9. MVC打包压缩JS&CSS文件调试时过滤了一些文件

    BundleTable.这个确实是比较好用,打包并压缩了CSS,使之加载时减少流量. 但是在调试的时候会疑问为何有很多JS,CSS文件无法打包,其实是因为调试时VS自动过滤了如下文件:   后台跟踪了 ...

随机推荐

  1. 升级AutoMapper后遇到的“Missing map”与“Missing type map configuration”问题

    前几天发现 AutoMapper 3.3 的一个性能问题(详见:遭遇AutoMapper性能问题:映射200条数据比100条慢了近千倍),于是将 AutoMapper 升级至最新的 5.1.1 看是否 ...

  2. STC12C5A60S2笔记5(省电模式)

    1. 基本特性 STC12C5A60S2系列单片机可运行三种省电模式以降低功能,STC正常工作电流是2mA~7mA,而掉电模式下<0.1uA,空闲模式下<0.1mA. 1) 空闲模式:由电 ...

  3. 说说WeakReference弱引用

    WeakReference弱引用概述 http://www.cnblogs.com/xrq730/p/4836700.html,关于Java的四种引用状态具体请参看此文 Java里一个对象obj被创建 ...

  4. Unity3D热更新全书FAQ

    只要有程序员朋友们问过两次的问题 就会收录在此FAQ中 1.C#Light对比LUA有什么好处 C#Light是静态类型脚本语言,语法同C#,Lua是动态类型脚本语言,这两种都有人喜欢. 我更喜欢静态 ...

  5. 据说每个大牛、小牛都应该有自己的库——Ajax

    蹉跎到今天终于要写Ajax部分了,平时工作中除了选择器我用jQuery的最多的就是ajax,所以这部分在自己的框架中必不可少. XMLHttpRequest 我以为对每个使用过Ajax的人来说XMLH ...

  6. C struct结构体内存对齐问题

    在空间看到别人的疑问引起了我的兴趣,刚好是我感兴趣的话题,就写一下.为了别人的疑问,也发表在qq空间里.因为下班比较晚,10点才到家,发表的也晚.其实是个简单的问题.  直接用实例和内存图说明: #i ...

  7. WebViewJavascriptBridge的暂时理解

    直接从项目里复制了一份关于WebViewJavascriptBridge使用的代码,注释部分是自己暂时的理解.孟哥说,callHandler类似于jq里的trigger, registerHandle ...

  8. xamarin UWP设置HUD加载功能

    使用xamarin开发的时候经常用到加载HUD功能,就是我们常见的一个加载中的动作,Android 下使用 AndHUD , iOS 下使用 BTProgressHUD, 这两个在在 NuGet 上都 ...

  9. ios UIButton设置单选效果,以及同时设置图片和标题

    一,设置单选效果 - (void)selectedBtnPress:(UIButton*)sender { //首先把原来按钮的选中效果消除 for (int i=0;i<num;i++) {/ ...

  10. Java-继承,多态练习0922-06

    编写一个Shape类,具有属性:周长和面积: 定义其子类三角形和矩形,分别具有求周长的方法. 定义主类E,在其main方法中创建三角形和矩形类的对象, 并赋给Shape类的对象a.b,使用对象a.b来 ...