| 
1 | 1 | <script>  | 
2 | 2 | 	import { SvelteMap } from 'svelte/reactivity';  | 
3 | 3 | 
  | 
4 |  | -	let visibleExternal = $state(false);  | 
5 |  | -	let external = new SvelteMap();  | 
6 |  | -	const throws = $derived.by(() => {  | 
7 |  | -		external.set(1, 1);  | 
8 |  | -		return external;  | 
 | 4 | +	let outside_basic = $state(false);  | 
 | 5 | +	let outside_basic_map = new SvelteMap();  | 
 | 6 | +	const throw_basic = $derived.by(() => {  | 
 | 7 | +		outside_basic_map.set(1, 1);  | 
 | 8 | +		return outside_basic_map;  | 
9 | 9 | 	});  | 
10 | 10 | 
  | 
11 |  | -	let visibleInternal = $state(false);  | 
12 |  | -	const works = $derived.by(() => {  | 
13 |  | -		let internal = new SvelteMap();  | 
14 |  | -		internal.set(1, 1);  | 
15 |  | -		return internal;  | 
 | 11 | +	let inside_basic = $state(false);  | 
 | 12 | +	const works_basic = $derived.by(() => {  | 
 | 13 | +		let inside = new SvelteMap();  | 
 | 14 | +		inside.set(1, 1);  | 
 | 15 | +		return inside;  | 
 | 16 | +	});  | 
 | 17 | +
  | 
 | 18 | +	let outside_has = $state(false);  | 
 | 19 | +	let outside_has_map = new SvelteMap([[1, 1]]);  | 
 | 20 | +	const throw_has = $derived.by(() => {  | 
 | 21 | +		outside_has_map.has(1);  | 
 | 22 | +		outside_has_map.set(1, 2);  | 
 | 23 | +		return outside_has_map;  | 
 | 24 | +	});  | 
 | 25 | +
  | 
 | 26 | +	let inside_has = $state(false);  | 
 | 27 | +	const works_has = $derived.by(() => {  | 
 | 28 | +		let inside = new SvelteMap([[1, 1]]);  | 
 | 29 | +		inside.has(1);  | 
 | 30 | +		inside.set(1, 1);  | 
 | 31 | +		return inside;  | 
 | 32 | +	});  | 
 | 33 | +
  | 
 | 34 | +	let outside_get = $state(false);  | 
 | 35 | +	let outside_get_map = new SvelteMap([[1, 1]]);  | 
 | 36 | +	const throw_get = $derived.by(() => {  | 
 | 37 | +		outside_get_map.get(1);  | 
 | 38 | +		outside_get_map.set(1, 2);  | 
 | 39 | +		return outside_get_map;  | 
 | 40 | +	});  | 
 | 41 | +
  | 
 | 42 | +	let inside_get = $state(false);  | 
 | 43 | +	const works_get = $derived.by(() => {  | 
 | 44 | +		let inside = new SvelteMap([[1, 1]]);  | 
 | 45 | +		inside.get(1);  | 
 | 46 | +		inside.set(1, 1);  | 
 | 47 | +		return inside;  | 
 | 48 | +	});  | 
 | 49 | +
  | 
 | 50 | +	let outside_values = $state(false);  | 
 | 51 | +	let outside_values_map = new SvelteMap([[1, 1]]);  | 
 | 52 | +	const throw_values = $derived.by(() => {  | 
 | 53 | +		outside_values_map.values(1);  | 
 | 54 | +		outside_values_map.set(1, 2);  | 
 | 55 | +		return outside_values_map;  | 
 | 56 | +	});  | 
 | 57 | +
  | 
 | 58 | +	let inside_values = $state(false);  | 
 | 59 | +	const works_values = $derived.by(() => {  | 
 | 60 | +		let inside = new SvelteMap([[1, 1]]);  | 
 | 61 | +		inside.values();  | 
 | 62 | +		inside.set(1, 1);  | 
 | 63 | +		return inside;  | 
16 | 64 | 	});  | 
17 | 65 | </script>  | 
18 | 66 | 
 
  | 
19 |  | -<button onclick={() => (visibleExternal = true)}>external</button>  | 
20 |  | -{#if visibleExternal}  | 
21 |  | -	{throws}  | 
 | 67 | +<button onclick={() => (outside_basic = true)}>external</button>  | 
 | 68 | +{#if outside_basic}  | 
 | 69 | +	{throw_basic}  | 
 | 70 | +{/if}  | 
 | 71 | +<button onclick={() => (inside_basic = true)}>internal</button>  | 
 | 72 | +{#if inside_basic}  | 
 | 73 | +	{works_basic}  | 
 | 74 | +{/if}  | 
 | 75 | + | 
 | 76 | +<button onclick={() => (outside_has = true)}>external</button>  | 
 | 77 | +{#if outside_has}  | 
 | 78 | +	{throw_has}  | 
22 | 79 | {/if}  | 
23 |  | -<button onclick={() => (visibleInternal = true)}>internal</button>  | 
24 |  | -{#if visibleInternal}  | 
25 |  | -	{works}  | 
 | 80 | +<button onclick={() => (inside_has = true)}>internal</button>  | 
 | 81 | +{#if inside_has}  | 
 | 82 | +	{works_has}  | 
26 | 83 | {/if}  | 
27 | 84 | 
 
  | 
 | 85 | +<button onclick={() => (outside_get = true)}>external</button>  | 
 | 86 | +{#if outside_get}  | 
 | 87 | +	{throw_get}  | 
 | 88 | +{/if}  | 
 | 89 | +<button onclick={() => (inside_get = true)}>internal</button>  | 
 | 90 | +{#if inside_get}  | 
 | 91 | +	{works_get}  | 
 | 92 | +{/if}  | 
 | 93 | + | 
 | 94 | +<button onclick={() => (outside_values = true)}>external</button>  | 
 | 95 | +{#if outside_values}  | 
 | 96 | +	{throw_values}  | 
 | 97 | +{/if}  | 
 | 98 | +<button onclick={() => (inside_values = true)}>internal</button>  | 
 | 99 | +{#if inside_values}  | 
 | 100 | +	{works_values}  | 
 | 101 | +{/if}  | 
0 commit comments