Explorar el Código

fix #4041, warn overriding Vue's internal methods (#4111)

* fix #4041, warn overriding Vue's internal methods

* prefer concise warning message
(´・ω・`) hace 9 años
padre
commit
4078ce9c58
Se han modificado 2 ficheros con 18 adiciones y 2 borrados
  1. 8 2
      src/core/instance/state.js
  2. 10 0
      test/unit/features/options/methods.spec.js

+ 8 - 2
src/core/instance/state.js

@@ -21,6 +21,8 @@ import {
   noop
 } from '../util/index'
 
+import BuiltinVue from '../index'
+
 export function initState (vm: Component) {
   vm._watchers = []
   initProps(vm)
@@ -143,12 +145,16 @@ 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
+        )
       }
     }
   }

+ 10 - 0
test/unit/features/options/methods.spec.js

@@ -24,4 +24,14 @@ 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()
+  })
 })