Vue支持预览 docx格式,xlsx格式,pdf格式的文件

1 预览docx格式文档

配置文件存放位置
1.1 引入相关配置文件
  • docx预览会使用 docx-preview

  • 如果直接使用npm包,当解析时出现如下错误的话,就使用下面的方法,如果没报错,就正常引入使用即可,不需要把打包后的代码引入到入口文件里。

    效果图

  • 直接把 docx-preview打包后的代码直接引入到入口文件里 -- 如果未报错则跳过这一步

<!DOCTYPE html>
<html lang="">
  <head>
    <meta charset="utf-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width,initial-scale=1.0" />
    <link rel="icon" href="<%= BASE_URL %>favicon.ico" />
    <title><%= htmlWebpackPlugin.options.title %></title>
    <script src="<%= BASE_URL %>static/config.js"></script>
    <!--------docx-preview配置文件--------->
    <script src="./docxPreview/polyfill.min.js"></script>
    <script src="./docxPreview/jszip.min.js"></script>
    <script src="./docxPreview/docx-preview.min.js"></script>
    <script src="./docxPreview/docx-preview.min.js.map"></script>

  </head>
  <body>
    <noscript>
      <strong
        >We're sorry but <%= htmlWebpackPlugin.options.title %> doesn't work
        properly without JavaScript enabled. Please enable it to
        continue.</strong
      >
    </noscript>
    <div id="app"></div>
    <!-- built files will be auto injected -->
  </body>
</html>
1.2 预览docx格式文件
<template>
  <div class="center">
    <div class="center-file" id="center-file">
  </div>
</template>

<script>
import { defaultOptions, renderAsync } from "docx-preview";
import axios from "axios";
export default {
  name: "",

  props: {},

  components: {},

  data() {
    return {};
  },

  computed: {},

  watch: {},
  created() {
    this.init();
  },

  methods: {
    init() {
      axios({
        method: "GET",
        url: "http://127.0.0.1:8899/file",
        params: {},
        responseType: "blob",
      }).then(function (data) {
        // docx
        renderAsync(data.data, document.getElementById("center-file"), null, {
          className: "docx", // 默认和文档样式类的类名/前缀
          inWrapper: false, // 启用围绕文档内容渲染包装器
          ignoreWidth: false, // 禁止页面渲染宽度
          ignoreHeight: false, // 禁止页面渲染高度
          ignoreFonts: false, // 禁止字体渲染
          breakPages: false, // 在分页符上启用分页
          ignoreLastRenderedPageBreak: false, //禁用lastRenderedPageBreak元素的分页
          experimental: false, //启用实验性功能(制表符停止计算)
          trimXmlDeclaration: false, //如果为真,xml声明将在解析之前从xml文档中删除
          debug: false, // 启用额外的日志记录
        });
      });
    },
  },

  mounted() {},
};
</script> 

<style scoped lang="scss">
.center {
  width: 100%;
  height: 100%;
  background-color: #efefef;
  padding: 24px;
  box-sizing: border-box;
  .center-file {
    width: 100%;
    height: 100%;
    overflow: auto;
    background: #fff;
  }
}
</style>
  • 特别注意:返回值是用的 blob格式接收的,但只需要红框里的数据,如发现报错(描述具体为不是文件等等)麻烦打印下返回值跟此图对照,如还未解决麻烦评论区留言!
    注意点,下面的同理

    docx效果图

2 xlsx格式文件预览

  • xlsx预览会使用 luckyexcel

  • 如果直接使用npm包,当出现如下错误时,使用以下解决方案,如果没报错,就正常引入使用即可,不需要把打包后的代码引入到入口文件里。

    效果图

  • 直接把 luckyexcel打包后的代码直接引入到入口文件里

2.1 引入相关配置文件 -- 如果未报错则跳过这一步
<!DOCTYPE html>
<html lang="">
  <head>
    <meta charset="utf-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width,initial-scale=1.0" />
    <link rel="icon" href="<%= BASE_URL %>favicon.ico" />
    <title><%= htmlWebpackPlugin.options.title %></title>
    <script src="<%= BASE_URL %>static/config.js"></script>
    <!---------luckyexcel 配置文件-------->
    <link rel="stylesheet" href="./luckyexcelConfig/pluginsCss.css" />
    <link rel="stylesheet" href="./luckyexcelConfig/plugins.css" />
    <link rel="stylesheet" href="./luckyexcelConfig/luckysheet.css" />
    <link rel="stylesheet" href="./luckyexcelConfig/iconfont.css" />
    <script src="./luckyexcelConfig/plugin.js"></script>
    <script src="./luckyexcelConfig/luckysheet.umd.js"></script>
    <script src="./luckyexcelConfig/luckysheet.umd.js.map"></script>
  </head>
  <body>
    <noscript>
      <strong
        >We're sorry but <%= htmlWebpackPlugin.options.title %> doesn't work
        properly without JavaScript enabled. Please enable it to
        continue.</strong
      >
    </noscript>
    <div id="app"></div>
    <!-- built files will be auto injected -->
  </body>
</html>
1.2 预览xlsx格式文件
<template>
  <div class="center">
    <div class="center-file" id="center-file">
  </div>
</template>

<script>
import LuckyExcel from "luckyexcel";
import axios from "axios";
export default {
  name: "",

  props: {},

  components: {},

  data() {
    return {};
  },

  computed: {},

  watch: {},
  created() {
    this.init();
  },

  methods: {
    init() {
      axios({
        method: "GET",
        url: "http://127.0.0.1:8899/file",
        params: {},
        responseType: "blob",
      }).then(function (data) {
        // xlsx
        LuckyExcel.transformExcelToLucky(
            data.data,
            (exportJson, luckysheetfile) => {
              // luckysheet.destroy(); // 卸载表格
              // 重新创建新表格
              luckysheet.create({
                container: "center-file", // 设定DOM容器的id
                title: "luckysheet", //表 头名
                lang: "zh", //中文
                plugins: ["chart"],
                showinfobar: false, // 是否显示顶部信息栏
                // showstatisticBar: false, // 是否显示底部计数栏
                // allowEdit: false, // 是否允许前台编辑
                enableAddRow: false, // 是否允许增加行
                enableAddCol: false, // 是否允许增加列
                // sheetFormulaBar: false, // 是否显示公式栏
                // enableAddBackTop: false, //返回头部按钮
                data: exportJson.sheets, //表格内容
                // showtoolbar: false, // 是否显示工具栏
                title: exportJson.info.name, //表格标题
              });
            }
          );
      });
    },
  },

  mounted() {},
};
</script> 

<style scoped lang="scss">
.center {
  width: 100%;
  height: 100%;
  background-color: #efefef;
  padding: 24px;
  box-sizing: border-box;
  .center-file {
    width: 100%;
    height: 100%;
    overflow: auto;
    background: #fff;
  }
}
</style>
xlsx效果图

2 pdf格式文件预览

  • 浏览器本身是支持pdf格式文件预览的,除非想在界面里内嵌一个区域。
1.1 下载所需配置包
  • 特别注意:vue-pdf需要文档的http地址
npm i vue-pdf
1.2 预览pdf格式文件
<template>
  <div class="center">
      <pdf
          ref="pdf"
          v-for="i in numPages"
          :key="i"
          :src="url"
          :page="i"
        ></pdf>
  </div>
</template>

<script>
import axios from "axios";
import pdf from "vue-pdf";

export default {
  name: "",

  props: {},

  components: {},

  data() {
    return {
      url: null,
      numPages: null,
    };
  },

  computed: {},

  watch: {},
  created() {
    this.init();
  },

  methods: {
    init() {
      axios({
        method: "GET",
        url: "http://127.0.0.1:8899/file",
        params: {},
        responseType: "blob",
      }).then(function (data) {
        // pdf
        // vue-pdf 包不允许本地localhost与任何地址进行访问--发到服务器这个问题自然就没了
       // 文件流里会自带服务端文件地址,如不理解请翻到1.2区域返回值展示图(特别注意红字下那个图)此处不再贴图。
        this.url = data.config.url;
        let loadingTask = pdf.createLoadingTask(this.url);
        loadingTask.promise
          .then((pdf) => {
            this.numPages = pdf.numPages;
          })
          .catch((err) => {
            console.error("pdf 加载失败", err);
            this.$message.error("pdf 加载失败");
          });
      });
    },
  },

  mounted() {},
};
</script> 

<style scoped lang="scss">
.center {
  width: 100%;
  height: 100%;
  background-color: #efefef;
  padding: 24px;
  box-sizing: border-box;
  .center-file {
    width: 100%;
    height: 100%;
    overflow: auto;
    background: #fff;
  }
}
</style>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,053评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,527评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,779评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,685评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,699评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,609评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,989评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,654评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,890评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,634评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,716评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,394评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,976评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,950评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,191评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,849评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,458评论 2 342

推荐阅读更多精彩内容