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

珠海十大网站建设公司网络营销包括哪些

珠海十大网站建设公司,网络营销包括哪些,就业网站建设总结,比较好的网页制作公司背景 实现预览ofd/pdf超链接功能 业务实现 pdf的预览 实现方式&#xff1a; 直接使用 <iframe :src"${url}#navpanes0&toolbar0" /> 实现pdf的预览。 navpanes0 隐藏侧边栏toolbar0 隐藏顶部工具栏 使用pdf.js&#xff0c;代码先行&#xff1a; <tem…

背景

实现预览ofd/pdf超链接功能

业务实现

  1. pdf的预览

    实现方式:

    1. 直接使用 <iframe :src="${url}#navpanes=0&toolbar=0" /> 实现pdf的预览。

      • navpanes=0 隐藏侧边栏
      • toolbar=0 隐藏顶部工具栏
    2. 使用pdf.js,代码先行:

      <template><a-tabsv-if="props.urls.length > 0":default-active-key="activateTab"type="card"class="pdf-tabs"@change="tabChangeHandler"><a-tab-pane v-for="url in props.urls" :key="url" :tab="fileName(url)"><div class="pdf-container"><canvasv-if="url.endsWith('.pdf')"class="canvas":ref="(el) => (canvasRefs[url] = el)"></canvas><a-button class="mb-2" type="link" @click="handleDownload(url)">{{ fileName(url) }}</a-button></div></a-tab-pane></a-tabs>
      </template><script lang="ts" setup>
      import { ref, watch, nextTick } from 'vue'
      import * as pdfjsLib from 'pdfjs-dist'
      import { debounce } from 'lodash-es'
      import { saveAs } from 'file-saver'
      import EasyOFD from 'easyofd'interface Props {urls?: string[]
      }const props = withDefaults(defineProps<Props>(), {urls: () => [],
      })
      const url = ref<string>('')
      const activateTab = ref<string>('')
      const canvasRefs = ref<Record<string, HTMLCanvasElement | null>>({})// 文件类型判断
      const ext = ref<string>('pdf')
      const isOfd = ref<boolean>(false)
      const isPdf = ref<boolean>(false)//  设置 PDF.js worker 路径(推荐方式)
      pdfjsLib.GlobalWorkerOptions.workerSrc = '/pdf.worker.min.mjs'//  从 URL 中提取文件名
      function fileName(url: string): string {try {const decodeURL = decodeURIComponent(url).split('/')const lastSegment = decodeURL[decodeURL.length - 1]const firstIndex = lastSegment.indexOf('-')const lastIndex = lastSegment.lastIndexOf('-')if (firstIndex === -1 || lastIndex === -1 || lastIndex <= firstIndex) {return lastSegment.split('.')[0] // fallback 文件名}const name = lastSegment.substring(firstIndex + 1, lastIndex)const ext = name.split('.').pop()if (['pdf', 'ofd'].includes(ext ?? '')) {return name.substring(0, name.lastIndexOf('.'))}return name} catch {return 'unknown'}
      }// 获取文件类型
      const getFileType = (url: string) => {const decodeURL = decodeURIComponent(url)ext.value = decodeURL.endsWith('.pdf') ? 'pdf' : 'ofd'isPdf.value = ext.value === 'pdf'isOfd.value = ext.value === 'ofd'isPdf.value ? loadAndRenderPdf(url) : loadAndRenderOfd(url)
      }
      //  下载文件
      const handleDownload = debounce((url: string) => {saveAs(url, `${fileName(url)}.${ext.value}`)
      }, 300)//  加载并渲染 PDF
      async function loadAndRenderPdf(pdfUrl: string) {try {const canvas = canvasRefs.value[pdfUrl]if (!canvas) returnconst loadingTask = pdfjsLib.getDocument(pdfUrl)const pdf = await loadingTask.promiseconst page = await pdf.getPage(1)const viewport = page.getViewport({ scale: 1.3 })canvas.height = viewport.heightcanvas.width = viewport.widthconst context = canvas.getContext('2d')if (!context) returnconst renderContext = {canvasContext: context,viewport,}await page.render(renderContext).promise} catch (error) {console.error('PDF 渲染失败:', error)}
      }//  标签页切换时加载 PDF
      async function tabChangeHandler(key: string) {url.value = keyactivateTab.value = fileName(key)await nextTick() // 等待 DOM 更新if (key.endsWith('.pdf')) {await loadAndRenderPdf(key)}
      }//  页面初始化时自动加载第一个 PDF
      watch(() => props.urls,async (newUrls) => {if (newUrls && newUrls.length > 0) {console.log('newUrls:', newUrls)url.value = newUrls[0]activateTab.value = fileName(newUrls[0])await nextTick()getFileType(newUrls[0])}},{ immediate: true },
      )
      </script><style lang="less" scoped>
      .canvas {border: 1px solid #000;width: 100%; // 响应式宽度border: 1px solid #000;
      }
      .pdf-container {display: flex;flex-direction: column;align-items: start;gap: 12px;max-width: 100%; // 限制最大宽度max-height: 400px;overflow: auto;
      }
      </style>
      

      说一下重点:

      问题一: 通过命令pnpm install pdf.js安装后,通常出现引用问题;Cannot resolve pdf.worker.entry。代码中使用的版本"pdfjs-dist": "^5.2.133"

      import * as pdfjsLib from 'pdfjs-dist';
      import pdfjsWorker from 'pdfjs-dist/build/pdf.worker.entry';pdfjsLib.GlobalWorkerOptions.workerSrc = pdfjsWorker;
      

      解决方案:

      1. 将文件从node_modules/pdfjs-dist/build/pdf.worker.min.mjs移动至项目的public/pdf.worker.min.mjs,可以使用命令 cp node_modules/pdfjs-dist/build/pdf.worker.min.mjs public/pdf.worker.min.mjs
      2. 修改引用:
        import * as pdfjsLib from 'pdfjs-dist';pdfjsLib.GlobalWorkerOptions.workerSrc = '/pdf.worker.min.mjs'
        

      ps: 上面的代码中包含了文件的下载功能,需要安装 "file-saver": "^2.0.5",

  2. ofd的预览

    实现方式:easyofd
    安装的依赖:pnpm -i jszip x2js jb2 opentype.js easyofd
    业务实现:

    <template><div ref="containerRef" style="width: 100%; height: 800px;"></div>
    </template><script setup>
    import EasyOFD from "easyofd"
    import { ref, onMounted } from 'vue'const containerRef = ref(null)onMounted(async () => {if (!containerRef.value) {console.error('OFD 容器不存在')return}const ofd = new EasyOFD('myOFD', containerRef.value)try {const response = await fetch('/files/sample.ofd')const blob = await response.blob()ofd.loadFromBlob(blob)} catch (e) {console.error('OFD 加载失败:', e)}
    })
    </script><style lang="less" scoped>
    // 隐藏右侧的ppi模块,减少空白
    :deep(#myOFD-ppi) {display: none;
    }
    // 增加边框
    :deep(#myOFD-ofd-canvas) {border: 1px solid #000;
    }
    // 隐藏顶部按钮
    :deep(.OfdButton) {display: none !important;
    }
    </style>
    

官网效果:(easyOfd官网手册)
在这里插入图片描述

http://www.dtcms.com/wzjs/15934.html

相关文章:

  • 古镇网站建设深圳网站营销seo费用
  • 做微网站公司简介怎么在网上推广广告
  • 50岁到55岁急招工东莞搜索网络优化
  • 帮公司做网站网站建设的方法有哪些
  • 企业建设网站公司安徽搜索引擎优化
  • 怎么查网站开发者联系方式市场营销毕业后做什么工作
  • 怎样做一名优秀的网站技术客服新东方留学机构官网
  • 成都交投成高建设公司网站手机百度app免费下载
  • 合肥网站建设兼职外贸平台排名
  • 自己建设网站怎么做seo系统源码
  • 曹县有没有做网站seo如何提高网站排名
  • 汕头市政府门户网站官网手机百度网页版 入口
  • 龙岩做网站改版找哪家公司今日头条搜索引擎
  • 个旧网络推广宁波seo网页怎么优化
  • 郑州大学现代远程教育《网页设计与网站建设》课程考核要求网络营销的策划方案
  • 珠海企业网站广州全网推广
  • 服务器如何做网站网站seo
  • 常用网站开发工具千锋教育学费多少
  • 网站怎么做搜素引擎如何在百度上做广告
  • 做风险代理案源的网站网站提交入口百度
  • 网站好坏标准seo关键词查询
  • 网站规划设计是什么淘宝指数查询工具
  • 东莞天助网的网站黄页网站推广
  • 微站官网最大免费发布平台
  • 建设设计网站线上推广平台报价
  • 网站必须做可信认证吗百度pc端提升排名
  • 网站下面的公安备案怎么做长春seo排名扣费
  • 国务院 门户网站建设要求免费引流推广
  • 国家质检总局网站品牌建设上海牛巨微网络科技有限公司
  • 青海西宁网页网站制作百度信息流推广和搜索推广