JS Javascript 用js做响应式布局(不常用,仅做拓展了解)

本文介绍了如何利用JavaScript监听浏览器视口的resize事件,通过获取视口宽度来动态调整页面样式,实现响应式布局。主要步骤包括设置resize事件监听、定义变量存储视口宽度、根据宽度条件设置不同样式,并提供了示例代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.设置浏览器视口监听事件resize

window.addEventListener( ‘resize’ , function(){});
当用户的视口发生改变,运行相应的函数程序;

2.在函数程序中定义一个变量赋值浏览器的用户视口宽度;

3.在函数程序中判断用户浏览器的视口宽度进而设置不同宽度下的样式

4.示例代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style> 
        body{
            height: 5000px;
        }

        div{
            width: 1000px;
            height: 100px;
            background: pink;
            margin: 50px auto;
        }
    </style>
</head>
<body>
    <div></div>

    <script>
        // 获取div标签对象
        var oDiv = document.querySelector('div');

        // 视窗窗口监听事件
        // 当 视窗窗口 宽度高度改变时 触发函数程序
        window.addEventListener( 'resize' , function(){
            // 视窗窗口 宽度高度改变时 触发函数程序 
            // 获取 浏览器视窗窗口的宽度
            var width = document.documentElement.clientWidth ;

            // 如果 视窗窗口宽度 大于 1200 div的宽度是原始宽度的100%
            if( width > 1200 ){
                oDiv.style.width = '1000px';
                oDiv.style.background = 'pink';
            
            // 如果 视窗窗口宽度 在 1200 至 960 div的宽度是原始宽度的 80%
            }else if( width <= 1200 && width > 960 ){
                oDiv.style.width = '800px';
                oDiv.style.background = 'blue';

            // 如果 视窗窗口宽度 在 960 至 768 div的宽度是原始宽度的 60%
            }else if( width <= 960 && width > 768 ){
                oDiv.style.width = '600px';
                oDiv.style.background = 'orange';
            
            // 如果 视窗窗口宽度 小于 768 div的宽度是原始宽度的 40%
            }else if( width <= 768 ){
                oDiv.style.width = '400px';
                oDiv.style.background = 'green';

            }
        })
 
    </script>

</body>
</html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值