From 789975a92a831ba08d67e341adcac8b2154b341e Mon Sep 17 00:00:00 2001 From: Soo Jae Hwang Date: Fri, 3 Nov 2017 06:09:29 +0900 Subject: [PATCH] fix(v-model): v-if / v-else not working with :type + v-model (#6955) fix #6918 --- src/platforms/web/compiler/modules/model.js | 9 ++++ .../features/directives/model-dynamic.spec.js | 42 +++++++++++++++++++ 2 files changed, 51 insertions(+) diff --git a/src/platforms/web/compiler/modules/model.js b/src/platforms/web/compiler/modules/model.js index 61657d1fa4..5e882d7254 100644 --- a/src/platforms/web/compiler/modules/model.js +++ b/src/platforms/web/compiler/modules/model.js @@ -29,6 +29,8 @@ function preTransformNode (el: ASTElement, options: CompilerOptions) { const typeBinding: any = getBindingAttr(el, 'type') const ifCondition = getAndRemoveAttr(el, 'v-if', true) const ifConditionExtra = ifCondition ? `&&(${ifCondition})` : `` + const hasElse = getAndRemoveAttr(el, 'v-else', true) != null + const elseIfCondition = getAndRemoveAttr(el, 'v-else-if', true) // 1. checkbox const branch0 = cloneASTElement(el) // process for on the main node @@ -59,6 +61,13 @@ function preTransformNode (el: ASTElement, options: CompilerOptions) { exp: ifCondition, block: branch2 }) + + if (hasElse) { + branch0.else = true + } else if (elseIfCondition) { + branch0.elseif = elseIfCondition + } + return branch0 } } diff --git a/test/unit/features/directives/model-dynamic.spec.js b/test/unit/features/directives/model-dynamic.spec.js index eb193f19bd..a5c18fe82b 100644 --- a/test/unit/features/directives/model-dynamic.spec.js +++ b/test/unit/features/directives/model-dynamic.spec.js @@ -40,6 +40,48 @@ describe('Directive v-model dynamic input type', () => { assertInputWorks(vm, chain).then(done) }) + it('with v-else', done => { + const data = { + ok: true, + type: null, + test: 'b' + } + const vm = new Vue({ + data, + template: `
haha
` + }).$mount() + document.body.appendChild(vm.$el) + expect(vm.$el.textContent).toBe('haha') + + vm.ok = false + assertInputWorks(vm).then(done) + }) + + it('with v-else-if', done => { + const vm = new Vue({ + data: { + foo: true, + bar: false, + type: null, + test: 'b' + }, + template: `
text
` + }).$mount() + document.body.appendChild(vm.$el) + + const chain = waitForUpdate(() => { + expect(vm.$el.textContent).toBe('text') + }).then(() => { + vm.foo = false + }).then(() => { + expect(vm._vnode.isComment).toBe(true) + }).then(() => { + vm.bar = true + }) + + assertInputWorks(vm, chain).then(done) + }) + it('with v-for', done => { const vm = new Vue({ data: {