vue动态获取div高度

vue动态获取div高度


<div v-resize="resize" id="first">
	111111111111
</div>

<div id="second"></div>

<script>
	directives: {  // 使用局部注册指令的方式
	    resize: { // 指令的名称
	      bind (el, binding) { // el为绑定的元素,binding为绑定给指令的对象
	        let width = '', height = '';
	        function isReize () {
	          const style = document.defaultView.getComputedStyle(el);
	          if (width !== style.width || height !== style.height) {
	            binding.value();  // 关键
	          }
	          width = style.width;
	          height = style.height;
	        }
	        el.__vueSetInterval__ = setInterval(isReize, 300);
	      },
	      unbind (el) {
	        clearInterval(el.__vueSetInterval__);
	      }
	    }
  },
  methods:{
  	resize () {
  	  //获取第一个div高度,第二个div距离头部高度
      let height=document.getElementById("first").clientHeight
      let body=document.getElementById("second")
      body.style.marginTop=(height+50).toString()+"px"
    },
  }
</script>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值