Vue mixins 和 watch 动态监测屏幕的高度

当页面内容的高度不确定的时候  header 始终在顶部--- fixed。footer是随内容移动的 内容很少则footer在页面底部,当内容很多footer在内容的底部

屏幕始终是满屏的 不留空白

为了能够重复使用这个功能 用了vue 的混入 

mixins.js

export const MixIns = {
    data() {
        return {
            //屏幕高度
            clientHeight: '',
        }
    },
    mounted() {
        this.clientHeight = `${document.documentElement.clientHeight}`;
        let that = this
        window.onresize = function() {
            that.clientHeight = `${document.documentElement.clientHeight}`;
            if (that.$refs.page) {
                that.$refs.page.style.minHeight = that.clientHeight + 'px';
            }
        }
    },
    watch: {
        clientHeight(clientHeight) {
            this.$refs.page.style.minHeight = clientHeight + 'px';
        }
    }
}

app.vue

<template>
    <div>
        <div ref="page" class="live">
            <div id="local-player" class="player-box">
            </div>
        </div>
    </div>
</template>

<script>
import {MixIns} from "@/api/mixins.js"
    export default {
        mixins:[MixIns],
        data(){}
    }

不管那个页面。自需要设置 ref 等于 page

引入并注册即可实现。动态监测屏幕的高度

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值