精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

用原生JS進行CSS格式化和壓縮

開發 前端
一直比較喜歡收集網頁特效,很多時候都會遇到CSS被壓縮過的情況,這時查看起來就會非常不方便,有時為了減少文件大小,也會對自己的CSS進行壓縮,網上提供這樣服務的很多,但都不盡如人意,因此打算自己動手寫一個JS來進行CSS的格式化和壓縮。

前  言

一直比較喜歡收集網頁特效,很多時候都會遇到CSS被壓縮過的情況,這時查看起來就會非常不方便,有時為了減少文件大小,也會對自己的CSS進行壓縮,網上提供這樣服務的很多,但都不盡如人意,因此打算自己動手寫一個JS來進行CSS的格式化和壓縮。

原  理

CSS的結構如下:

  1. 選擇器{  
  2.   css屬性聲明:值;  

所以對CSS格式化也就比較簡單,大致分為以下幾步;

1、把多個空格合并成一個,去掉換行

2、對處理后的字符串按"{"進行分組

3、遍歷分組,對含有"}"的部分再次以"}"進行分組

4、對分組后的數據進行處理,主要是加上空格和換行

對CSS壓縮就比較簡單了,把空格合并,去掉換行就可以了

 

格式化

下面分步對以上步驟進行實現。

初始化:

  1. function formathtmljscss(source, spaceWidth, formatType) {  
  2.     this.source = source;  
  3.     this.spaceStr = "    ";  
  4.     if (!isNaN(spaceWidth)) {  
  5.         if (spaceWidth > 1) {  
  6.             this.spaceStr = "";  
  7.             for (var i = 0; i < spaceWidth; i++) {  
  8.                 this.spaceStr += " ";  
  9.             }  
  10.         }  
  11.         else {  
  12.             this.spaceStr = "\t";  
  13.         }  
  14.     }  
  15.     this.formatType = formatType;  
  16.     this.output = [];  

這里幾個參數分別是要格式化的CSS代碼、CSS屬性聲明前空格寬度,類型(格式化/壓縮)

1、把多個空格合并成一個,去掉換行:

  1. formathtmljscss.prototype.removeSpace = function () {  
  2.     this.source = this.source.replace(/\s+|\n/g, " ")  
  3.         .replace(/\s*{\s*/g, "{")  
  4.         .replace(/\s*}\s*/g, "}")  
  5.         .replace(/\s*:\s*/g, ":")  
  6.         .replace(/\s*;\s*/g, ";");  

2、對處理后的字符串按"{"進行分組

  1. formathtmljscss.prototype.split = function () {  
  2.     var bigqleft = this.source.split("{");  

3、遍歷分組,對含有"}"的部分再次以"}"進行分組

  1. formathtmljscss.prototype.split = function () {  
  2.     var bigqleft = this.source.split("{");  
  3.     var bigqright;  
  4.     for (var i = 0; i < bigqleft.length; i++) {  
  5.         if (bigqleft[i].indexOf("}") != -1) {  
  6.             bigqright = bigqleft[i].split("}");  
  7.         }  
  8.         else {  
  9.              
  10.         }  
  11.     }  

4、對分組后的數據進行處理,主要是加上空格和換行

這里的處理主要分為,把CSS屬性聲明和值部分取出來,然后加上空格和換行:

  1. formathtmljscss.prototype.split = function () {  
  2.     var bigqleft = this.source.split("{");  
  3.     var bigqright;  
  4.     for (var i = 0; i < bigqleft.length; i++) {  
  5.         if (bigqleft[i].indexOf("}") != -1) {  
  6.             bigqright = bigqleft[i].split("}");  
  7.             var pv = bigqright[0].split(";");  
  8.             for (var j = 0; j < pv.length; j++) {  
  9.                 pv[j] = this.formatStatement(this.trim(pv[j]),true);  
  10.                 if (pv[j].length > 0) {  
  11.                     this.output.push(this.spaceStr + pv[j] + ";\n");  
  12.                 }  
  13.             }  
  14.             this.output.push("}\n");  
  15.             bigqright[1] = this.trim(this.formatSelect(bigqright[1]));  
  16.             if (bigqright[1].length > 0) {  
  17.                 this.output.push(bigqright[1], " {\n");  
  18.             }  
  19.         }  
  20.         else {  
  21.             this.output.push(this.trim(this.formatSelect(bigqleft[i])), " {\n");  
  22.         }  
  23.     }  

這里調用了幾個方法:trim、formatSelect、formatStatement,下面一一說明。

trim:從命名就可以看出是去除首尾空格;

  1. formathtmljscss.prototype.trim = function (str) {  
  2.     return str.replace(/(^\s*)|(\s*$)/g, "");  

formatSelect:是處理選擇器部分語法,做法就是給"."前面加上空格,把","前后的空格去掉,把多個空格合并為一個:

  1. formathtmljscss.prototype.formatSelect = function (str) {  
  2.     return str.replace(/\./g, " .")  
  3.         .replace(/\s+/g, " ")  
  4.         .replace(/\. /g, ".")  
  5.         .replace(/\s*,\s*/g, ",");  

formatStatement:是處理“css屬性聲明:值;”部分的語法,做法就是給":"后面加上空格,把多個空格合并為一個,去掉“#”后面的空格,去掉"px"前面的空格,去掉"-"兩邊的空格,去掉":"前面的空格:

  1. formathtmljscss.prototype.formatStatement = function (str, autoCorrect) {  
  2.     str = str.replace(/:/g, " : ")  
  3.         .replace(/\s+/g, " ")  
  4.         .replace("# ""#")  
  5.         .replace(/\s*px/ig, "px")  
  6.         .replace(/\s*-\s*/g, "-")  
  7.         .replace(/\s*:/g, ":");  
  8.  
  9.     return str;  

調  用

調用部分比較簡單,對于格式化來說就是去掉空格和換行,然后分組處理,對于壓縮來說就是去掉空格和換行:

  1. formathtmljscss.prototype.formatcss = function () {  
  2.     if (this.formatType == "compress") {  
  3.         this.removeSpace();  
  4.     }  
  5.     else {  
  6.         this.removeSpace();  
  7.         this.split();  
  8.         this.source = this.output.join("");  
  9.     }  

界面HTML代碼:

  1. <div id="content"> 
  2.         <div class="container"> 
  3.             <div class="box"> 
  4.                 <div class="main"> 
  5.                     <h2>CSS格式化/壓縮</h2> 
  6.                     <div id="blurb"> 
  7.                         <fieldset id="options"> 
  8.                             <button id="submit"> 
  9.                                 <span>格式化 / 壓縮&nbsp;&nbsp;<img alt="格式化" src="/images/29.png"/></span> 
  10.                             </button><br/> 
  11.                             <span>縮進:</span> 
  12.                             <ul> 
  13.                                 <li> 
  14.                                     <select name="tabsize" id="tabsize"> 
  15.                                         <option value="1">tab鍵縮進</option> 
  16.                                         <option value="2">2空格縮進</option> 
  17.                                         <option selected="selected" value="4">4空格縮進</option> 
  18.                                     </select> 
  19.                                 </li> 
  20.                             </ul><br /> 
  21.                             <span>類型:</span><br /> 
  22.                             <input type="radio" name="format_type" value="format" checked="checked" id="format_format" /><label for="format_format">格式化</label> 
  23.                             <input type="radio" name="format_type" value="compress" id="format_compress" /><label for="format_compress">壓縮</label> 
  24.                         </fieldset> 
  25.                     </div> 
  26.                     <div id="beauty"> 
  27.                         <fieldset id="textarea-wrap"> 
  28.                             <textarea rows="20" cols="40" id="source"></textarea> 
  29.                         </fieldset> 
  30.                     </div> 
  31.                 </div> 
  32.             </div> 
  33.         </div> 
  34.     </div> 

跟頁面元素按鈕綁定事件:

  1. window.onload = function () {  
  2.     var submitBtn = document.getElementById("submit");  
  3.     var tabsize = document.getElementById("tabsize");  
  4.     var sourceCon = document.getElementById("source");  
  5.     var size = 4;  
  6.     var formatType = "format";  
  7.     submitBtn.onclick = function () {  
  8.         var radios = document.getElementsByName("format_type");  
  9.         for (i = 0; i < radios.length; i++) {  
  10.             if (radios[i].checked) {  
  11.                 formatType = radios[i].value;  
  12.                 break;  
  13.             }  
  14.         }  
  15.         var format = new formathtmljscss(sourceCon.value, size, formatType);  
  16.         format.formatcss();  
  17.         sourceCon.value = format.source;  
  18.     }  
  19.     tabsize.onchange = function () {  
  20.         size = this.options[this.options.selectedIndex].value;  
  21.         submitBtn.click();  
  22.         return false;  
  23.     }  

演示(請進原文)

原文鏈接:http://www.cnblogs.com/artwl/archive/2012/03/25/2416909.html

【編輯推薦】

  1. 10件有關JavaScript讓人費解的事情
  2. 面向對象的JavaScript基本知識指南大全
  3. 是時候開始使用JavaScript嚴格模式了
  4. 好用的高質量JavaScript庫一覽
  5. 一位反JavaScript主義者的覺醒
責任編輯:林師授 來源: Artwl的博客
相關推薦

2012-03-26 10:45:34

CSS

2018-12-03 09:10:07

Linux驅動器命令

2020-11-03 10:21:33

MySQL

2009-08-03 14:25:59

C#日期格式化

2013-02-01 10:14:14

Visual Stud

2024-01-08 22:03:22

python代碼開發

2022-05-09 08:17:37

InstantJava字符

2025-07-22 09:17:42

2010-08-03 15:36:38

FlexBuilder

2024-12-09 08:10:00

Python字符串格式化

2009-08-03 16:24:05

C#格式化

2010-07-29 11:12:30

Flex日期格式化

2013-07-08 17:41:53

Linux 系統U盤格式化

2023-06-13 07:50:49

Gopher格式化時間

2018-11-02 10:45:35

windowsU盤格式化

2015-01-07 15:21:30

Android Stu代碼格式化

2010-07-16 16:00:08

Perl格式化輸出

2010-07-16 15:44:57

Perl格式化輸出

2010-07-29 11:03:53

Flex代碼格式化

2010-10-28 15:32:42

oracle日期格式化
點贊
收藏

51CTO技術棧公眾號

av在线官网| 手机在线看片1024| 亚洲91网站| 午夜精品久久久久久久99樱桃| 精品国产一二| 国产偷人爽久久久久久老妇app| 欧美xxav| 亚洲高清av在线| 国产 porn| 国产精品一卡二卡三卡 | 3344国产精品免费看| 日韩中文字幕有码| 91成人精品在线| 日韩欧美在线视频免费观看| 伊人精品久久久久7777| 日本高清视频在线| 麻豆国产欧美一区二区三区| 欧美激情第1页| 国产又粗又猛又爽又黄的视频四季| 亚洲无线观看| 欧美精品一级二级三级| 国产精品视频一区二区三区四区五区| 麻豆av在线免费看| 久久久一区二区| 国产精品免费一区二区三区四区 | 中文字幕电影av| 米奇777超碰欧美日韩亚洲| 在线不卡的av| 日本va中文字幕| 九色porny自拍视频在线播放| 中文字幕日本不卡| 日韩一区二区三区高清| 天堂在线观看视频| 国产成人精品影视| 成人啪啪免费看| 中文字幕乱伦视频| 小嫩嫩精品导航| 国语自产精品视频在线看| 亚洲天堂黄色片| 国产高清久久| 中文字幕精品www乱入免费视频| 熟女人妻在线视频| 精品丝袜久久| 日韩色视频在线观看| 天堂av在线8| 国产成人精品一区二区三区在线| 天天色 色综合| av7777777| 69av成人| 狠狠躁夜夜躁人人躁婷婷91 | 日日摸夜夜添夜夜添精品视频| 久久久久久久久久国产| 欧美成人一区二区三区高清| 久久久久久久久久久久久久| 精品国产美女在线| 精品在线观看一区| 久久久精品久久久久久96| 中文字幕亚洲一区二区三区| 欧美xxxx精品| 99久久影视| 久久6免费高清热精品| 欧美成人黄色网| 亚洲茄子视频| 欧美孕妇毛茸茸xxxx| 日韩人妻精品中文字幕| 奇米影视一区二区三区小说| 国产精品日韩欧美综合| 国产精品久久久久久免费| 精品无人码麻豆乱码1区2区| 国产精品视频26uuu| 91久久久久国产一区二区| 激情综合五月婷婷| 懂色中文一区二区三区在线视频| 亚洲a视频在线观看| 国产精品第6页| 国内精品国产成人国产三级粉色 | 亚洲一区二区高清| 成人免费在线网| 亚洲精品动漫| 欧美午夜在线一二页| 日韩a一级欧美一级| 精品亚洲a∨一区二区三区18| 欧美www视频| 精品久久久久久中文字幕人妻最新| 亚洲ab电影| 少妇av一区二区三区| 欧美日韩综合一区二区| 亚洲永久在线| 国产日韩视频在线观看| 亚洲第一色视频| 91美女视频网站| 尤物国产精品| xxx性欧美| 在线观看91视频| 亚洲欧美中文日韩在线| 久久久999免费视频| 91九色综合| 亚洲精品一区二区三区精华液| 日本xxx在线播放| 国产精品国产一区| 97超级碰碰碰久久久| 中文字幕乱伦视频| 成人av资源在线观看| 亚洲精品视频一二三| 超碰97免费在线| 欧美日韩久久不卡| 国产精品久久AV无码| 日韩精品午夜| 欧美在线www| 亚洲精品第五页| 中文字幕第一区综合| 丰满的少妇愉情hd高清果冻传媒| 91精品国产经典在线观看| 亚洲电影天堂av | 一级黄色片免费看| 校园春色另类视频| 欧美精品亚州精品| 这里只有久久精品视频| 成人av免费网站| 中国一级黄色录像| 日韩欧美一区二区三区免费观看| 日韩欧美国产三级| 日韩一卡二卡在线观看| 日韩综合小视频| 久久九九视频| 欧美大片黄色| 欧美一卡二卡在线| 波兰性xxxxx极品hd| 久久国产精品久久久久久电车 | www.com毛片| 日韩08精品| 久久久国产视频91| 亚洲怡红院av| 中文字幕 久热精品 视频在线| 男女激情无遮挡| aaa国产精品视频| 久久综合国产精品台湾中文娱乐网| 日韩乱码一区二区三区| 2024国产精品| av黄色在线网站| 老司机在线精品视频| 欧美黄色片免费观看| 精品国产999久久久免费| 最新不卡av在线| 日本超碰在线观看| 久久人体视频| 国产精品一区二区三区在线播放| 国产日韩精品在线看| 色8久久精品久久久久久蜜| 欧美一级成年大片在线观看| 天堂一区在线观看| 免费不卡中文字幕在线| 欧美一区在线直播| 久草在线免费福利资源| 色呦呦日韩精品| 久久婷婷五月综合| 麻豆视频一区二区| 一本久道久久综合狠狠爱亚洲精品| 91九色综合| 另类色图亚洲色图| 成人无码一区二区三区| 亚洲 欧美综合在线网络| 捆绑裸体绳奴bdsm亚洲| 久久婷婷av| 亚洲国产激情一区二区三区| 日韩黄色三级| 欧美成人精品一区| 亚洲国产精品欧美久久| 亚洲福利视频导航| aaaaa一级片| 日本伊人午夜精品| 国产又大又长又粗又黄| av成人综合| 日本91av在线播放| 精品麻豆一区二区三区| 精品久久久久香蕉网| 狠狠人妻久久久久久| 国产精品网友自拍| 日本黄色www| 99在线热播精品免费99热| 欧美日韩在线高清| 国产专区精品| 91精品成人久久| 在线免费观看黄| 精品国产第一区二区三区观看体验| 日韩在线视频免费播放| 国产精品美女久久久久久久网站| 亚洲一区二区偷拍| 中国女人久久久| 亚洲国产一区在线| 日韩欧美一级| 日韩免费观看网站| 污的网站在线观看| 亚洲人成在线观看| 亚洲va欧美va| 在线一区二区三区四区五区| 欧美精品一级片| 久久精品视频一区二区三区| 一区二区三区四区毛片| 新67194成人永久网站| 免费看啪啪网站| 蜜桃视频在线观看www| 狠狠88综合久久久久综合网| 蜜桃麻豆91| 日韩欧美一级| 国产精品一区二区久久国产| 91九色美女在线视频| 色爱精品视频一区| 日韩在线观看视频网站| 欧美久久一区二区| 少妇高潮av久久久久久| 亚洲精品国产精华液| 亚洲精品午夜视频| 成人h动漫精品一区二区| 久久久久国产一区| 美女尤物久久精品| 奇米影视亚洲色图| 久久久久久久久丰满| 日韩精品久久久免费观看| 国产精品中文字幕制服诱惑| 91久久国产综合久久91精品网站| 成人做爰视频www网站小优视频| 欧美精品videossex88| 米奇精品一区二区三区| 一区二区三区黄色| 国产日产精品久久久久久婷婷| 亚洲成人网在线观看| 国产ts变态重口人妖hd| 欧美二区在线观看| 中文字幕av在线免费观看| 欧美视频在线免费看| 久久精品国产亚洲AV无码麻豆 | 青娱乐国产91| 欧美挤奶吃奶水xxxxx| 亚洲自拍偷拍色图| 久久免费资源| 国产精品永久在线| 欧美va在线观看| 国产成人精品一区二区三区| 国模私拍一区二区国模曼安| 国语对白做受69| 国产va在线视频| 91精品成人久久| 狼人综合视频| 欧美亚洲日本网站| 天堂√中文最新版在线| 97超级碰碰碰久久久| 中文字幕乱码中文乱码51精品| 国语自产偷拍精品视频偷| av岛国在线| 欧美一区二区三区艳史| 伊人久久国产| 日韩免费观看视频| 国产成人a视频高清在线观看| 国产精品网红直播| 女同性恋一区二区| 日韩精品免费一区二区夜夜嗨| 国产 高清 精品 在线 a| а√中文在线天堂精品| 国产女人水真多18毛片18精品| 精品视频自拍| 青娱乐一区二区| 久久一区二区三区电影| 中文字幕中文字幕99| 欧美区国产区| 国产精品网站免费| 日日夜夜一区二区| 久久精品一卡二卡| 国产成人8x视频一区二区| 天天躁日日躁狠狠躁av麻豆男男 | 成人影院在线看| 欧美大荫蒂xxx| 一个人看的www视频在线免费观看| 日本一区二区在线播放| 91福利精品在线观看| 91久久国产婷婷一区二区| 97久久综合区小说区图片区 | 香港三日本三级少妇66| 日韩国产精品视频| a视频网址在线观看| 欧美老少做受xxxx高潮| 精品丝袜在线| 国产日韩欧美视频| 精品网站aaa| 亚洲aⅴ天堂av在线电影软件| 久久久久电影| 337p粉嫩大胆噜噜噜鲁| 蜜桃久久av一区| 超级砰砰砰97免费观看最新一期 | 欧美大波大乳巨大乳| 亚洲免费av高清| 成人精品免费在线观看| 欧美精品粉嫩高潮一区二区| 天堂av一区二区三区| 久久黄色av网站| 天堂av在线| 97视频中文字幕| 美女毛片一区二区三区四区| 综合色婷婷一区二区亚洲欧美国产| 亚洲精选在线| www.久久av.com| 91美女片黄在线| 亚洲色婷婷一区二区三区| 欧美视频在线观看 亚洲欧| 99久久夜色精品国产亚洲| 亚洲裸体xxxx| 欧美伦理免费在线| 国产精品一区二区三区久久久| 啪啪国产精品| 欧美 亚洲 视频| 免费观看在线综合| 国产亚洲一区二区三区在线播放| 色综合久久网女同蕾丝边| 日韩在线免费视频观看| 91精品论坛| 国产一级二级三级精品| 91综合在线| av免费网站观看| 99综合电影在线视频| 久久r这里只有精品| 欧美丝袜丝nylons| 国产在线黄色| 欧美性资源免费| 精品在线网站观看| 国产av熟女一区二区三区| 国产一区不卡精品| 中文国语毛片高清视频| 91久久精品一区二区三区| 午夜在线视频免费| 97超级碰碰碰| 老汉色老汉首页av亚洲| 国产一二三在线视频| 国产精品18久久久久| 强伦人妻一区二区三区| 欧美日韩在线第一页| 婷婷久久久久久| 午夜精品视频在线| 免费萌白酱国产一区二区三区| 日韩美女爱爱视频| 国产成人在线观看免费网站| 成年人一级黄色片| 91精品一区二区三区久久久久久| 素人av在线| 成人国产精品色哟哟| 久久精品久久久| 91人妻一区二区三区| 亚洲精品五月天| 精品国产九九九| 色综合久久88| 99久热这里只有精品视频免费观看| 国产成人在线小视频| 成人综合激情网| 国产情侣在线视频| 精品亚洲永久免费精品| 黑人巨大精品| 日韩精品久久久免费观看| 奇米777欧美一区二区| 成人黄色短视频| 欧美一区二区网站| 日韩三级免费| 精品高清视频| 视频精品一区二区| 少妇愉情理伦三级| 91精品视频网| 丁香影院在线| 久久综合狠狠综合久久综青草| 久久精品盗摄| 亚洲女人毛茸茸高潮| 欧美一区二区成人6969| 不卡的av影片| 日本一区免费观看| 精品一区中文字幕| 黄网站免费在线| 亚洲美女在线视频| 日韩成人在线电影| 免费网站在线观看视频| 91看片淫黄大片一级| 性高潮视频在线观看| 久久伊人精品天天| 国产精品白丝av嫩草影院| aaa毛片在线观看| 一区在线中文字幕| 57pao国产成永久免费视频| 波多野结衣的一区二区三区| 亚洲免费一级视频| 一区二区三区欧美日| 三级黄视频在线观看| 国产精品视频永久免费播放| 伊人久久大香线| 精品人妻一区二区三区视频| 欧美午夜片在线看| 99色在线观看| 在线视频精品一区| 91蜜桃免费观看视频| 国产女无套免费视频| 51精品国产黑色丝袜高跟鞋| 欧美韩日一区| 中文字幕一区二区三区人妻不卡| 欧美电影影音先锋| 电影网一区二区|