vue.js

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript类库 > vue.js > 前端Vue全屏screenfull通用

前端Vue全屏screenfull通用解决方案及原理详细分析

作者:溜_x_i_a_o_迪

这篇文章主要给大家介绍了关于前端Vue全屏screenfull通用解决方案及原理的相关资料,使用screenfull这一第三方库可以实现更稳定的全屏功能,需要的朋友可以参考下

全屏 API

原理

对于 screenfull 而言,浏览器本身已经提供了对用的 API点击这里即可查看,这个 API 中,主要提供了两个方法:

原生方法存在问题

尝试了一个网页,(整个) 区域背景颜色为黑色

所以通常情况下我们不会直接使用该 API 来去实现全屏效果,而是会使用它的包装库 screenfull

方案

方案实现分为两步:

实现 screenfull 组件

封装 **screenfull** 组件:

npm i screenfull@5.1.0

icon是一个变化的值:需要监听全屏的变化然后切换图标非全屏模式展示:

全屏模式展示:

<template>
  <div>
    <svg-icon
      :icon="isFullscreen ? 'exit-fullscreen' : 'fullscreen'"
      @click="onToggle"
    />
  </div>
</template>

<script setup>
import { ref, onMounted, onUnmounted } from 'vue'
import screenfull from 'screenfull'

// ref 对象,用于存储当前是否为全屏状态,初始值为 false。
const isFullscreen = ref(false)

// 监听screenfull的变化
const change = () => {
  isFullscreen.value = screenfull.isFullscreen
}

// 切换事件
const onToggle = () => {
  // 切换全屏模式
  screenfull.toggle()
}

// 设置侦听器
onMounted(() => {
  // on:绑定监听
  screenfull.on('change', change)
})

// 删除侦听器
onUnmounted(() => {
  // off:取消监听
  screenfull.off('change', change)
})
</script>

<style lang="scss" scoped></style>

引入该组件:

<screenfull class="right-menu-item hover-effect" />
import Screenfull from '@/components/Screenfull'

总结

到此这篇关于前端Vue全屏screenfull通用解决方案及原理的文章就介绍到这了,更多相关前端Vue全屏screenfull通用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文