会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132358个问题
WEB前端全系列/第二阶段:JavaScript编程模块/运算符_数据类型和流程循环语句 137楼

老师,对于document.body.clientWidth/document.body.clientHeight

document.body.offsetWidth/document.body.offsetHeight

document.body.scrollWidth/document.body.scrollHeight

document.body.scrollTop/document.body.scrollLeft

这几个有点不太明白,我理解是offsetWidth=clientWidth+border;可是在变网页窗口的时候,offsetWidth比clientWidth小。不知道为什么我这么写之后,网页就不显示div了。

f5b1aa9a5fa1d7bc4d2e63a7ca19485.png

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style type="text/css">
    </style>
<body style="height: 1000px">
<div style="background: #0d3349;width: 300px;height: 2000px"></div>
</body>
    <script type="text/javascript">
        window.onload=function(){
            document.write("网页可见区域宽:"+document.body.clientWidth+"</br>");
            document.write("网页可见区域高client:"+document.body.clientHeight+"</br>");
            document.write("网页可见区域宽:"+document.body.offsetWidth+"</br>");
            document.write("网页可见区域高offset:"+document.body.offsetHeight+"</br>");
            document.write("网页正文全文宽:"+document.body.scrollWidth);
            document.write("网页正文全文高:"+document.body.scrollHeight);
            document.write("网页被卷去的高:"+document.body.scrollTop);
            document.write("网页被卷去的左:"+document.body.scrollLeft);
            document.write("网页正文部分上:"+window.screenTop);
            document.write("网页正文部分左:"+window.screenLeft);
            document.write("网页正文部分上:"+window.screenX);
            document.write("网页正文部分左:"+window.screenY);
            document.write("屏幕分辨率的高:"+window.screen.height);
            document.write("屏幕分辨率的宽:"+window.screen.width);
            document.write("屏幕可用工作区高度:"+window.screen.availHeight);
            document.write("屏幕可用工作区宽度:"+window.screen.availWidth);
            document.write("浏览器高度:"+window.outerHeight+"</br>");
            document.write("浏览器宽度:"+window.outerWidth+"</br>");
            document.write("浏览器内页面可用高度:"+window.innerHeight+"</br>");
            document.write("浏览器内页面可用宽度:"+window.innerWidth);
        }
    </script>
</head>
</html>


WEB前端全系列/第二阶段:JavaScript编程模块/面向对象编程 141楼
WEB前端全系列/第二阶段:JavaScript编程模块/字符串与数组 142楼
WEB前端全系列/第二阶段:JavaScript编程模块/浏览器模型(BOM) 144楼
WEB前端全系列/第二阶段:JavaScript编程模块/浏览器模型(BOM) 145楼
WEB前端全系列/第二阶段:JavaScript编程模块/DOM模型 146楼

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>编写一个带有hover样式的导航栏,要求采用鼠标事件实现</title>
</head>
<body>
    <script>
        var arr = ["首页","军事","新闻","我们"];
        var ul = document.createElement('ul');
        var ul_style = document.createAttribute('style');
        ul_style.value="list-style: none;margin: 0px;padding: 0px;";
        ul.setAttributeNode(ul_style);
        for (var i = 0;i<arr.length;i++){
            var li = document.createElement("li");
            var li_style = document.createAttribute("style");
            li_style.value="display: block;float: left;width: 150px;height: 50px;" +
                "line-height: 50px;text-align: center;background:pink;margin-left:100px;";
            li.setAttributeNode(li_style);
            var a = document.createElement("a");
            var a_style = document.createAttribute("style");
            a_style.value="text-decoration: none;";
            a.setAttributeNode(a_style);
            a.innerHTML=arr[i];
            li.appendChild(a);
            ul.appendChild(li);
        }
        document.body.appendChild(ul);
        
        //li事件
        var li = document.querySelector('li');
        li.onmouseover = function () {
            li.style.background='yellow';
        };
        li.onmouseout = function () {
            li.style.background="pink";
        };
        
        //超链接事件
        var a = document.querySelector('a');
        a.onmouseover = function () {
            a.style.color="white";
        };
        a.onmouseleave = function () {
            a.style.color="#ccc";
        };
    </script>
</body>
</html>

老师,你好,请问一下怎么设置属性能让每个li元素都有鼠标事件,我这样设置的只有第一个li产生了鼠标事件?

image.png

WEB前端全系列/第二阶段:JavaScript编程模块/浏览器模型(BOM) 148楼
WEB前端全系列/第二阶段:JavaScript编程模块/正则对象 149楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637