我在Vue.js中使用Vue.js组件作为前端,并希望创建一个带有文件上传的用户注册表单。我能够使用v-text-field (一个Vuetify组件)创建表单。
发布于 2017-11-14 08:04:39
Vue JS直到今天还没有文件输入功能,所以您可以调整v文本字段以像图像输入字段一样工作。这个概念是,创建一个文件输入字段,然后使用css隐藏它,并在v-text字段中添加一个事件来触发该特定的文件输入字段来上传图像。我已经附加了片段,请做玩,我也有一个小提琴创建使用vue和vuetify,访问这里。谢谢!
new Vue({
el: '#app',
data: () => ({
title: "Image Upload",
dialog: false,
imageName: '',
imageUrl: '',
imageFile: ''
}),
methods: {
pickFile() {
this.$refs.image.click()
},
onFilePicked(e) {
const files = e.target.files
if (files[0] !== undefined) {
this.imageName = files[0].name
if (this.imageName.lastIndexOf('.') <= 0) {
return
}
const fr = new FileReader()
fr.readAsDataURL(files[0])
fr.addEventListener('load', () => {
this.imageUrl = fr.result
this.imageFile = files[0] // this is an image file that can be sent to server...
})
} else {
this.imageName = ''
this.imageFile = ''
this.imageUrl = ''
}
}
}
})<link href='https://fonts.googleapis.com/css?family=Roboto:300,400,500,700|Material+Icons' rel="stylesheet">
<link href="https://unpkg.com/vuetify/dist/vuetify.min.css" rel="stylesheet">
<div id="app">
<v-app>
<v-toolbar dark color="primary">
<v-toolbar-side-icon></v-toolbar-side-icon>
<v-toolbar-title class="white--text">{{ title }}</v-toolbar-title>
<v-spacer></v-spacer>
<v-btn icon @click="dialog = !dialog">
<v-icon>link</v-icon>
</v-btn>
</v-toolbar>
<v-content>
<v-container fluid>
<v-flex xs12 class="text-xs-center text-sm-center text-md-center text-lg-center">
<img :src="imageUrl" height="150" v-if="imageUrl"/>
<v-text-field label="Select Image" @click='pickFile' v-model='imageName' prepend-icon='attach_file'></v-text-field>
<input
type="file"
style="display: none"
ref="image"
accept="image/*"
@change="onFilePicked"
>
</v-flex>
<v-dialog v-model="dialog" max-width="290">
<v-card>
<v-card-title class="headline">Hello World!</v-card-title>
<v-card-text>
Image Upload Script in VUE JS
<hr>
Yubaraj Shrestha
<br>http://yubarajshrestha.com.np/
</v-card-text>
<v-card-actions>
<v-spacer></v-spacer>
<v-btn color="green darken-1" flat="flat" @click.native="dialog = false">Close</v-btn>
</v-card-actions>
</v-card>
</v-dialog>
</v-container>
</v-content>
</v-app>
</div>
<script src="https://unpkg.com/vue/dist/vue.js"></script>
<script src="https://unpkg.com/vuetify/dist/vuetify.js"></script>
最新版本(V2.0.5)在编辑这篇日期为2019年8月11日的帖子时,有一个专用的文件输入选项。请按照下面的链接获得官方文件:https://vuetifyjs.com/en/components/file-inputs。
发布于 2019-02-13 19:05:25
一个简单的窍门是:
<v-btn color="success" @click="$refs.inputUpload.click()">Success</v-btn>
<input v-show="false" ref="inputUpload" type="file" @change="yourFunction" >只需使用以下属性创建一个输入:
type=fileref=inputUpload这个像id一样工作,你可以按你的意愿命名它。v-show=false,这隐藏了输入然后创建一个按钮,当您单击它时,它会在输入上传按钮上触发一个单击事件。
发布于 2017-07-10 13:54:32
这是我们将来会添加的东西,但目前不是。有关于github的讨论,有几个用户发布了他们目前正在使用的实现,https://github.com/vuetifyjs/vuetify/issues/238
https://stackoverflow.com/questions/44989162
复制相似问题