12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- import { haveText, html, test } from '../../utils'
- test('can reference elements from event listeners',
- html`
- <div x-data="{}">
- <button x-on:click="$refs['bob'].textContent = 'lob'"></button>
- <span x-ref="bob"></span>
- </div>
- `,
- ({ get }) => {
- get('button').click()
- get('span').should(haveText('lob'))
- }
- )
- test('can reference elements from data object methods',
- html`
- <div x-data="{ foo() { this.$refs.bob.textContent = 'lob' } }">
- <button x-on:click="foo()"></button>
- <span x-ref="bob"></span>
- </div>
- `,
- ({ get }) => {
- get('button').click()
- get('span').should(haveText('lob'))
- }
- )
- test('can reference elements from x-init',
- html`
- <div x-data x-init="$refs.foo.textContent = 'lob'">
- <span x-ref="foo">bob</span>
- </div>
- `,
- ({ get }) => {
- get('span').should(haveText('lob'))
- }
- )
- test('can reference elements outside of x-init',
- html`
- <div x-data x-ref="foo" data-foo="bar">
- <div x-init="() => {}">
- <span x-text="$refs.foo.dataset.foo"></span>
- </div>
- </div>
- `,
- ({ get }) => {
- get('span').should(haveText('bar'))
- }
- )
- test('can reference refs of parent scope',
- html`
- <div x-data x-ref="foo" data-foo="bar">
- <div x-data>
- <span x-text="$refs.foo.dataset.foo"></span>
- </div>
- </div>
- `,
- ({ get }) => {
- get('span').should(haveText('bar'))
- }
- )
- test('when referencing refs from parent scope, the closest ref is used',
- html`
- <div x-data x-ref="foo" data-foo="bar">
- <div x-data x-ref="foo" data-foo="baz">
- <span x-text="$refs.foo.dataset.foo"></span>
- </div>
- </div>
- `,
- ({ get }) => {
- get('span').should(haveText('baz'))
- }
- )
|