From 9084747e307dc9b415ff8e2a788c6a585a2a8f6c Mon Sep 17 00:00:00 2001 From: Piotr Kaminski Date: Tue, 13 Mar 2018 08:09:49 -0700 Subject: [PATCH] fix(core): Make set/delete warning condition for undefined, null and (#7818) primitive values more precise. Corrects #7452 --- src/core/observer/index.js | 12 ++++++------ test/unit/modules/observer/observer.spec.js | 4 ++-- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/src/core/observer/index.js b/src/core/observer/index.js index 49d28a291d..4a030ed7f9 100644 --- a/src/core/observer/index.js +++ b/src/core/observer/index.js @@ -10,6 +10,8 @@ import { hasProto, isObject, isPlainObject, + isPrimitive, + isUndef, isValidArrayIndex, isServerRendering } from '../util/index' @@ -195,10 +197,9 @@ export function defineReactive ( */ export function set (target: Array | Object, key: any, val: any): any { if (process.env.NODE_ENV !== 'production' && - !Array.isArray(target) && - !isObject(target) + (isUndef(target) || isPrimitive(target)) ) { - warn(`Cannot set reactive property on non-object/array value: ${target}`) + warn(`Cannot set reactive property on undefined, null, or primitive value: ${(target: any)}`) } if (Array.isArray(target) && isValidArrayIndex(key)) { target.length = Math.max(target.length, key) @@ -231,10 +232,9 @@ export function set (target: Array | Object, key: any, val: any): any { */ export function del (target: Array | Object, key: any) { if (process.env.NODE_ENV !== 'production' && - !Array.isArray(target) && - !isObject(target) + (isUndef(target) || isPrimitive(target)) ) { - warn(`Cannot delete reactive property on non-object/array value: ${target}`) + warn(`Cannot delete reactive property on undefined, null, or primitive value: ${(target: any)}`) } if (Array.isArray(target) && isValidArrayIndex(key)) { target.splice(key, 1) diff --git a/test/unit/modules/observer/observer.spec.js b/test/unit/modules/observer/observer.spec.js index 2002682328..5f075bccc9 100644 --- a/test/unit/modules/observer/observer.spec.js +++ b/test/unit/modules/observer/observer.spec.js @@ -360,12 +360,12 @@ describe('Observer', () => { try { setProp(null, 'foo', 1) } catch (e) {} - expect(`Cannot set reactive property on non-object/array value`).toHaveBeenWarned() + expect(`Cannot set reactive property on undefined, null, or primitive value`).toHaveBeenWarned() try { delProp(null, 'foo') } catch (e) {} - expect(`Cannot delete reactive property on non-object/array value`).toHaveBeenWarned() + expect(`Cannot delete reactive property on undefined, null, or primitive value`).toHaveBeenWarned() }) it('should lazy invoke existing getters', () => {