打开中处理文件的文件夹,再打开bulk rename utility,你可以使用拖动的方法直接添加文件到bulk rename utility。这个方法在XP中不适用。
当然你可以软件左侧进行增加文件,但这个方法稍稍慢一点。
在”替换“后的文本框中输入一个空格,在”用“后的文本框中什么都不输入
最后点击”重命名“按钮。如果初次使用这个软件还会有一个警告框,不要管它。
这个时候我们可以发现我们删除文件名中的多余空格效果已经达到了。
注入package.json(此json文件需要自己在当前项目目录下创建即可--不能有注释)安装:
npm install gulp-uglify --save-dev
全局安装:
npm install gulp-uglify -g
整站静态文件压缩配置文件gulpfile.js(html/css/image/js前提是安装下列require用到的模块):
var gulp = require('gulp'),//基础库
htmlmin = require('gulp-htmlmin'),//html压缩
cssmin = require('gulp-minify-css'),//css压缩
jshint = require('gulp-jshint'),//js检查
uglify = require('gulp-uglify'),//js压缩
imagemin = require('gulp-imagemin'),//图片压缩
pngquant = require('imagemin-pngquant'),//图片深入压缩
imageminOptipng = require('imagemin-optipng'),
imageminSvgo = require('imagemin-svgo'),
imageminGifsicle = require('imagemin-gifsicle'),
imageminJpegtran = require('imagemin-jpegtran'),
domSrc = require('gulp-dom-src'),
cheerio = require('gulp-cheerio'),
processhtml = require('gulp-processhtml'),
Replace = require('gulp-replace'),
cache = require('gulp-cache'),//图片压缩缓存
clean = require('gulp-clean'),//清空文件夹
conCat = require('gulp-concat'),//文件合并
plumber=require('gulp-plumber'),//检测错误
gutil=require('gulp-util')//如果有自定义方法,会用到
var date = new Date().getTime()
gulp.task('clean',function(){
return gulp.src('min/**',{read:false})
.pipe(clean())
})
function errrHandler( e ){
// 控制台发声,错误时beep一下
gutil.beep()
gutil.log(e)
this.emit('end')
}
gulp.task('cleanCash', function (done) {//清除缓存
return cache.clearAll(done)
})
gulp.task('htmlmin', function () {
var options = {
removeComments: true,//清除HTML注释
collapseWhitespace: true,//压缩HTML
collapseBooleanAttributes: false,//省略布尔属性的值 <input checked="true"/>==><input />
removeEmptyAttributes: false,//删除所有空格作属性值 <input id="" />==><input />
removeScriptTypeAttributes: true,//删除<script>的type="text/javascript"
removeStyleLinkTypeAttributes: true,//删除<style>和<link>的type="text/css"
minifyJS: true,//压缩页面JS
minifyCSS: true//压缩页面CSS
}
gulp.src(['index/*.htm','index/*.html'])
.pipe(plumber({errorHandler:errrHandler}))
.pipe(Replace(/_VERSION_/gi, date))
.pipe(processhtml())
.pipe(htmlmin(options))
.pipe(gulp.dest('min'))
})
gulp.task('cssmin', function(){
gulp.src('index/**/*.css')
.pipe(conCat('css/index.min.css'))
.pipe(plumber({errorHandler:errrHandler}))
.pipe(cssmin({
advanced: false,//类型:Boolean 默认:true [是否开启高级优化(合并选择器等)]
compatibility: 'ie7',//保留ie7及以下兼容写法 类型:String 默认:''or'*' [启用兼容模式; 'ie7':IE7兼容模式,'ie8':IE8兼容模式,'*':IE9+兼容模式]
keepBreaks: false,//类型:Boolean 默认:false [是否保留换行]
keepSpecialComments: '*'
//保留所有特殊前缀 当你用autoprefixer生成的浏览器前缀,如果不加这个参数,有可能将会删除你的部分前缀
}))
.pipe(gulp.dest('min'))
})
gulp.task('jsmin', function () {
gulp.src(['index/js/*.js','!index/**/{text1,text2}.js'])
.pipe(conCat('js/index.min.js'))
.pipe(plumber({errorHandler:errrHandler}))
.pipe(uglify({
mangle: {except: ['require' ,'exports' ,'module' ,'$']},//类型:Boolean 默认:true 是否修改变量名
compress: true,//类型:Boolean 默认:true 是否完全压缩
preserveComments: 'false' //保留所有注释
}))
.pipe(gulp.dest('min'))
})
gulp.task('imagemin', function () {
gulp.src('index/**/*.{png,jpg,gif,ico}')
.pipe(plumber({errorHandler:errrHandler}))
.pipe(cache(imagemin({
progressive: true, //类型:Boolean 默认:false 无损压缩jpg图片
svgoPlugins: [{removeViewBox: false}],//不要移除svg的viewbox属性
use: [pngquant(),imageminJpegtran({progressive: true})
, imageminGifsicle({interlaced: true}),imageminOptipng({optimizationLevel:3}), imageminSvgo()] //使用pngquant深度压缩png图片的imagemin插件
})))
.pipe(gulp.dest('min'))
})
gulp.task('default',['clean'],function(){
gulp.start('cssmin','htmlmin','jsmin','imagemin')
})
package.json(例子) package.json详细介绍:https://docs.npmjs.com/files/package.json
(package.json npm init 命令行创建文件方法http://blog.csdn.net/liyanhui1001/article/details/44020235 )
{
"name": "web",
"version": "1.0.0",
"description": "my text",
"main": "gulpfile.js",
"dependencies": {
"gulp": "^3.9.1",
"gulp-cache": "^0.4.5",
"gulp-concat": "^2.6.0",
"gulp-htmlmin": "^2.0.0",
"gulp-imagemin": "^3.0.1",
"gulp-jshint": "^2.0.1",
"gulp-minify-css": "^1.2.4",
"gulp-plumber": "^1.1.0",
"gulp-uglify": "^1.5.4",
"gulp-util": "^3.0.7",
"imagemin-pngquant": "^5.0.0",
"jshint": "^2.9.2",
"gulp-clean": "^0.3.2"
},
"devDependencies": {
"gulp-cheerio": "^0.6.2",
"gulp-dom-src": "^0.2.0",
"gulp-jslint": "^1.0.1",
"gulp-processhtml": "^1.1.0",
"gulp-rename": "^1.2.2",
"gulp-replace": "^0.5.4",
"gulp-webpack": "^1.5.0",
"imagemin-gifsicle": "^5.1.0",
"imagemin-jpegtran": "^5.0.2",
"imagemin-optipng": "^5.1.1",
"imagemin-svgo": "^5.1.0",
"webpack": "^1.13.1"
},
"scripts": {
"test": "echo \"Error: no test specified\" &&exit 1"
},
"keywords": [
"web"
],
"author": "yl",
"license": "ISC"
}
devDependencies里的内容即为你安装gulp的模块插件名称和版本号!
最后,node.js里指定到当前项目目录下输入gulp命令即可:
gulp default
浏览网页产生的流量是由网页html代码、flash、图片、css、js等文件体积组成,因此,控制空间网页流量就得从这几个部分出发,减少它们的体积容量。1、优化html代码
优化html代码,基本做法是去掉很多不必要的字符,例如去掉注释部分、去掉空行等。
还有更重要的是html代码的书写问题。用最少的代码实现需求,是一个html程序员必须永远追求的境界。举个很简单的例子,假如你对网页表格宽度的定义,是在每个表格里都用“width="***px"”,那么你的写法虽然能实现要求,但是总体看来是比较低效的。你完全可以用css全局定义一下table{width:***px}。这样处理,你的代码就会减少很多,简洁很多,进一步说,你的网页体积就会减少,网页打开时间就会减少,网页流量就会减少。
优化html代码,当然少不了gzip压缩,通过gzip压缩,代码的传输量会减少60%以上!这是控制流量最值得推荐也是最应用广泛的方法。你的网站启用了gzip吗?立即在线检测gzip压缩看看。如何启用网站的gzip压缩功能?
所以,优化html代码,无论是对于网页流量的控制还是网页打开时间的控制,都是非常重要的。不过你如果用的是现成的程序模版,基本是不用怎么优化html了,开发者多在这方面下了很大功夫,做得已经很优秀的了。
2、优化flash
flash体积一般比较大,这里谈的优化flash,并不是说如何去做体积更小的flash,而是站长对flash的取舍问题。一张网页,如果放太多的flash文件,网页体积就会变得非常之大,网页打开速度会变得比较慢,网页流量却会增加得很快。
所以,网页应尽量少用,最好不用flash文件。
3、优化图片
图片是网页的重要组成部分,一张网页如果没有图片就会变得太过沉静,很影响网页美观,也影响用户感受。但是一张网页如果图片数量过多或体积过大,就会严重影响下载速度和打开时间,再就是,它会让你的网页流量增长迅速,这对于受月流量限制的空间来说,简直就是个噩梦。
所以,网页除了使用很必要的图片外,其他不相干的图片应尽量不用。一部分人使用图床来控制空间流量,这样做是个办法,但不可否认会导致网页的打开时间增多和速度减慢的问题。
因此,我认为图片最好是在正式放到空间使用前,做个压缩优化。webkaka的图片在线压缩优化工具,给大家提供了一个便利,经测试,部分图片的无损压缩比达到90%以上!换句话来说,50k的图片经过无损压缩后,只有5k!
4、优化css
优化css,主要是从代码出发,删除多余的字符,从而达到压缩优化的目的。webkaka的css在线压缩优化工具,能使部分css代码压缩比达到30%以上。使用压缩优化过css文件,可以减少网页的总体积,从而减少浏览网页时产生的流量。这是控制网页流量的一个手段。
5、优化js
与优化css一样,主要是从代码出发,删除多余的字符,从而达到压缩优化的目的。webkaka的js在线压缩优化工具,能使js代码压缩比达到20%以上。
总结
网站空间月流量超标,是站长不愿看到的事,但是换另一个角度来看,网站流量超标,不就说明了网站流量提升了么?这应该事个值得庆贺的事!而对于本文提到的控制网页流量的方法,其实只能是治标不治本,最好的做法是用个没有月流量限制的空间,那样,你可以腾出更多的时间去做网站内容,而不用再去担心网站流量的问题。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)