-
-
Notifications
You must be signed in to change notification settings - Fork 107
/
Copy pathtemplateRef.spec.ts
97 lines (88 loc) · 2.04 KB
/
templateRef.spec.ts
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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
import type { NodeRef } from 'packages/runtime-vapor/src/dom/templateRef'
import {
createIf,
nextTick,
ref,
renderEffect,
setRef,
template,
} from '../../src'
import { makeRender } from '../_utils'
const define = makeRender()
describe('api: template ref', () => {
test('string ref mount', () => {
const t0 = template('<div ref="refKey"></div>')
const el = ref(null)
const { render } = define({
setup() {
return {
refKey: el,
}
},
render() {
const n0 = t0()
setRef(n0 as Element, 'refKey')
return n0
},
})
const { host } = render()
expect(el.value).toBe(host.children[0])
})
it('string ref update', async () => {
const t0 = template('<div></div>')
const fooEl = ref(null)
const barEl = ref(null)
const refKey = ref('foo')
const { render } = define({
setup() {
return {
foo: fooEl,
bar: barEl,
}
},
render() {
const n0 = t0()
let r0: NodeRef | undefined
renderEffect(() => {
r0 = setRef(n0 as Element, refKey.value, r0)
})
return n0
},
})
const { host } = render()
expect(fooEl.value).toBe(host.children[0])
expect(barEl.value).toBe(null)
refKey.value = 'bar'
await nextTick()
expect(barEl.value).toBe(host.children[0])
expect(fooEl.value).toBe(null)
})
it('string ref unmount', async () => {
const t0 = template('<div></div>')
const el = ref(null)
const toggle = ref(true)
const { render } = define({
setup() {
return {
refKey: el,
}
},
render() {
const n0 = createIf(
() => toggle.value,
() => {
const n1 = t0()
setRef(n1 as Element, 'refKey')
return n1
},
)
return n0
},
})
const { host } = render()
expect(el.value).toBe(host.children[0])
toggle.value = false
await nextTick()
expect(el.value).toBe(null)
})
})