php – 通过jQuery获取META描述

前端之家收集整理的这篇文章主要介绍了php – 通过jQuery获取META描述前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
假设我做了一个简单的 AJAX请求(在jQuery中),比如geturl.PHP?url = http://google.com

和geturl.PHP是这样的:

<?PHP
    if($_GET['url'])
    {
        $url=$_GET['url'];
        echo file_get_contents($url);
    }
?>

简单吧?

我如何从jQuery中返回的(非常长的)字符串中获取Meta描述?

这是我到目前为止所拥有的.是的,我知道,desc是错的.

$.get("geturl.PHP?url="+url,function(response)
{
    // Loading <title></title>data
    var title=(/<title>(.*?)<\/title>/m).exec(response)[1];
    var desc = $("Meta[name=description]").val();
    $("#linkBox").html("<div><b>"+title+"</b><br/>"+url+"<br />Desc: " + desc)
});

解决方法

使用正则表达式解析HTML是 bad practice.

令人讨厌的是,jQuery不支持解析头部中的元素,只支持正文.所以直接用JS代替:

window.onload = function(){ 
    $.ajax({
          type: 'GET',url: '/',dataType: 'html',success: function(data) {

            //cross platform xml object creation from w3schools
            try //Internet Explorer
              {
              xmlDoc=new ActiveXObject("Microsoft.XMLDOM");
              xmlDoc.async="false";
              xmlDoc.loadXML(data);
              }
            catch(e)
              {
              try // Firefox,Mozilla,Opera,etc.
                {
                parser=new DOMParser();
                xmlDoc=parser.parseFromString(data,"text/xml");
                }
              catch(e)
                {
                alert(e.message);
                return;
                }
              }

            var Metas = xmlDoc.getElementsByTagName("Meta");
            for (var i = 0; i < Metas.length; i++) {
              if (Metas[i].getAttribute("name") == "description") {
                alert(Metas[i].getAttribute("content") || Metas[i].getAttribute("edit"));
              }
            }
          }
    });
  }

David Burrows开始无耻地撕掉.谢谢,大卫!

小提琴:http://jsfiddle.net/wCL8W/8/

猜你在找的PHP相关文章