在WEB应用中,如果使用jsp作为view层的显示模板,都会被空格/空换行问题所困扰.
 
 
这个问题当年也困扰了我比较长的时间.因为在jsp内使用的EL标签和其他标签时,会产生大量的空格和换行符.例如:

复制代码代码如下:
------- start ---------- 
<c:choose> 
<c:when test="${fn:length(mainPageList)>1&}"> 
Something 
</c:when> 
<c:otherwise> 
Others 
</c:otherwise> 
</c:choose> 
------- end ----------- 

这段代码在Tomcat上输出如下,多了几行换行。

复制代码代码如下:
------- start ---------- 
Something 
------- end ----------- 

当然,一般不去特别留意是不会发现有什么问题的,毕竟输出再多的空格和换行符,对于浏览器生成的最终效果是一样的。也就是大部分开发人员忽略这个问题的原因;但实际上这些空格和换行会占用了不少空间,我的经验是30%左右是空格/换行。也有人说,当web服务器以zip的方式来输出html时,空格引起的带宽问题就可以解决了;是的,当使用zip来输出html时,空格/换行的空间会被节省回来,但这个增加zip的工作量,而且最大的问题是,浏览器生成页面时,还是会还原所有的空格的换行符。对于前端开发人员来说这是个噩耗,面对大量的空格和冗长的html源码,想要找到对应出问题的样式所在的位置可不是容易的事情。 
下面说一下解决方案,以Tomcat为例: 
方案一,利用web服务器的trimSpaces功能。 
Tomcat5 以上版本都可以使用,这是最简单的方法。

复制代码代码如下:
<servlet> 
<servlet-name>jsp</servlet-name> 
<servlet-class>org.apache.jasper.servlet.JspServlet</servlet-class> 
<init-param> 
<param-name>fork</param-name> 
<param-value>false</param-value> 
</init-param> 
<init-param> 
<param-name>trimSpaces </param-name> 
<param-value>true </param-value> 
</init-param> 
<init-param> 
<param-name>xpoweredBy</param-name> 
<param-value>false</param-value> 
</init-param> 
<load-on-startup>3</load-on-startup> 
</servlet> 

这个方案有个缺点,它会去掉所有jsp EL标签之间的空格的换行符,在部分情况下也来带来不便。 
如:Your name is ${firstName} ${lastName}. ==输出为==> Your name is firstNamelastName. 
两个${}变量之间的空格也会消失。要解决这个问题是相当麻烦,要引入一个只有一个空格的变量。 
<c:set var="one_space"> </c:set> 
Your name is ${firstName}${one_space}${lastName}. 
这样就正常了,麻烦。虽然可以在一些全局变量的地方来增加一个one_space的变量,但代码看上去还是不爽。 
方案二,我比较喜欢。 
这个方案只有在支持jsp 2.1的web服务器上才可以使用,如Tomcat6。 
Jsp2.1多了一个很有用的命令; 
<%@ page trimDirectiveWhitespaces="true" %> 
这个命令可以使jsp输出的html时去除多余的空行(jsp上使用EL和tag会产生大量的空格和空行),没有使用trimSpaces的问题,现在jsp输出html也可以很好地排版,看上去也专业;以前我一直都羡慕velocity的模板,输出html十分干净好看,现在jsp也可以了。 
另外提一下,Tomcat6有一些兼容性问题,例如不能使用#{}这种代码在jsp中,因为会被当成JSF脚本执行。 
虽然这是一个很小的问题,但我们还是要注意细节。

最新文章

  1. 我的第一篇博客/markdown
  2. oracle表空间相关SQL语句
  3. 读书笔记_Effective_C++_条款二十一:当必须返回对象时,别妄想返回其reference
  4. WordPress SEO ☞ WordPress网站终极优化指南
  5. 判断浏览器 IE 11
  6. VS2013 图片背景&#183;全透明背景图(转)
  7. P2P技术详解(一):NAT详解——详细原理、P2P简介
  8. 【Unity Shaders】使用Unity Render Textures实现画面特效——建立画面特效脚本系统
  9. CentOS7x64 防火墙配置
  10. wangEditor的使用
  11. [转] web前端js构造无法销毁的类UUID识别码,识别浏览器设备唯一性
  12. __c语言__整型、实型的存储(十进制转二进制)
  13. Class_fifth
  14. Windows Server 2012 R2域控制器部署
  15. ionic3 热更新发布步骤记录
  16. vue VNode如何使用,是什么东西?
  17. 【读书笔记】iOS-手势识别
  18. Nginx入门到精通
  19. 【工具使用】Git密码存储相关问题探究以及资料整理
  20. 图片 和 base64 互转

热门文章

  1. Scala实现乘法口诀
  2. HTTP与HTTPS对访问速度(性能)的影响【转】
  3. ASP.NET Web配置指南
  4. Java实现验证码的产生和验证
  5. 浏览器指纹 - HTTP cookie 浏览器指纹 欺诈检测 浏览器id hash 浏览器插件信息 canvas 字体信息
  6. centos 7 update to python V3.43 to assure git clone as usual
  7. CSS布局与定位——height百分比设置无效/背景色不显示
  8. Ajax返回乱码
  9. if嵌套和elif的区别
  10. pycharm进行调试[转载]