6

我有一个响应式的 wordpress 主题。当屏幕尺寸低于 740 时,菜单被编码为隐藏。但是它只在主页上正确执行此操作。如果我转到任何其他页面,菜单会折叠但它无法隐藏并且我收到此错误:“未捕获的 TypeError:无法读取属性 'clientWidth' of null”

这是代码,我在主题的 header.php 文件中调用了它:

var ww = document.body.clientWidth;
$(document).ready(function() {
    adjustMenu();


    $(".cat").click(function(e) { // cat class
        e.preventDefault();
        $(this).toggleClass("active");
        $(".sf-menu").toggle();
    });
});

function adjustMenu() {
    if (ww <= 740) { //change this to your breakpoint
        $('.sf-menu').hide();
        $(".cat").show();
        if (!$(".cat").hasClass("active")) {
            $(".sf-menu").hide();
        } else {
            $(".sf-menu").show();
        }
    } else {
        $('.sf-menu').show();
        $(".cat").hide();

    }
}


$(window).bind('resize orientationchange', function() {
    ww = document.body.clientWidth;
    adjustMenu();
});
4

2 回答 2

9

尝试在文档末尾添加您的脚本。原因是,一开始你的文档宽度为零,因为你的内容还没有加载,所以没有什么可以显示的,所以你的宽度为零

于 2013-06-23T17:56:01.903 回答
6

我会说$(window).width();从 jquery 中使用。它返回浏览器视口的宽度,这是等效的,或者我会说是传统 javascript 的更好选择。

您的代码将如下所示。检查它是否有效。

var ww = $(window).width();
$(document).ready(function() {
    adjustMenu();


    $(".cat").click(function(e) { // cat class
        e.preventDefault();
        $(this).toggleClass("active");
        $(".sf-menu").toggle();
    });
});

function adjustMenu() {
    if (ww <= 740) { //change this to your breakpoint
        $('.sf-menu').hide();
        $(".cat").show();
        if (!$(".cat").hasClass("active")) {
            $(".sf-menu").hide();
        } else {
            $(".sf-menu").show();
        }
    } else {
        $('.sf-menu').show();
        $(".cat").hide();

    }
}


$(window).bind('resize orientationchange', function() {
    ww = document.body.clientWidth;
    adjustMenu();
    });
    function adjustMenu() {
        if (ww <= 740) { //change this to your breakpoint
        $('.sf-menu').hide();
        $(".cat").show();
        if (!$(".cat").hasClass("active")) {
            $(".sf-menu").hide();
        } else {
            $(".sf-menu").show();
        }
    } else {
        $('.sf-menu').show();
        $(".cat").hide();

    }
}


$(window).bind('resize orientationchange', function() {
    ww = $(window).width();
    adjustMenu();
});
于 2013-04-08T10:10:08.397 回答