diff --git a/src/core/instance/state.js b/src/core/instance/state.js index 8469749349..36a8d3fb11 100644 --- a/src/core/instance/state.js +++ b/src/core/instance/state.js @@ -21,8 +21,6 @@ import { noop } from '../util/index' -import BuiltinVue from '../index' - export function initState (vm: Component) { vm._watchers = [] initProps(vm) @@ -145,16 +143,12 @@ function initMethods (vm: Component) { if (methods) { for (const key in methods) { vm[key] = methods[key] == null ? noop : bind(methods[key], vm) - if (process.env.NODE_ENV !== 'production') { - methods[key] == null && warn( + if (process.env.NODE_ENV !== 'production' && methods[key] == null) { + warn( `method "${key}" has an undefined value in the component definition. ` + `Did you reference the function correctly?`, vm ) - hasOwn(BuiltinVue.prototype, key) && warn( - `Avoid overriding Vue's internal method "${key}".`, - vm - ) } } } diff --git a/test/unit/features/options/methods.spec.js b/test/unit/features/options/methods.spec.js index d9c54a8590..3e6991144b 100644 --- a/test/unit/features/options/methods.spec.js +++ b/test/unit/features/options/methods.spec.js @@ -24,14 +24,4 @@ describe('Options methods', () => { }) expect(`method "hello" has an undefined value in the component definition`).toHaveBeenWarned() }) - - it('should warn overriding builtin methods', () => { - new Vue({ - methods: { - $emit () { - } - } - }) - expect(`Avoid overriding Vue's internal method "$emit".`).toHaveBeenWarned() - }) })