用户
 找回密码
 入住 CI 中国社区
搜索
查看: 4663|回复: 2
收起左侧

[已解决] 关于使用CI分页类后,网页顶部有空白的问题!

[复制链接]
发表于 2010-5-19 16:41:01 | 显示全部楼层 |阅读模式
本帖最后由 jackbang 于 2010-5-20 13:23 编辑

在VIEW视图页里设了BODY  margin-left: 0px; margin-top: 0px; margin-right: 0px; margin-bottom: 0px;

如果直接$this->load->view('test_view');则网页上下左右全部都是顶边的,没有缝隙,
当$this->load->view('equip/eq_seach',$data);传了$data后,网页顶部总是要留有大约30PX的空白,左右下三面没有缝隙。

不知道是为什么,百思不得其解,很是郁闷啊,请大家帮帮我,如果有类似经验的请告诉我如何解决,谢谢!
发表于 2010-5-19 18:07:08 | 显示全部楼层
视图里有 BOM
我猜的。
如果不是就是见鬼了。
 楼主| 发表于 2010-5-20 13:18:56 | 显示全部楼层
感谢,感谢HEX的帮助,确是BOM的问题,这里我还要说一下,视图文件里没有BOM,是控制器文件里有BOM,所以单独输出视图CSS是正常的,如果一旦传入$data就会发生顶部空白的问题,后在网上查了一下相关资料,现在把解决办法记下,方便初学者解决。

顶部有空白行或整页空白的原因:
BOM信息是文件开头的一串隐藏的字符,用于让某些编辑器识别这是个UTF-8编码的文件。
文件以UTF-8编码保存时,有两种情情况:带Unicode签名(BOM)和不带 Unicode签名
类似WINDOWS自带的记事本等软件,在保存一个以UTF-8编码的文件时,会在文件开始的地方插入三个不可见的字符(0xEF 0xBB 0xBF,即BOM——Byte Order Mark)。它是一串隐藏的字符,用于让记事本等编辑器识别这个文件是否以UTF-8编码。
对于一般的文件,这样并不会产生什么麻烦。但对于 PHP来说,PHP在设计时就没有考虑 BOM的问题,不会忽略UTF-8编码的文件开头BOM的那三个字符,会把BOM作为该文件开头正文的一部分。由于必须在<?或者<?php后面的代码才会作为PHP代码执行,所以将会造成在页面上输出这三个字符,显示效果就要看浏览器了,一般是一个空行或是一个乱码。由于在html一开头有这3个字符的存在,即使页面的 top padding 设置为0,也无法让整个网页紧贴浏览器顶部。由于受COOKIE送出机制的限制,在这些文件开头已经有BOM的文件中,COOKIE无法送出(因为在 COOKIE送出前PHP已经送出了文件头),所以登入和登出功能失效。一切依赖COOKIE、SESSION实现的功能全部无效。

解决办法:

    在编辑、更改任何文本文件时,请务必使用不会乱加BOM的编辑器。Linux下的编辑器应该都没有这个问题。WINDOWS下,请勿使用记事本等编辑器。推荐的编辑器是:Editplus 2.12版本以上;EmEditor;UltraEdit(需要取消‘添加BOM’的相关选项);Dreamweaver(需要取消‘添加BOM’的相关选项)等。对于已经添加了BOM的文件,要取消的话,可以用以上编辑器另存一次。(Editplus需要先另存为gb,再另存为UTF-8。)

ultraedit, editplus, notepad四个工具对UTF-8 的支持不相同,下面是对四个工具对UTF-8 支持的总结:
UTF-8 BOM header: 是三个字符: EF BB BF。
  1. notepad
notepad 在保存时,选择UTF-8 格式,会在文件头写上BOM header.
  2. editplus
文件保存时,选择UTF-8 格式,不会在文件头写上 BOM header.
  3. ultraedit
ultraedit 对UTF-8 的支持最为完备。在advanced->configuration中可以    选择文件保存时是否写上BOM header.
  4. vi
指的是Linux 下的vim, 如果UTF-8 文件开头有BOM header, 其能够正常显示UTF-8编码,否则,显示为乱码。
  还有一些编码转换工具,比如,可以用java 写一个简单的编码转换工具,这些工具是不会增加BOM header的。

--------------------
但是一个文件一个文件去除必竟很麻烦,后来找到了段代码,将它生成PHP文件放在网站根目录下执行一下,立即就把所有的BOM文件记号
去掉了,如果BOM文件太多的话,用这个方法吧,

<?php
//remove the utf-8 boms
//by magicbug at gmail dot com

if (isset($_GET['dir'])){ //config the basedir
$basedir=$_GET['dir'];
}else{
$basedir = '.';
}

$auto = 1;

checkdir($basedir);

function checkdir($basedir){
if ($dh = opendir($basedir)) {
while (($file = readdir($dh)) !== false) {
if ($file != '.' && $file != '..'){
if (!is_dir($basedir."/".$file)) {
echo "filename: $basedir/
$file ".checkBOM("$basedir/$file")."
";
}else{
$dirname = $basedir."/".
$file;
checkdir($dirname);
}
}
}
closedir($dh);
}
}

function checkBOM ($filename) {
global $auto;
$contents = file_get_contents($filename);
$charset[1] = substr($contents, 0, 1);
$charset[2] = substr($contents, 1, 1);
$charset[3] = substr($contents, 2, 1);
if (ord($charset[1]) == 239 && ord($charset[2]) == 187 &&
ord($charset[3]) == 191) {
if ($auto == 1) {
$rest = substr($contents, 3);
rewrite ($filename, $rest);
return ("BOM found,
automatically removed.
");
} else {
return ("BOM found.
");
}
}
else return ("BOM Not Found.");
}

function rewrite ($filename, $data) {
$filenum = fopen($filename, "w");
flock($filenum, LOCK_EX);
fwrite($filenum, $data);
fclose($filenum);
}
?>


最后再次谢谢HEX的提示,希望对像我一样的初学者有所帮助,也请大家对我等初学者尽量给于关心和支持,我爱CI.

本版积分规则