vue中支持txt,docx,xlsx,mp4格式文件预览(纯前端)

这篇具有很好参考价值的文章主要介绍了vue中支持txt,docx,xlsx,mp4格式文件预览(纯前端)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言

在平常的工作当中,已经会遇到文件上传后需要预览的功能,比如docx,doc,xls,xlsx,ppt,pdf,txt,图片,视频等格式的文件,其实也可以让后端人员写接口解析,本着不想麻烦别人的心态,能自己解决的绝不麻烦别人,这里简单介绍txt,docx,xlsx,mp4文件预览。

一、txt文本预览

       1.在vue项目中安装axios     npm i axios -S  或 yarn add axios 

        2. 准备一个txt文件,里面随便输入些内容

        vue 预览txt,vue,前端,vue.js,javascript

      

       3. 使用axios来请求该txt文件

        vue 预览txt,vue,前端,vue.js,javascript

        页面完整代码如下

        

<template>
    <div class="txt" style="white-space: pre-wrap;">{{ textContent }}</div>
</template>
<script setup lang="ts">
    import { ref } from 'vue';
    import axios from 'axios';

    const textContent = ref<any>("");
    //这里可以是http地址,也可以是本地地址
    const url = "http://10.3.1.171:7878/123.txt";
    axios.get(url,{
        responseType:"text",
    }).then(res=>{
        textContent.value = res.data;
    })

</script>

 结果如下

  vue 预览txt,vue,前端,vue.js,javascript

发现他可以成功的拿到文本内容,但是我们文本里不仅有数字,英文,还有中文

4.这个时候我们往txt里写入一些中文

vue 预览txt,vue,前端,vue.js,javascript

再来看下结果

vue 预览txt,vue,前端,vue.js,javascript

喔嚯,这个时候出现了乱码,为什么会出现乱码呢???

原因很简单,axios用的默认编码为UTF-8,而txt的默认编码为ANSI,也就是GBK,明白了错误的原因就好办了,解决方法有两种

1.直接修改txt的编码为UTF-8,修改方式参考:怎么修改txt文件默认的编码格式?_百度知道

   修改完成后结果如下

   vue 预览txt,vue,前端,vue.js,javascript

   发现结果是我们想要的,你以为到这里就一切都结束了么?NO,NO,NO,这种方式不推荐,我们不可能每个文件都去设计编码,我们追求的就是要完美,永不加班...硬着头皮继续往下干,怀着一颗匠心精神的我必须打磨好自己的艺术品,哈哈,于是就有了第二种解决方案

2.在axios上做返回值的编码转换

   看了axios的文档发现一个transformResponse字段配置

    vue 预览txt,vue,前端,vue.js,javascript

我们就可以使用这个配置项来对返回的数据做转码,在处理之前先将

vue 预览txt,vue,前端,vue.js,javascript

responseType设置为blob,我们改用流的方式来实现,下面是完整代码

<template>
    <div><div class="txt" style="white-space: pre-wrap;">{{ textContent }}</div></div>
</template>
<script setup lang="ts">
    import { ref } from 'vue';
    import axios from 'axios';


    const textContent = ref<any>("");

    const url = "http://10.3.1.171:7878/123.txt";


    const transformData = (data:any)=>{
        return new Promise((resolve)=>{
            let reader = new FileReader();
            reader.readAsText(data,'GBK');
            reader.onload = ()=>{
                resolve(reader.result)
            }
        })
    }

    axios.get(url,{
        responseType:"blob",
        transformResponse: [
            async function (data) {
                return await transformData(data);
            },
        ],
    }).then(res=>{
        res.data.then((data:any)=>{
            textContent.value = data;
        })
    })

</script>

  这里使用的promise来返回fileReader读取到的数据,在fileReader中设置编码为GBK,这样编码  就同txt保持一致了,接下来

   我们再来重新创建一个txt文件

  vue 预览txt,vue,前端,vue.js,javascript

然后再来测试一下,结果如下

vue 预览txt,vue,前端,vue.js,javascript

结果就是我们最终想要的了,到此txt的预览就完成了,这里只是演示了如何加载txt文本,可以将其做成一个组件,便于以后使用

二、docx文件预览

docx文件的预览我们借用第三方插件@vue-office/docx 来处理 ,这里我们直接做成一个组件,子组件提供一个url即可,代码如下

  先使用yarn或npm安装@vue-office/docx 

<!--  docx文档查看器 -->
<template>
    <teleport to="body">
        <div  class="sx-docx-wrapper change-y-translate">
            <vue-office-docx :src="url" style="height: 100%; margin: 0; padding: 0"  @rendered="rendered"/>
            <span class="icon-close" @click="emits('close')"></span>
        </div>
    </teleport>
</template>
<script  lang="ts" setup>

    //引入VueOfficeDocx组件
    import VueOfficeDocx from "@vue-office/docx";
    //引入相关样式
    import "@vue-office/docx/lib/index.css";

    const props = defineProps({ 
        url:{
            type:String,
            default:""
        }
    })


    const emits = defineEmits<{
        (e:"close"):void
    }>()

    const rendered = ()=>{
        console.log("渲染完成");
    }
    
</script>
<style lang="scss" scoped>
    .sx-docx-wrapper{
        position:fixed;
        width:100%;
        height:100%;
        background:rgba(0,0,0,0.6);
        overflow:hidden;
        top:0;
        left:0;
        z-index:9999;
        display:flex;
        justify-content:center;
        align-items:center;

        .icon-close{
            position:absolute;
            top:10px;
            right:20px;
            width:30px;
            height:30px;
            background:url("/img/close.png") center no-repeat;
            background-size:100%;
            cursor:pointer;
        }
    }
</style>   

实现效果如下

vue 预览txt,vue,前端,vue.js,javascript

三、xlsx文件预览

       实现的方法跟docx差不多,只是插件不一样

       1、 npm i @vue-office/excel  或  yarn  add @vue-office/excel

       2、代码封装如下

        

<!--  excel文档查看器 -->
<template>
    <teleport to="body">
        <div  class="sx-excel-wrapper change-y-translate">
            <vue-office-excel
                :src="url"
                @rendered="renderedHandler"
                @error="errorHandler"
                style="width:80%;"
            />
            <span class="icon-close" @click="emits('close')"></span>
        </div>
    </teleport>
</template>
<script  lang="ts" setup>

    //引入VueOfficeExcel组件
    import VueOfficeExcel from "@vue-office/excel";
    //引入相关样式
    import "@vue-office/excel/lib/index.css";

    const props = defineProps({ 
        url:{
            type:String,
            default:""
        }
    })


    const emits = defineEmits<{
        (e:"close"):void
    }>()

    const renderedHandler = ()=>{
        console.log("渲染完成");
    }

    const errorHandler = ()=>{
        console.log("渲染失败");
    }
   
    
</script>
<style lang="scss" scoped>
    .sx-excel-wrapper{
        position:fixed;
        width:100%;
        height:100%;
        background:rgba(0,0,0,0.6);
        overflow:hidden;
        top:0;
        left:0;
        z-index:9999;
        display:flex;
        justify-content:center;
        align-items:center;

        .icon-close{
            position:absolute;
            top:10px;
            right:20px;
            width:30px;
            height:30px;
            background:url("/img/close.png") center no-repeat;
            background-size:100%;
            cursor:pointer;
        }
    }
</style>   

  运行效果如下

vue 预览txt,vue,前端,vue.js,javascript

四、mp4文件预览

mp4预览我们借用西瓜视频插件来实现

1、安装xgplayer  yarn add xgplayer  或者 npm i xgplayer

2.封装代码如下

<!-- 西瓜视频播放器插件 https://h5player.bytedance.com/guide/#%E5%AE%89%E8%A3%85 -->
<template>
    <teleport to="body">
        <div  class="sx-xgplayer-wrapper change-y-translate">
            <div class="video-section">
                <div id="video"></div>
                <span class="icon-close" @click="emits('close')"></span>
            </div>
        </div>
    </teleport>
</template>
<script  lang="ts" setup>
    import Player, { Events } from 'xgplayer'
    import 'xgplayer/dist/index.min.css';
    import { onMounted,onUnmounted } from 'vue';

    let player:any = null;
    const props = defineProps({ 
        url:{
            type:String,
            default:""
        }
    })

    const emits = defineEmits<{
        (e:"close"):void
    }>()


    onMounted(()=>{
        player = new Player({
            id: 'video',
            url: props.url,
            height: '100%',
            width: '100%',
            lang:'zh-cn'
        })
    })

    onUnmounted(()=>{
        player.destroy() // 销毁播放器
        player = null // 将实例引用置空
    })

   
    
</script>
<style lang="scss" scoped>
    .sx-xgplayer-wrapper{
        position:fixed;
        width:100%;
        height:100%;
        background:rgba(0,0,0,0.6);
        overflow:hidden;
        top:0;
        left:0;
        z-index:9999;
        display:flex;
        justify-content:center;
        align-items:center;

        .video-section{
            width:1200px;
            height:660px;
            background:#000;
            padding:20px;
            position:relative;
            box-shadow: 0 1px 8px 1px #5c5c5c;
        }

        .icon-close{
            position:absolute;
            top:10px;
            right:10px;
            width:20px;
            height:20px;
            background:url("/img/close.png") center no-repeat;
            background-size:100%;
            cursor:pointer;
        }
    }
</style>   

 相关的配置项请自行参考西瓜开发文档,文档地址在代码中哟!!!

 来看看实现的效果吧

vue 预览txt,vue,前端,vue.js,javascript
 

到这里,关于docx,xlsx,txt,mp4等预览的功能实现完成啦,下班!!!

感悟: 你不歇斯底里筋疲力尽,怎能破茧成蝶涅盘重生文章来源地址https://www.toymoban.com/news/detail-739865.html

到了这里,关于vue中支持txt,docx,xlsx,mp4格式文件预览(纯前端)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • vue实战--vue+elementUI实现多文件上传+预览(word/PDF/图片/docx/doc/xlxs/txt)

        最近在做vue2.0+element UI的项目中遇到了一个需求:需求是多个文件上传的同时实现文件的在线预览功能。需求图如下:     看到这个需求的时候,小栗脑袋一炸。并不知道该如何下手,之前的实践项目中也并没有遇到相似的功能。因此也废了一番功夫想要实现这样一个

    2024年01月23日
    浏览(51)
  • Vue通过微软官方链接预览pptx docx xlsx

    目录:         一、实现步骤         二、实现效果 代码真实可用! 一、实现步骤: 1、使用的是vue和elementUI, 假设有这些变量:attachment是附件的意思 2、页面代码: 主要是用 iframe 组件,src地址即为要展示的文件地址 3、methods中的函数: word、xls、ppt这些文件要用

    2024年02月11日
    浏览(28)
  • python 读写 json,csv,txt,docx,xlsx,xls文件大全

    最近再处理数据的时候,总会用到读写json,csv,xlsx和xls文件代码 这里就做个总结记录一下 扩展: json.loads(line)和 json.load(line) 通用写法: 1.2.1 list类型写入 1.2.2 dict类型写入 注意:json.dump()将Python对象序列化为JSON格式,并将其写入文件中。 扩展:json.dumps()和 json.dump() 2.2.1

    2024年02月06日
    浏览(33)
  • vue-office 支持多种文件(docx、excel、pdf)预览的vue组件库

    https://gitcode.com/mirrors/501351981/vue-office/overview?utm_source=csdn_github_acceleratorisLogin=1 文档预览场景大致可以分为两种: 有文档网络地址,比如 https://***.docx 文件上传时预览,此时可以获取文件的ArrayBuffer或Blob .docx文件预览 使用网络地址预览 上传文件预览 读取文件的ArrayBuffer 二进制

    2024年02月01日
    浏览(45)
  • vue 预览 有token验证的 doc、docx、pdf、xlsx、csv、图片 并下载

    预览 doc我也不会 下载

    2024年02月09日
    浏览(33)
  • 微信小程序 - 在线预览 Office 文件(doc / docx / xls / xlsx / ppt / pptx / pdf)

    网上大部分教程功能有问题且文章无逻辑混乱,本文将提供优秀的示例。

    2024年02月12日
    浏览(52)
  • 调库实现简单的AES,ECC,SHA-256,支持文本(txt)、图片(png)、音频(mp4)

    一、设计要求 在设计和实现系统时,选择调用了以下密码库: Bouncy Castle (BC): 用于实现椭圆曲线密码学(ECC)算法,确保系统安全传输密钥的过程。 Java Cryptography Architecture (JCA): 用于实现对称加密算法(如AES)和SHA-256哈希算法等,提供主流密码学算法的支持。 支持的数据类

    2024年01月25日
    浏览(43)
  • Android 13.0 开机动画支持mp4格式视频作为开机动画播放

     在13.0的系统产品开发中,在系统开机动画这块一般情况下都是播放开机图片,然后绘制多张开机图片形成开机动画模式,而产品需求要求支持开机mp4格式的短视频来作为开机动画播放视频来介绍产品情况,就需要用开机视频来替代开机动画来实现功能 Android 开机画面 由三个

    2024年02月08日
    浏览(43)
  • MP4文件格式解析

    读完本文你将收获: 知道如何读取一个mp4文件的基本信息。 知道如何从一个mp4文件中分离对应的视频数据或者音频数据的基本原理。 知道播放一个mp4文件时seek到指定时间,如何在mp4文件中查找到对应的媒体数据。 一个 mp4 文件通常由音频和视频两部分组成(当然有些还包含

    2023年04月26日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包