<template>
<div class="p-content">
<div>
<input @change="handleGetFile" type="file" id="file" />
div>
div>
template>
<script lang="ts">
import { Options, Vue } from 'vue-class-component';
import HelloWorld from './components/HelloWorld.vue';
import {Room} from './types/room'
@Options({
components: {
HelloWorld,
},
})
export default class App extends Vue {
list: Room[] = [];
handleGetFile(file: any) {
const dom = document.getElementById('file') as HTMLInputElement;
if (dom && dom.files) {
console.log(dom.files);
const file = dom.files[0];
const types = file.name.split('.')[1];
const fileType = ['json'].some(
(item) => item === types
);
if (!fileType) {
alert('格式错误,请上传excel类型文件');
return;
}
this.handleReadFile(file)
}
}
handleReadFile(file: File) {
const reader = new FileReader();
reader.readAsText(file);
reader.onload = (thisFile)=>{
if(thisFile.target && thisFile.target.result) {
const result = JSON.parse(thisFile.target.result.toString())
console.log(result)
}
}
}
}
script>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
margin-top: 60px;
}
style>

- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
- 66
- 67
- 68