Skip to content
This repository has been archived by the owner on Dec 31, 2024. It is now read-only.

Commit

Permalink
🐛 bug(directive): fix cannot unbind bug
Browse files Browse the repository at this point in the history
closes #377
  • Loading branch information
kazupon committed Jun 18, 2018
1 parent f935a97 commit 105888d
Show file tree
Hide file tree
Showing 3 changed files with 58 additions and 3 deletions.
10 changes: 10 additions & 0 deletions src/directive.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,16 @@ export function update (el: any, binding: Object, vnode: any, oldVNode: any): vo
t(el, binding, vnode)
}

export function unbind (el: any, binding: Object, vnode: any, oldVNode: any): void {
if (!assert(el, vnode)) { return }

el.textContent = ''
el._vt = undefined
delete el['_vt']
el._locale = undefined
delete el['_locale']
}

function assert (el: any, vnode: any): boolean {
const vm: any = vnode.context
if (!vm) {
Expand Down
4 changes: 2 additions & 2 deletions src/install.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { warn } from './util'
import extend from './extend'
import mixin from './mixin'
import component from './component'
import { bind, update } from './directive'
import { bind, update, unbind } from './directive'

export let Vue

Expand All @@ -29,7 +29,7 @@ export function install (_Vue) {

extend(Vue)
Vue.mixin(mixin)
Vue.directive('t', { bind, update })
Vue.directive('t', { bind, update, unbind })
Vue.component(component.name, component)

// use object-based merge strategy
Expand Down
47 changes: 46 additions & 1 deletion test/unit/issues.test.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import messages from './fixture/index'
import { parse } from '../../src/format'
const compiler = require('vue-template-compiler')

describe('issues', () => {
let vm, i18n
Expand Down Expand Up @@ -287,7 +288,7 @@ describe('issues', () => {
})

describe('#259', () => {
it('this points to the right', (done) => {
it('this points to the right', done => {
const vm = new Vue({
i18n: new VueI18n({
locale: 'en',
Expand All @@ -314,4 +315,48 @@ describe('issues', () => {
done()
})
})

describe('#377', () => {
it('should be destroyed', done => {
const el = document.createElement('div')
const template = `<div id="app">
<p>TIMEOUT : {{ timeout }}</p>
<div ref="el1" v-if="!timeout">
<span v-t="'SHOULD_NOT_DISPLAY_WHEN_TIMEOUT_EQUAL_TRUE'"></span>
</div>
<div ref="el2" v-if="timeout">
<span class="">{{ $t('CANNOT_REPRODUCE_WITHOUT_THIS') }}</span>
</div>
</div>`
const { render, staticRenderFns } = compiler.compileToFunctions(template)
const vm = new Vue({
i18n: new VueI18n({ locale: 'id' }),
data () {
return { timeout: false }
},
methods: {
startLoading: function () {
this.timeout = true
setTimeout(() => {
this.timeout = false
}, 100)
}
},
render,
staticRenderFns
}).$mount(el)

Vue.nextTick(() => {
assert.equal(vm.$refs.el1.outerHTML, '<div><span>SHOULD_NOT_DISPLAY_WHEN_TIMEOUT_EQUAL_TRUE</span></div>')
vm.startLoading()
delay(50).then(() => {
assert.equal(vm.$refs.el2.outerHTML, '<div><span>CANNOT_REPRODUCE_WITHOUT_THIS</span></div>')
delay(60).then(() => {
assert.equal(vm.$refs.el1.outerHTML, '<div><span>SHOULD_NOT_DISPLAY_WHEN_TIMEOUT_EQUAL_TRUE</span></div>')
done()
})
})
})
})
})
})

0 comments on commit 105888d

Please sign in to comment.