Los dos métodos que figuran a continuación tienen el mismo objetivo: escanear el contenido de la publicación y determinar si al menos una etiqueta img tiene un atributo alt que contiene la "palabra clave" que se está probando.¿Utiliza xPath o Regex?
Soy nuevo en XPath y preferiría usarlo en función de lo caro que el enfoque se compara con la versión de expresiones regulares ...
Método # 1 utiliza preg_match Método
function image_alt_text_has_keyword($post)
{
$theKeyword = trim(wpe_getKeyword($post));
$theContent = $post->post_content;
$myArrayVar = array();
preg_match_all('/<img\s[^>]*alt=\"([^\"]*)\"[^>]*>/siU',$theContent,$myArrayVar);
foreach ($myArrayVar[1] as $theValue)
{
if (keyword_in_content($theKeyword,$theValue)) return true;
}
return false;
}
function keyword_in_content($theKeyword, $theContent)
{
return preg_match('/\b' . $theKeyword . '\b/i', $theContent);
}
# 2 utiliza xRuta
function keyword_in_img_alt()
{
global $post;
$keyword = trim(strtolower(wpe_getKeyword($post)));
$dom = new DOMDocument;
$dom->loadHTML(strtolower($post->post_content));
$xPath = new DOMXPath($dom);
return $xPath->evaluate('count(//a[.//img[contains(@alt, "'.$keyword.'")]])');
}
"constains"? Creo que tienes un error tipográfico. –
Gracias, corrigió el error ortográfico y editó xPath –