electron和vue读取本地视频文件并转化为blob

electron和vue读取本地视频文件并转化为blob

fs获取本地视频并转化为blob格式

<template>
    <div class="test">
        <video controls="true" autoplay="" name="media">
      			<source :src="videoSrc" type="video/mp4">
        </video>
    </div>
</template>
<script>
    let fs = window.require('fs');
    export default {
        name: "test",
        data() {
            return {
                localSrc: 'C:/Users/xxxx/Desktop/source/视频文件.mp4',
                videoSrc: ''
            }
},
        mounted() {
            const _this= this;
            const buf = fs.readFileSync(this.localSrc);//读取文件,并将缓存区进行转换
           	const bolb = new Blob([uint8Buffer]);//转为一个新的Blob文件流
            console.log(bolb);
            _this.videoSrc = window.URL.createObjectURL(bolb); //转换为url地址并直接给到audio
        }
    }
</script>

参考 https://blog.csdn.net/qq_39050445/article/details/105066444

fs获取本地图片并转化为base64格式

<template>
    <div class="test">
        <img :src='imgSrc'>
    </div>
</template>
<script>
    let fs = window.require('fs');
    export default {
        name: "test",
        data() {
             return {
                localSrc: 'C:/Users/xxxx/Desktop/source/1.jpg',
                imgSrc: ''
            }
        },
        mounted() {
			// 1. 异步读取文件
           fs.readFile(this.localSrc, (err, data) => {    // url:读取文件的路径 data:读取的数据 err:读取失败时返回的信息
	           if (err) {
                    throw err;
                }
                console.log(data);  
                console.log(data.toString());  // 把buffer格式转化成字符串格式的数据
                console.log(data.toString('base64'));  // base64图片编码字符串
                this.imgSrc = 'data:image/jpeg;base64,'+data.toString('base64')   //返回值是读取的数据
            });
			// // 2. 同步读取文件
			//             console.log(fs.readFileSync(this.localSrc));    //返回值是读取的数据
			//             this.imgSrc = 'data:image/jpeg;base64,'+fs.readFileSync(this.localSrc)   //返回值是读取的数据
		}
    }
  • 1
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
首先,我们需要在Vue项目中安装一个依赖库:`vue-electron`,这个库可以让Vue项目支持Electron,从而实现本地文件读取和写入。 安装命令如下: ``` npm install --save vue-electron ``` 然后,在Vue项目的入口文件`main.js`中,引入`vue-electron`并使用它: ```js import Vue from 'vue' import App from './App.vue' import VueElectron from 'vue-electron' Vue.use(VueElectron) new Vue({ render: h => h(App) }).$mount('#app') ``` 接下来,我们可以在Vue组件中使用Node.js的`fs`模块来实现本地文件读取和写入。 假设我们要读取本地的一个名为`test.txt`的文件,代码如下: ```js const fs = require('fs') // 读取文件 fs.readFile('test.txt', 'utf-8', (err, data) => { if (err) { console.log(err) return } console.log(data) }) ``` 如果要写入文件,可以使用`fs.writeFile()`方法: ```js const fs = require('fs') // 写入文件 fs.writeFile('test.txt', 'Hello, world!', (err) => { if (err) { console.log(err) return } console.log('写入成功!') }) ``` 最后,如果需要获取本地文件路径,可以使用`dialog.showOpenDialog()`方法来弹出一个对话框,让用户选择文件。代码如下: ```js const { dialog } = require('electron').remote // 弹出对话框 dialog.showOpenDialog({ properties: ['openFile'] }).then(result => { // 获取选择的文件路径 const filePath = result.filePaths[0] console.log(filePath) }).catch(err => { console.log(err) }) ``` 需要注意的是,上面的代码需要在Vue组件的`<script>`标签中使用,而不能在单独的`.js`文件中使用。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值