为什么出现在我的 HTML?

我在 Firebug 中看到这个字符。

我不知道为什么会这样,我的代码里没有这样的字符。对于 Firefox 来说还可以,但是对于 IE 来说,一切都会崩溃。我甚至不能在谷歌上搜索这个字符。

我用 utf-8编码保存文件,没有出错。

enter image description here

148548 次浏览

问题中的字符 &#65279是 Unicode字符“零宽度无中断空间”(U + FEFF)。这可能是您通过复制/粘贴将其复制到代码中而没有意识到。由于它不可见,所以很难判断您是否使用了显示实际 Unicode 字符的编辑器。

一种选择是在一个不理解 unicode 的非常基本的文本编辑器中打开该文件,或者在一个理解 Unicode 但能够使用实际代码显示任何非 ascii 字符的编辑器中打开该文件。

一旦找到它,就可以删除它周围的小块文本,然后手动重新键入该文本。

试试:

<?php
// Tell me the root folder path.
// You can also try this one
// $HOME = $_SERVER["DOCUMENT_ROOT"];
// Or this
// dirname(__FILE__)
$HOME = dirname(__FILE__);


// Is this a Windows host ? If it is, change this line to $WIN = 1;
$WIN = 0;


// That's all I need
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>UTF8 BOM FINDER and REMOVER</title>
<style>
body { font-size: 10px; font-family: Arial, Helvetica, sans-serif; background: #FFF; color: #000; }
.FOUND { color: #F30; font-size: 14px; font-weight: bold; }
</style>
</head>
<body>
<?php
$BOMBED = array();
RecursiveFolder($HOME);
echo '<h2>These files had UTF8 BOM, but i cleaned them:</h2><p class="FOUND">';
foreach ($BOMBED as $utf) { echo $utf ."<br />\n"; }
echo '</p>';


// Recursive finder
function RecursiveFolder($sHOME) {
global $BOMBED, $WIN;


$win32 = ($WIN == 1) ? "\\" : "/";


$folder = dir($sHOME);


$foundfolders = array();
while ($file = $folder->read()) {
if($file != "." and $file != "..") {
if(filetype($sHOME . $win32 . $file) == "dir"){
$foundfolders[count($foundfolders)] = $sHOME . $win32 . $file;
} else {
$content = file_get_contents($sHOME . $win32 . $file);
$BOM = SearchBOM($content);
if ($BOM) {
$BOMBED[count($BOMBED)] = $sHOME . $win32 . $file;


// Remove first three chars from the file
$content = substr($content,3);
// Write to file
file_put_contents($sHOME . $win32 . $file, $content);
}
}
}
}
$folder->close();


if(count($foundfolders) > 0) {
foreach ($foundfolders as $folder) {
RecursiveFolder($folder, $win32);
}
}
}


// Searching for BOM in files
function SearchBOM($string) {
if(substr($string,0,3) == pack("CCC",0xef,0xbb,0xbf)) return true;
return false;
}
?>
</body>
</html>

将此代码复制到 php 文件上传到 root 并运行它。

了解更多: http://forum.virtuemart.net/index.php?topic=98700.0

只要使用带编码 UTF-8的记事本 + + ,不带 BOM 即可。

是的,解决这个问题非常简单,只需要通过记事本 + + 打开该文件,然后按照下面的步骤—— > 编码 UTF-8而不需要 BOM。 那就省省吧。 对我也有用!

“我不知道为什么会这样”

我刚刚遇到一个可能的原因: ——你的 HTML 页面正在组装 从不同的文件里。也许您的文件只包含最终页面的正文或横幅部分。这些文件包含 BOM (0xFEFF)标记。然后,作为合并过程的一部分,您将在最终合并的 HTML 文件上运行整洁的 HTML 或 xmllint。

那会导致它!

一个老的愚蠢的把戏,在这种情况下工作... 粘贴代码从您的编辑器的女士记事本,然后反之亦然,邪恶的字符将消失! 我的灵感来自于 Wyisyg/mword 复制粘贴问题。 记事本 + + utf-8 w/out BOM 也可以工作。

这是我的建议: 我也有同样的问题,我尝试使用记事本 + + 转换为 UTF-8无 BOM,还有老的“复制到 MS 记事本,然后再回来”的伎俩,都没有用。通过确保所有文件(以及“包含”文件)都是 相同的文件系统,我的问题得到了解决; 我有一些文件是 Windows 格式的,还有一些是从远程 Linux 服务器上复制的,所以是 UNIX 格式的。

净空(装饰)前

然后用正则表达式 .replace("/\xEF\xBB\xBF/", "")代替

我正在研究 JavaScript,我曾经研究过 JavaScript。

如果你使用记事本 + + ,“菜单”> > “编码”> > “转换为 UTF-8”你的“包含”文件。

如果你有很多文件要查看,你可以使用这个工具: Https://www.mannaz.at/codebase/utf-byte-order-mark-bom-remover/

都是莫里斯的功劳

它帮助我清理一个系统,在 CakePhp 中使用 MVC,在 Linux、 Windows 中使用不同的工具。.在一些文件中,我的设计被破坏了。.所以在使用调试工具登录 Chrome 后,找到 & # 65279错误