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

网站建立之间不安全如何解决网络营销是什么专业类别

网站建立之间不安全如何解决,网络营销是什么专业类别,仿冒网站制作,wordpress 原理在工作中可能会遇到前端展示pdf文件进行预览并提供下载的需求场景,例如操作指引,这个时候需要寻找一款实现该功能的插件,以pdjjs举例子 1. 安装pdf.js npm install pdfjs-dist2. 引入pdf.js import pdfjsLib from pdfjs-dist3.加载pdf文件流 这个地方区分是请求后端接口还是…

在工作中可能会遇到前端展示pdf文件进行预览并提供下载的需求场景,例如操作指引,这个时候需要寻找一款实现该功能的插件,以pdjjs举例子

1. 安装pdf.js

npm install pdfjs-dist

2. 引入pdf.js

import pdfjsLib from 'pdfjs-dist'

3.加载pdf文件流

这个地方区分是请求后端接口还是直接加载本地pdf文件

如果是请求后端获取到的pdf文件流

axios.get('/api/pdfdoc', { responseType: 'blob' }).then(response => {const blob = new Blob([response.data], { type: 'application/pdf' })this.viewPdf(blob)})

如果是读取本地的文件,则url地址直接是本地的地址

在viewPdf()方法中,使用getDocument()方法加载pdf文件:

viewPdf(fileUrl){
let _this = this;
PDFJS.getDocument(fileUrl).then(fileContent =>{
_this.pdfDoc = fileContent;
setTimeout(()=>{
_this.renderPage();
},100)
})},

4. 渲染pdf

使用pdf.js的Renderer渲染pdf文件。可以使用getViewport()方法获取pdf页面的视图大小。

在renderPdf()方法中,遍历pdf文件的每个页面,并使用Renderer将其渲染:

renderPage(){
// 获取页面canvas节点
let canvas = document.getElementById('infoPrvacy-content');
const ctx = canvas.getContext("2d");
this.pdfDoc.getPage(1).then(page =>{
// 文件页面的视图 1倍
const viewport = page.getViewport(0.5);
// 将画布宽度设置为视图宽度
canvas.width = viewport.width;
canvas.height = viewport.height;const renderContext = {
canvasContext: ctx,
viewport: viewport
};
console.log(renderContext);
// 渲染页面内容:参数是canvas画布上下文,以及文件视图
page.render(renderContext);
})
},

注意: 一定要引用字体包,否则会乱码

const obj = {};
obj.cMapUrl = '/assets/pdfjs/cmaps/';
obj.cMapPacked = true;
obj.url = './static/test.pdf'
this.viewPdf(obj)

js部分的代码

<script>
const pdfJS = require("pdfjs-dist");pdfJS.GlobalWorkerOptions.workerSrc = require("pdfjs-dist/build/pdf.worker.entry");
export default {mounted() {},data() {return {pageNo: null,pdfPageNumber: null,pdfTotalPages: 1,renderingPage: false,pdfData: null, // PDF的base64scale: 1, // 缩放值};},methods: {uploadFile() {let inputDom = this.$refs.fielinput;let file = inputDom.files[0];let reader = new FileReader();reader.readAsDataURL(file);reader.onload = () => {let data = atob(reader.result.substring(reader.result.indexOf(",") + 1));this.loadPdfData(data);};},loadPdfData(data) {// 引入pdf.js的字体let CMAP_URL = "https://unpkg.com/pdfjs-dist@2.0.943/cmaps/";//读取base64的pdf流文件this.pdfData = pdfJS.getDocument({data: data, // PDF base64编码cMapUrl: CMAP_URL,cMapPacked: true,});console.log(this.pdfData);this.renderPage(1);this.renderScrollPdf();},// 根据页码渲染相应的PDFrenderPage(num) {this.renderingPage = true;this.pdfData.promise.then((pdf) => {this.pdfPageNumber = pdf.numPages;pdf.getPage(num).then((page) => {// 获取DOM中为预览PDF准备好的canvasDOM对象let canvas = this.$refs.myCanvas;let viewport = page.getViewport(this.scale);canvas.height = viewport.height;canvas.width = viewport.width;let ctx = canvas.getContext("2d");let renderContext = {canvasContext: ctx,viewport: viewport,};page.render(renderContext).then(() => {this.renderingPage = false;this.pageNo = num;});});});},clickPre() {if (!this.renderingPage && this.pageNo && this.pageNo > 1) {this.renderPage(this.pageNo - 1);}},clickNext() {if (!this.renderingPage &&this.pdfPageNumber &&this.pageNo &&this.pageNo < this.pdfPageNumber) {this.renderPage(this.pageNo + 1);}},renderScrollPdf() {this.pdfData.promise.then((pdf) => {this.pdfTotalPages = pdf.numPages;this.renderScrollPdfPage(1);});},},
};
</script>
http://www.khdw.cn/news/55826.html

相关文章:

  • 成都网站网页制作seo查询seo优化
  • 商城网站项目案例常州seo排名收费
  • 建立电子商务网站百度高级搜索页面
  • 代理网络工具下载快速刷排名seo软件
  • 做优惠卷网站倒闭了多少制作网站的最大公司
  • 制作网站需要钱吗指数型基金怎么买
  • 用电脑做网站网站开发用什么软件
  • 在网上那里能接单做网站品牌网站建设
  • 包头做网站的公司招聘信息南宁百度关键词排名公司
  • html5网站素材关键词搜索指数查询工具
  • 成都广告公司排名网站seo视频狼雨seo教程
  • ai中如何做网站切图全国广告投放平台
  • 数据录入网站开发免费涨粉工具
  • ubuntu 做网站 分区国家市场监督管理总局官网
  • 做网站要求什么公司网络推广方案
  • wordpress引用php文件网站优化策划书
  • 四川招标信息网官网处理事件seo软件
  • 找别人做网站靠谱吗自动推广引流app
  • 英文网站接单做翻译优化营商环境条例
  • 请问网上有没有比较好的网站可以做照片书的呀?要求质量比较好的!建一个网站需要多少钱?
  • 网站适配手机个人推广app的妙招
  • 广州做网站比较好的公司免费域名解析平台
  • 荆门网站建设服务潍坊seo网络推广
  • 电商网站用什么框架做青岛seo青岛黑八网络最强
  • 购买手表的网站界首网站优化公司
  • 免费英文建设网站短视频培训机构
  • 成都龙泉建设有限公司网站seo经理
  • 网站域名被劫持网站seo推广排名
  • 企业网站相关案例营销技巧和营销方法心得
  • 企业网站导航一般做多高长沙 建站优化