即 mount
和 shallowMount
的选项。该对象同时包含了 Vue Test Utils 挂载选项和其它选项。
context
slots
scopedSlots
stubs
mocks
localVue
attachToDocument
propsData
attrs
listeners
parentComponent
provide
sync
- 类型:
Object
将上下文传递给函数式组件。该选项只能用于函数式组件。
示例:
import Foo from './Foo.vue'
import Bar from './Bar.vue'
const wrapper = mount(Component, {
context: {
props: { show: true },
children: [Foo, Bar]
}
})
expect(wrapper.is(Component)).toBe(true)
- 类型:
{ [name: string]: Array<Component>|Component|string }
为组件提供一个 slot 内容的对象。该对象中的键名就是相应的 slot 名,键值可以是一个组件、一个组件数组、一个字符串模板或文本。
示例:
import Foo from './Foo.vue'
const bazComponent = {
name: 'baz-component',
template: '<p>baz</p>'
}
const wrapper = shallowMount(Component, {
slots: {
default: [Foo, '<my-component />', 'text'],
fooBar: Foo, // 将会匹配 `<slot name="FooBar" />`.
foo: '<div />',
bar: 'bar',
baz: bazComponent,
qux: '<my-component />'
}
})
expect(wrapper.find('div')).toBe(true)
- 类型:
{ [name: string]: string|Function }
提供一个该组件所有作用域插槽的对象。每个键对应到插槽的名字。
你可以使用 slot-scope 特性设置 prop 的名称:
shallowMount(Component, {
scopedSlots: {
foo: '<p slot-scope="foo">{{foo.index}},{{foo.text}}</p>'
}
})
否则插槽被计算的时候可以通过 props
对象使用 prop:
shallowMount(Component, {
scopedSlots: {
default: '<p>{{props.index}},{{props.text}}</p>'
}
})
你也可以传递一个函数将 prop 作为参数带入:
shallowMount(Component, {
scopedSlots: {
foo: function (props) {
return this.$createElement('div', props.index)
}
}
})
或者你可以使用 JSX。如果你在一个方法里撰写 JSX,babel-plugin-transform-vue-jsx 会自动注入 this.$createElement
:
shallowMount(Component, {
scopedSlots: {
foo (props) {
return <div>{ props.text }</div>
}
}
})
- 类型:
{ [name: string]: Component | boolean } | Array<string>
将子组件存根。可以是一个要存根的组件名的数组或对象。如果 stubs
是一个数组,则每个存根都是一个 <${component name}-stub>
。
示例:
import Foo from './Foo.vue'
mount(Component, {
stubs: ['registered-component']
})
shallowMount(Component, {
stubs: {
// 使用一个特定的实现作为存根
'registered-component': Foo,
// 使用创建默认的实现作为存根。
// 这里默认存根的组件名是 `another-component`。
// 默认存根是 `<${the component name of default stub}-stub>`。
'another-component': true
}
})
- 类型:
Object
为实例添加额外的属性。在伪造全局注入的时候有用。
示例:
const $route = { path: 'http://www.example-path.com' }
const wrapper = shallowMount(Component, {
mocks: {
$route
}
})
expect(wrapper.vm.$route.path).toBe($route.path)
- 类型:
Vue
通过 [./createLocalVue.md
] 创建的一个 Vue
的本地拷贝,用于挂载该组件的时候。在这份拷贝上安装插件可以防止原始的 Vue
被污染。
示例:
import { createLocalVue, mount } from '@vue/test-utils'
import VueRouter from 'vue-router'
import Foo from './Foo.vue'
const localVue = createLocalVue()
localVue.use(VueRouter)
const routes = [
{ path: '/foo', component: Foo }
]
const router = new VueRouter({
routes
})
const wrapper = mount(Component, {
localVue,
router
})
expect(wrapper.vm.$route).toBeInstanceOf(Object)
- 类型:
boolean
- 默认值:
false
当设为 true
时,组件在渲染时将会挂载到 DOM 上。
- 类型:
Object
设置组件实例的 $attrs
对象。
- 类型:
Object
在组件被挂载时设置组件实例的 prop。
示例:
const Component = {
template: '<div>{{ msg }}</div>',
props: ['msg']
}
const wrapper = mount(Component, {
propsData: {
msg: 'aBC'
}
})
expect(wrapper.text()).toBe('aBC')
::: tip 提示
值得注意的是 propsData
实际上是一个 Vue API,不是 Vue Test Utils 的挂载选项。它会被 extends
处理。请查阅其它选项。
:::
- 类型:
Object
设置组件实例的 $listeners
对象。
- 类型:
Object
用来作为被挂载组件的父级组件。
示例:
import Foo from './Foo.vue'
const wrapper = shallowMount(Component, {
parentComponent: Foo
})
expect(wrapper.vm.$parent.$options.name).toBe('foo')
- 类型:
Object
为组件传递用于注入的属性。可查阅 provie/inject 了解更多。
示例:
const Component = {
inject: ['foo'],
template: '<div>{{this.foo()}}</div>'
}
const wrapper = shallowMount(Component, {
provide: {
foo () {
return 'fooValue'
}
}
})
expect(wrapper.text()).toBe('fooValue')
- 类型:
boolean
- 默认值:
true
当 sync
是 true
时,这个 Vue 组件会被同步渲染。
当 sync
是 false
时,这个 Vue 组件会被异步渲染。
当 mount
和 shallowMount
的选项包含了挂载选项之外的选项时,则会将它们通过扩展覆写到其组件选项。
const Component = {
template: '<div>{{ foo() }}{{ bar() }}{{ baz() }}</div>',
methods: {
foo () {
return 'a'
},
bar () {
return 'b'
}
}
}
const options = {
methods: {
bar () {
return 'B'
},
baz () {
return 'C'
}
}
}
const wrapper = mount(Component, options)
expect(wrapper.text()).toBe('aBC')