当前位置: 首页 > news >正文

vue3使用iframe全屏展示pdf效果

最近的一个功能是编写一个pdf展示的组件,外部传入pdf的链接,根据这个功能,可以使用iframe去展示pdf,目前主要是将预览pdf的样式调整成与屏幕宽高一样
1.pdf使用iframe
2.使用translate将这个组件,使用to属性将目标元素传到body中(to就是目标元素。 接收一个 to prop 来指定传送的目标。
3.显示,隐藏的动画效果可以使用transition组件对iframe进行包裹
具体代码如下:

<template>
  <!-- 使用 teleport 将遮罩层和 iframe 渲染到 body 中 -->
  <teleport to="body">
    <!-- 遮罩层动画 -->
    <transition name="fade">
      <div v-if="showOverlay" class="overlay">
        <!-- 取消按钮 -->
        <button class="close-button" @click="closeOverlay">取消</button>
      </div>
    </transition>

    <!-- iframe 动画 -->
    <transition name="scale">
      <iframe
        v-if="showOverlay && pdfUrl"
        :src="pdfUrl"
        width="100%"
        height="100%"
        frameborder="0"
        class="pdf-iframe"
      ></iframe>
    </transition>
  </teleport>
</template>

<script setup>
import { ref, watch } from 'vue';

// 定义 props
const props = defineProps({
  pdfUrl: {
    type: String,
    required: true,
  },
  show: {
    type: Boolean,
    required: true,
  },
});

// 定义 emits
const emit = defineEmits(['close']);

// 响应式数据
const showOverlay = ref(props.show);

// 监听 props.show 的变化
watch(
  () => props.show,
  (newVal) => {
    showOverlay.value = newVal;
  }
);

// 关闭遮罩的方法
const closeOverlay = () => {
  showOverlay.value = false;
  emit('close'); // 通知父组件关闭
};
</script>

<style scoped>
/* 遮罩层样式 */
.overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5); /* 半透明黑色遮罩 */
  z-index: 1000; /* 确保遮罩层在最上层 */
  display: flex;
  justify-content: center;
  align-items: center;
}

/* 取消按钮样式 */
.close-button {
  position: absolute;
  top: 20px;
  right: 20px;
  padding: 10px 20px;
  background-color: #ff4d4f; /* 红色背景 */
  color: white;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  font-size: 16px;
}

.close-button:hover {
  background-color: #ff7875; /* 鼠标悬停时的颜色 */
}

/* iframe 样式 */
.pdf-iframe {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80%;
  height: 80%;
  z-index: 1001; /* iframe 在遮罩层之上 */
  background-color: white;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

/* 遮罩层淡入淡出动画 */
.fade-enter-active,
.fade-leave-active {
  transition: opacity 0.3s ease;
}

.fade-enter-from,
.fade-leave-to {
  opacity: 0;
}

/* iframe 缩放动画 */
.scale-enter-active,
.scale-leave-active {
  transition: all 0.3s ease;
}

.scale-enter-from,
.scale-leave-to {
  opacity: 0;
  transform: translate(-50%, -50%) scale(0.8);
}
</style>

如果在父组件使用,如下代码

<template>
  <div>
    <!-- 打开 PDF 的按钮 -->
    <button @click="openPdf">打开 PDF</button>

    <!-- 使用 PdfViewer 组件 -->
    <PdfViewer
      :pdfUrl="pdfUrl"
      :show="showPdfViewer"
      @close="closePdfViewer"
    />
  </div>
</template>

<script setup>
import { ref } from 'vue';
import PdfViewer from './components/PdfViewer.vue'; // 引入 PdfViewer 组件

// 定义响应式数据
const pdfUrl = ref('');
const showPdfViewer = ref(false);

// 打开 PDF 的方法
const openPdf = () => {
  pdfUrl.value = '/path/to/your/pdf/file.pdf'; // 可以是本地或远程 PDF 文件路径
  showPdfViewer.value = true;
};

// 关闭 PDF 的方法
const closePdfViewer = () => {
  showPdfViewer.value = false;
  pdfUrl.value = '';
};
</script>

<style>
/* 父组件的样式 */
</style>

相关文章:

  • 基于 Spring Boot +VUE的 “机动车号牌管理系统” 系统的设计与实现
  • JavaScript 系列之:Ajax、Promise、Axios
  • <网络> 网络基础3
  • 建筑三维设计软件如何实现弯道超车?
  • AI知识架构之神经网络
  • 【Cursor】报错:FATAL:v8_initializer.cc(630)] Error loading V8 startup snapshot file
  • Linux文件管理
  • 机器学习数学基础:31.信度与重测
  • 【LaTex】Review后添加参考文献并标记颜色IEEE LaTex模板
  • Qt QScrollArea 总结
  • AD9268(16BIT 80M)与AD9643(14BIT 250M) LVDS芯片对比分析
  • C语言学习,快速排序
  • 融合DWRSeg扩张式残差网络的YOLOv8:小目标检测中的技术突破与优化探索
  • 【问题解决方案】随笔 - vscode里面出现双环境解决方案
  • VMware虚拟机Mac版安装Win10系统
  • Kubernetes 从入门到精通:解锁容器编排的终极指南 [特殊字符]
  • Jenkinsfile流水线构建教程
  • 3.15 AI Agent 技术全景解析:从核心能力到企业级应用实践
  • html中的css
  • 算法教程:香槟塔问题
  • “影像上海”中的自媒体影像特展:无论何时,影像都需要空间
  • 玉渊谭天丨中方为何此时同意与美方接触?出于这三个考虑
  • 国家出口管制工作协调机制办公室部署开展打击战略矿产走私出口专项行动
  • 常州市委原常委、组织部部长陈翔调任江苏省民宗委副主任
  • 少年中国之少年的形塑
  • 金融监管总局:近五年民企贷款投放年平均增速比各项贷款平均增速高出1.1个百分点