两种方法实现:
1)一行一行的读取aspx文件然后处理
2)一次性读取aspx文件然后处理
处理逻辑:
替换" "为" "(将两个空格替换为一个空格),将所有的换行符替换为空字符(极限压缩)
注意事项:
1)一行一行处理在极限压缩的情况下需要额外的处理服务端控件换行的情况,比如
复制代码 代码如下:
Line 1:<asp:Label runat="server"
Line 2: ....
Line 3:.../>
这种情况 一行一行处理会出问题
2) 另外JS脚本中内联的单行注释
推荐使用"/**/"代替"//"
使用结果:
一行行的处理比一次性处理稍快,对于两三百行的aspx文件,差距在毫秒级别。不过对整个项目进行处理,随着文件数增多,差距应该会体现出来。
一次性读取处理可以不使用极限压缩,这样服务器控件和内联单行注释的问题可以不用考虑。
我一般很少使用内联注释和单行注释以及服务器控件所以压缩效果非常明显,一般500-600行的源码压缩后不到50行,大小减少约三分之一。
不过这种压缩效果可能和你是否使用服务端数据列表控件以及如何使用有很大的关系 ,我一般只使用repeater。
复制代码 代码如下:
public static String Replace(String source,String oldStr,String newStr)
{
int count = Regex.Matches(source, oldStr).Count;
for (int i = 0; i < count; i++)
{
source = source.Replace(oldStr, newStr);
}
return source;
}
/// <summary>
/// 压缩指定路径的文件空白字符串和换行符
/// 压缩说明
/// 1)采取File.ReadAllLines读取所有行每一行做处理工作
/// 2)服务器控件最好写在一行内,只做了尾部标签与runat="server"跨行的处理,开始标签跨行为处理
/// 3)文件不能有单行注释"//"
/// 4)替换掉了换行符和空格
/// </summary>
/// <param>文件路径</param>
public static void CompressLineByLine(String filePath)
{
if (!File.Exists(filePath))
{
Console.WriteLine("文件不存在,检查路径{0}", filePath);
return;
}
var start = DateTime.Now;
Console.WriteLine("正在压缩文件:{0}\r\n开始于{1}...",
filePath,start.ToString());
var lines = File.ReadAllLines(filePath,
Encoding.GetEncoding("GB2312"));
for (int i = 0; i < lines.Length; i++)
{
var item = lines[i].Trim();
if (item.IndexOf("runat=\"server\"") > -1)
item += " ";
item = item.Replace("\r\n", "");
item = Replace(item, " ", " ");
lines[i] = item;
}
File.WriteAllText(filePath, string.Join("", lines),
Encoding.GetEncoding("GB2312"));
var end = DateTime.Now;
Console.WriteLine("结束于{0}...", end.ToString());
Console.WriteLine("====耗时====\r\n{0}\r\n", end - start);
}