PHP生成HTML页面顶部出现空白部分(#65279字符)的解决办法
2015-08-12 20:49
169 查看
最近项目使用到ThinkPHP框架,其中一个页面顶部总是一小段空白。
如下图所示:
而且只会在chrome和edge浏览器出现,ff则不会出现这个问题。由于该页面是由PHP+HTML模板拼接接,因此先后排查了html文件、JavaScript文件、php文件。均未发现问题。
使用chrome F12发现空白处是一串字符。通过搜索,了解到这原来是UTF-8的编码问题。
我使用的编码是UTF-8 + BOM,这种编码方式一般会在windows操作系统中出现,比如WINDOWS自带的记事本等软件,在保存一个以UTF-8编码的文件时,会在文件开始的地方插入三个不可见的字符(0xEF 0xBB 0xBF,即BOM)。它是一串隐藏的字符,用于让记事本等编辑器识别这个文件是否以UTF-8编码。对于一般的文件,这样并不会产生什么麻烦。但对于 PHP来说,BOM是个大麻烦。因为PHP并不会忽略BOM,所以在读取、包含或者引用这些文件时,会把BOM作为该文件开头正文的一部分。根据嵌入式语言的特点,这串字符将被直接执行(显示)出来。
知道问题的原因之后,便很好解决了。我使用的是 phpstorm,在菜单栏文件里有“remove bom”选项,可以直接存为UTF-8无BOM模式。如果使用notepad++或其他工具的也可以选择“另存为”,然后在编码那儿选择“UTF-8无BOM”即可解决。
相关文章推荐
- HTML页面顶部出现空白部分(#65279字符)
- PHP页面上输出空白隐形字符65279解决办法
- 浏览器预览PHP文件时顶部出现空白影响布局分析原因及解决办法
- 解决网站在本地一切正常,上线后部分页面顶部出现空白区域问题
- 浏览器预览PHP文件时顶部出现空白影响布局分析原因及解决办法
- 调试QWebEngineView中的HTML时,调试页面空白,出现document.registerElement is not a function的原因和解决办法
- PHP截取中文字符出现乱码的具体解决办法
- Systrace生成的trace.html打开空白或者打不开的解决办法
- php strp_trags()去除html标签仍有空白解决办法
- php 存储中文字符到数据库时意外空白,未能成功保存的解决办法
- birt页面出现数据空白解决办法
- 配置Silverlight网站访问出现空白页面的解决办法(未配置MIME)---转
- PHP substr截取中文字符出现乱码的具体解决办法
- phpcms发布与生成内容页面空白的解决办法
- 配置Silverlight网站访问出现空白页面的解决办法
- nginx + php-fpm配置后页面显示空白的解决办法
- 导致页面顶部空白一行解决方法
- Html中载入含中文字符的js文件时出现中文乱码的解决办法
- php resizeimage 部分jpg文件 生成缩略图失败的原因分析及解决办法
- LNMP一键安装环境 wordpress后台部分页面出现502解决办法