何时不应在 HTML 链接中使用 & 实体 ( &
)?
上下文:我问的原因是我正在使用 DOMDocument()
转换 <img>
标记到不同的 HTML,并且符号被复制。对于我的具体示例,我认为这是由于 mb_convert_encoding()
而发生的,但如果我不使用它,我还有其他问题。也许还有其他时候不应该在 HTML 链接中使用 & 实体?
public static function substituteImg($template, $values, $classI='autoInsert', $classF='',$escape=false) {
$classesToReplace = array($classI);
if($template) {
$doc = new DOMDocument();
$template = mb_convert_encoding($template, 'HTML-ENTITIES', 'UTF-8');
$doc->loadHTML($template);
$xpath = new DOMXPath($doc);
foreach( $xpath->query( '//img') as $img) {
// get the classes into an array
$classes = explode(' ', $img->getAttribute('class')); // this will contain the classes assigned to the element
if (array_intersect($classes, $classesToReplace))
{
// preprocess the image name to match the $values keys
$imageName = pathinfo($img->getAttribute("src"),PATHINFO_FILENAME);
if (isset($values[$imageName])) {
if(is_array($values[$imageName])){
//Not a text node
switch($values[$imageName]['type'])
{
case 'a':
$element = $doc->createElement( 'a',htmlentities($values[$imageName]['value']));
$element_href = $doc->createAttribute('href');
$element_href->value=htmlentities($values[$imageName]['attr']);
$element->appendChild($element_href);
if($classF) {
$element_class = $doc->createAttribute('class');
$element_class->value=$classF;
$element->appendChild($element_class);
}
break;
default:{trigger_error("Invalid element type", E_USER_ERROR);}
}
}
else {$element = $doc->createTextNode($escape?htmlentities($values[$imageName]):$values[$imageName]);}
$img->parentNode->replaceChild($element,$img);
}
}
}
$body = $doc->getElementsByTagName('body')->item(0);
$template=$doc->saveHTML($body); //Select the body tag
$template = str_replace(array('<body>', '</body>'), '', $template); //strip the body tags
unset($doc,$xpath);
}
return $template;
}
传递给 substituteImg() 的示例数组
Array
(
[bla] => 2721930660
[link1] => Array
(
[type] => a
[value] => Yes
[attr] => javascript:void(0)
)
[link2] => Array
(
[type] => a
[value] => link
[attr] => https://example.com/index.php?foo=123&bar=321
)
)
最佳答案
你应该使用 &
每当你想表达数据&
在 HTML 中,除非您在内容明确标记为 CDATA(这意味着 <script>
和 <style>
元素)的元素中使用它。
您不应该手动使用&
当您使用 DOM API 来操作 DOM 中的文本时。 (这就是你在这里所做的)。
如果 DOM 是从 HTML 文档生成的,&
将被解析为 &
当您生成 DOM 时。
如果您从 DOM 生成 HTML,&
将表示为 &
当您将其转换为 HTML 时。
For my specific example, I think it is happening due to mb_convert_encoding(),
不,这是由于 $doc->saveHTML($body);
它将 DOM 转换为 HTML。
关于javascript - 何时不应在 HTML 链接中使用 & 实体(和)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35869708/