JavaScript 监听单个元素高宽变化MutationObserver

如果你只是想监听窗口大小变化 resize就能满足你

window.onresize = () => {
     console.log("窗口变化");
};

jqurey写法

$(window).resize(()=>{
    console.log("窗口变化");
})

但如果是要监听某一块元素 resize就不太适用了

例如 我们在界面上定义一个类名为 main-wrapper 的div元素

<div class = "main-wrapper" style = "width: 10vw;height: 10vh;background-color: #00ff00"></div>

我们要监听他 可以通过MutationObserver
我们创建一个元素 来做一个点击事件 改变main-wrapper的宽度

<div id = "kelinp">变化</div>
document.getElementById("kelinp").onclick = () => {
    document.getElementsByClassName('main-wrapper')[0].style.width = "30vw";
}

此时 我们点击kelinp main-wrapper的宽度就会从10vw 变成30vw

那么 我们来写监听main-wrapper尺寸变化的js代码

const callback = (mutations) => {
   mutations.forEach((mutation)=> {
         console.log("main-wrapper宽度发生变化");
     });
 }
 var targetNode = document.getElementsByClassName('main-wrapper')[0];
 var config = { attributes: true, childList: false, subtree: false };
 const observer = new MutationObserver(callback);
 observer.observe(targetNode, config);

然后我们点击这个 kelinp 变化 元素
在这里插入图片描述
可以看到 我们也是顺利的监听到了main-wrapper的变化

disconnect可以取消监听

observer.disconnect();
  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Android 中,可以使用 `View` 的 `OnLayoutChangeListener` 接口来监听屏幕高宽变化。具体做法如下: 1. 首先,在需要监听屏幕尺寸变化的 `View` 中添加 `OnLayoutChangeListener` 监听器: ```java view.addOnLayoutChangeListener(new View.OnLayoutChangeListener() { @Override public void onLayoutChange(View view, int left, int top, int right, int bottom, int oldLeft, int oldTop, int oldRight, int oldBottom) { // 处理屏幕尺寸变化的逻辑 } }); ``` 2. 在 `onLayoutChange` 方法中处理屏幕尺寸变化的逻辑。 例如,你可以通过 `View` 的 `getWidth()` 和 `getHeight()` 方法获取当前的屏幕宽度和高度: ```java int width = view.getWidth(); int height = view.getHeight(); ``` 或者,你也可以通过 `View` 的 `getLayoutParams()` 方法获取 `LayoutParams` 对象,然后再从中获取宽度和高度: ```java ViewGroup.LayoutParams layoutParams = view.getLayoutParams(); int width = layoutParams.width; int height = layoutParams.height; ``` 注意,当屏幕尺寸变化时,`onLayoutChange` 方法会被多次调用。因此,你需要根据实际情况决定在何时执行相应的逻辑。 另外,如果你想监听整个屏幕的高宽变化,可以在 `Activity` 或 `Fragment` 的 `onCreate` 方法中添加全局的 `OnLayoutChangeListener` 监听器: ```java getWindow().getDecorView().getRootView().addOnLayoutChangeListener(new View.OnLayoutChangeListener() { @Override public void onLayoutChange(View view, int left, int top, int right, int bottom, int oldLeft, int oldTop, int oldRight, int oldBottom) { // 处理屏幕尺寸变化的逻辑 } }); ``` 这样,当整个屏幕的高宽发生变化时,上述监听器的 `onLayoutChange` 方法会被调用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值