Vue使用ScreenFull插件实现全屏切换

官网链接

1. 安装

javascript 复制代码
pnpm add screenfull

2. 使用

javascript 复制代码
<template>
  <!-- 如果浏览器不支持全屏,则不显示这个图标 -->
  <div class="screen-full" @click="changeScreenFull()" v-if="isScreenEnable">
    <!-- 全屏和非全屏的图标 -->
    <SvgIcon
      :name="isScreenFull ? 'fullscreen-exit' : 'fullscreen'"
      color="#515151"
      width="30px"
      height="30px"
    ></SvgIcon>
  </div>
</template>

<script setup lang="ts">
import { ref, onMounted, onUnmounted } from 'vue'
import { ElMessage } from 'element-plus'
import screenfull from 'screenfull'
// 是否支持全屏
const isScreenEnable = ref(screenfull.isEnabled)
// 用于控制图片状态
const isScreenFull = ref(false)
// 切换全屏
const changeScreenFull = () => {
  // 检查全屏功能是否可用
  if (!isScreenEnable.value) {
    ElMessage.error('浏览器不支持全屏')
    return
  }
  // 根据当前全屏状态进行切换
  if (screenfull.isFullscreen) {
    screenfull.exit()
    isScreenFull.value = false
  } else {
    screenfull.toggle()
    isScreenFull.value = true
  }
}
// 监听全屏状态, 当全屏状态改变时, 会触发change事件
onMounted(() => {
  screenfull.on('change', () => {})
})
// 停止监听
onUnmounted(() => {
  screenfull.off('change', () => {})
})
</script>

3. 方法

  • 引入
javascript 复制代码
import screenfull from 'screenfull'
  • 是否可以全屏(属性)(浏览器的支持)
javascript 复制代码
// 返回值是boolean类型
screenfull.isEnabled
  • 开启全屏状态(方法)
javascript 复制代码
screenfull.toggle()
  • 退出全屏状态
javascript 复制代码
screenfull.exit()
  • 监听全屏状态发生改变时,可以执行回调
javascript 复制代码
screenfull.on('change', () => {})
  • 停止监听的回调
javascript 复制代码
screenfull.off('change', () => {})
相关推荐
鱼樱前端4 分钟前
全前端需要的工程化能力之 Vue3 + TypeScript + Vite 工程化项目搭建最佳实践
前端·vue.js
明远湖之鱼5 分钟前
手把手带你实现 Vite+React 的简易 SSR 改造【含部分原理讲解】
前端·react.js·vite
野生的程序媛24 分钟前
重生之我在学Vue--第10天 Vue 3 项目收尾与部署
前端·javascript·vue.js
qq_353233538934 分钟前
【原创】springboot+vue智能办公管理系统设计与实现
vue.js·spring boot·后端
大叔_爱编程1 小时前
wx125基于ssm+vue+uniapp的校园商铺系统小程序
vue.js·小程序·uni-app·毕业设计·ssm·源码·课程设计
烟锁池塘柳01 小时前
技术栈的概念及其组成部分的介绍
前端·后端·web
加减法原则1 小时前
面试题之虚拟DOM
前端
故事与他6451 小时前
Tomato靶机攻略
android·linux·服务器·前端·网络·web安全·postcss
jtymyxmz2 小时前
mac 苍穹外卖 前端环境配置
前端
烛阴2 小时前
JavaScript Rest 参数:新手也能轻松掌握的进阶技巧!
前端·javascript