fix(runtime-core): bind default function of inject to instance (#3925)

fix #3923
This commit is contained in:
Eunjae Lee 2021-06-09 18:02:05 +02:00 committed by GitHub
parent bc100c5c48
commit db1dc1c630
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 31 additions and 2 deletions

View File

@ -7,7 +7,8 @@ import {
nextTick,
Ref,
readonly,
reactive
reactive,
defineComponent
} from '../src/index'
import { render, nodeOps, serialize } from '@vue/runtime-test'
@ -91,6 +92,34 @@ describe('api: provide/inject', () => {
expect(serialize(root)).toBe(`<div>foobar</div>`)
})
it('bound to instance', () => {
const Provider = {
setup() {
return () => h(Consumer)
}
}
const Consumer = defineComponent({
name: 'Consumer',
inject: {
foo: {
from: 'foo',
default() {
return this!.$options.name
}
}
},
render() {
// @ts-ignore
return this.foo
}
})
const root = nodeOps.createElement('div')
render(h(Provider), root)
expect(serialize(root)).toBe(`<div>Consumer</div>`)
})
it('nested providers', () => {
const ProviderOne = {
setup() {

View File

@ -60,7 +60,7 @@ export function inject(
return provides[key as string]
} else if (arguments.length > 1) {
return treatDefaultAsFactory && isFunction(defaultValue)
? defaultValue()
? defaultValue.call(instance.proxy)
: defaultValue
} else if (__DEV__) {
warn(`injection "${String(key)}" not found.`)