当前位置: 代码网 > it编程>编程语言>Javascript > vue如何封装选择文件组件和选择文件api

vue如何封装选择文件组件和选择文件api

2024年09月07日 Javascript 我要评论
vue封装选择文件组件和选择文件api方式一:选择文件组件<template><div @click="clickhandle"> <slot><

vue封装选择文件组件和选择文件api

方式一:选择文件组件

<template>
	<div @click="clickhandle">
       <slot></slot>
	   <input type="file" hidden  
	   ref="inputref" 
	   @change="changefile" 
	   :accept="accept"
	   :multiple="multiple"
	  /> 
	</div>
</template>
<script>
	export default {
		name:'choosefile',
		props:{
			accept:{
				type:string
			},
			multiple:{
				type:boolean,
				default:false
			}
		
		},
		methods: {
			clickhandle() {
				this.$refs.inputref.click()
			
			},
			changefile(e){
				
				this.$emit('choosefile',e.target.files)
			}
		},
	}
</script>

<style scoped>

</style>

方式二:选择文件api

const choosefile = (options) => {
	if(typeof options ==='function'){
		options={success:options}
	}
	if (typeof options === 'object') {
		let input = document.createelement("input")
		document.body.appendchild(input)
		input.type = 'file'
		input.hidden='hidden'
		if (options.accept) {
			input.accept = options.accept
		}
		if (options.multiple != null) {
			input.multiple = options.multiple
		}
		input.click()
		input.onchange = (e) => {
				options.success(e.target.files)
				document.body.removechild(input)
		}
	}
}
export default choosefile

挂载在vue原型上

使用

this.$choosefile((files)=>console.log(files))

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持代码网。

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com