mirror of https://github.com/sveltejs/svelte
				
				
				
			Merge pull request #3849 from AlbertLucianto/fix/file-input-binding-declared-last
	
		
	
				
					
				
			fix input binding fails if type declared lastpull/3860/head
						commit
						70de6a23c9
					
				| @ -0,0 +1,82 @@ | ||||
| import { | ||||
| 	SvelteComponent, | ||||
| 	attr, | ||||
| 	detach, | ||||
| 	element, | ||||
| 	init, | ||||
| 	insert, | ||||
| 	listen, | ||||
| 	noop, | ||||
| 	run_all, | ||||
| 	safe_not_equal, | ||||
| 	space | ||||
| } from "svelte/internal"; | ||||
| 
 | ||||
| function create_fragment(ctx) { | ||||
| 	let input0; | ||||
| 	let t; | ||||
| 	let input1; | ||||
| 	let dispose; | ||||
| 
 | ||||
| 	return { | ||||
| 		c() { | ||||
| 			input0 = element("input"); | ||||
| 			t = space(); | ||||
| 			input1 = element("input"); | ||||
| 			attr(input0, "type", "file"); | ||||
| 			attr(input1, "type", "file"); | ||||
| 
 | ||||
| 			dispose = [ | ||||
| 				listen(input0, "change", ctx.input0_change_handler), | ||||
| 				listen(input1, "change", ctx.input1_change_handler) | ||||
| 			]; | ||||
| 		}, | ||||
| 		m(target, anchor) { | ||||
| 			insert(target, input0, anchor); | ||||
| 			insert(target, t, anchor); | ||||
| 			insert(target, input1, anchor); | ||||
| 		}, | ||||
| 		p: noop, | ||||
| 		i: noop, | ||||
| 		o: noop, | ||||
| 		d(detaching) { | ||||
| 			if (detaching) detach(input0); | ||||
| 			if (detaching) detach(t); | ||||
| 			if (detaching) detach(input1); | ||||
| 			run_all(dispose); | ||||
| 		} | ||||
| 	}; | ||||
| } | ||||
| 
 | ||||
| function instance($$self, $$props, $$invalidate) { | ||||
| 	let { files } = $$props; | ||||
| 
 | ||||
| 	function input0_change_handler() { | ||||
| 		files = this.files; | ||||
| 		$$invalidate("files", files); | ||||
| 	} | ||||
| 
 | ||||
| 	function input1_change_handler() { | ||||
| 		files = this.files; | ||||
| 		$$invalidate("files", files); | ||||
| 	} | ||||
| 
 | ||||
| 	$$self.$set = $$props => { | ||||
| 		if ("files" in $$props) $$invalidate("files", files = $$props.files); | ||||
| 	}; | ||||
| 
 | ||||
| 	return { | ||||
| 		files, | ||||
| 		input0_change_handler, | ||||
| 		input1_change_handler | ||||
| 	}; | ||||
| } | ||||
| 
 | ||||
| class Component extends SvelteComponent { | ||||
| 	constructor(options) { | ||||
| 		super(); | ||||
| 		init(this, options, instance, create_fragment, safe_not_equal, { files: 0 }); | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| export default Component; | ||||
| @ -0,0 +1,6 @@ | ||||
| <script> | ||||
| 	export let files; | ||||
| </script> | ||||
| 
 | ||||
| <input type="file" bind:files> | ||||
| <input bind:files type="file"> | ||||
					Loading…
					
					
				
		Reference in new issue