HTML解析/检查某些标签的某些属性的某些值

时间:2013-04-26 07:49:59

标签: javascript jquery html html-parsing zoom

如何使用JavaScript检查网页是否包含以下任何内容:

<meta name="viewport" content="width=device-width, initial-scale=1.0 maximum-scale=1, user-scalable=no" />

<meta name="viewport" content="initial-scale=1.0 maximum-scale=1" />

<meta name="viewport" content="maximum-scale=1" />

<meta name="viewport" content="maximum-scale=1.0" />

<meta name="viewport" content="user-scalable=no" />

如果其中任何内容在源代码中,则运行某些JavaScript代码,就像在if条件的套件中一样。

基本上我要做的是检查是否禁用了缩放,如果是,则执行某些代码,如果不是,则执行其他代码。

2 个答案:

答案 0 :(得分:0)

您可以使用

function readViewportValues(){
    var metas = $('meta[name=viewport]');
    var properties = {};

    function isNumber(n) {
        return !isNaN(parseFloat(n)) && isFinite(n);
    }

    function readItem(index, text) {
        var parts = jQuery.trim(text).split(' ');
        console.log(parts);
        if (parts.length > 1) {
            $.each(parts, readItem);
        } else {
            parts = parts[0].split('=');
            var key = jQuery.trim(parts[0]),
                value = parts[1];
            value = isNumber(value) ? parseFloat(value) : value;
            properties[key] = value;
        }
    }

    metas.each(function () {
        var content = $(this).attr('content').split(',');
        $.each(content, readItem);
    });
    return properties;
}


// usage
var viewport = readViewportValues();
if (viewport['maximum-scale'] === 1){
    // do something
}

这将返回具有找到的属性的对象,您可以查询它..

答案 1 :(得分:0)

var nodes = $('meta[name=viewport]'); 
$(nodes).each(function(index, nodeValue){ 
     var content = $(nodeValue).attr('content');// check nodeValue here 
     // You will get values of content from each meta element here in content variable ex. "user-scalable=no"
     // so now based on these values you can so do any processing you want
});