fix(v-model): fix case where .trim and .number modifiers are used together (#5842)
fix #5839
This commit is contained in:
@@ -201,7 +201,7 @@ describe('vModel', () => {
|
||||
it('should support modifiers', async () => {
|
||||
const component = defineComponent({
|
||||
data() {
|
||||
return { number: null, trim: null, lazy: null }
|
||||
return { number: null, trim: null, lazy: null, trimNumber: null }
|
||||
},
|
||||
render() {
|
||||
return [
|
||||
@@ -229,6 +229,19 @@ describe('vModel', () => {
|
||||
trim: true
|
||||
}
|
||||
),
|
||||
withVModel(
|
||||
h('input', {
|
||||
class: 'trim-number',
|
||||
'onUpdate:modelValue': (val: any) => {
|
||||
this.trimNumber = val
|
||||
}
|
||||
}),
|
||||
this.trimNumber,
|
||||
{
|
||||
trim: true,
|
||||
number: true
|
||||
}
|
||||
),
|
||||
withVModel(
|
||||
h('input', {
|
||||
class: 'lazy',
|
||||
@@ -248,6 +261,7 @@ describe('vModel', () => {
|
||||
|
||||
const number = root.querySelector('.number')
|
||||
const trim = root.querySelector('.trim')
|
||||
const trimNumber = root.querySelector('.trim-number')
|
||||
const lazy = root.querySelector('.lazy')
|
||||
const data = root._vnode.component.data
|
||||
|
||||
@@ -261,6 +275,16 @@ describe('vModel', () => {
|
||||
await nextTick()
|
||||
expect(data.trim).toEqual('hello, world')
|
||||
|
||||
trimNumber.value = ' 1 '
|
||||
triggerEvent('input', trimNumber)
|
||||
await nextTick()
|
||||
expect(data.trimNumber).toEqual(1)
|
||||
|
||||
trimNumber.value = ' +01.2 '
|
||||
triggerEvent('input', trimNumber)
|
||||
await nextTick()
|
||||
expect(data.trimNumber).toEqual(1.2)
|
||||
|
||||
lazy.value = 'foo'
|
||||
triggerEvent('change', lazy)
|
||||
await nextTick()
|
||||
|
||||
Reference in New Issue
Block a user