diff --git a/src/core/vdom/patch.js b/src/core/vdom/patch.js index b5296db3c9..00c67a5b10 100644 --- a/src/core/vdom/patch.js +++ b/src/core/vdom/patch.js @@ -270,7 +270,7 @@ export function createPatchFunction (backend) { createElm(children[i], insertedVnodeQueue, vnode.elm, null, true) } } else if (isPrimitive(vnode.text)) { - nodeOps.appendChild(vnode.elm, nodeOps.createTextNode(vnode.text)) + nodeOps.appendChild(vnode.elm, nodeOps.createTextNode(String(vnode.text))) } } diff --git a/src/shared/util.js b/src/shared/util.js index fe1c025e49..a0bc957ee9 100644 --- a/src/shared/util.js +++ b/src/shared/util.js @@ -27,6 +27,8 @@ export function isPrimitive (value: any): boolean %checks { return ( typeof value === 'string' || typeof value === 'number' || + // $flow-disable-line + typeof value === 'symbol' || typeof value === 'boolean' ) } diff --git a/test/unit/modules/vdom/create-element.spec.js b/test/unit/modules/vdom/create-element.spec.js index 3bec065f31..f2fddcf6d1 100644 --- a/test/unit/modules/vdom/create-element.spec.js +++ b/test/unit/modules/vdom/create-element.spec.js @@ -215,6 +215,15 @@ describe('create-element', () => { expect('Avoid using non-primitive value as key').not.toHaveBeenWarned() }) + it('doesn\'t warn symbol key', () => { + new Vue({ + render (h) { + return h('div', { key: Symbol('symbol') }) + } + }).$mount() + expect('Avoid using non-primitive value as key').not.toHaveBeenWarned() + }) + it('nested child elements should be updated correctly', done => { const vm = new Vue({ data: { n: 1 },