fix(v-model): fix case where .trim and .number modifiers are used together (#5842)

fix #5839
This commit is contained in:
小刘(liulinboyi) 2022-05-13 07:52:16 +08:00 committed by GitHub
parent a3881299e9
commit 71066b5afe
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 60 additions and 3 deletions

View File

@ -355,6 +355,37 @@ describe('component: emit', () => {
expect(fn2).toHaveBeenCalledWith('two') expect(fn2).toHaveBeenCalledWith('two')
}) })
test('.trim and .number modifiers should work with v-model on component', () => {
const Foo = defineComponent({
render() {},
created() {
this.$emit('update:modelValue', ' +01.2 ')
this.$emit('update:foo', ' 1 ')
}
})
const fn1 = jest.fn()
const fn2 = jest.fn()
const Comp = () =>
h(Foo, {
modelValue: null,
modelModifiers: { trim: true, number: true },
'onUpdate:modelValue': fn1,
foo: null,
fooModifiers: { trim: true, number: true },
'onUpdate:foo': fn2
})
render(h(Comp), nodeOps.createElement('div'))
expect(fn1).toHaveBeenCalledTimes(1)
expect(fn1).toHaveBeenCalledWith(1.2)
expect(fn2).toHaveBeenCalledTimes(1)
expect(fn2).toHaveBeenCalledWith(1)
})
test('isEmitListener', () => { test('isEmitListener', () => {
const options = { const options = {
click: null, click: null,

View File

@ -122,7 +122,8 @@ export function emit(
const { number, trim } = props[modifiersKey] || EMPTY_OBJ const { number, trim } = props[modifiersKey] || EMPTY_OBJ
if (trim) { if (trim) {
args = rawArgs.map(a => a.trim()) args = rawArgs.map(a => a.trim())
} else if (number) { }
if (number) {
args = rawArgs.map(toNumber) args = rawArgs.map(toNumber)
} }
} }

View File

@ -201,7 +201,7 @@ describe('vModel', () => {
it('should support modifiers', async () => { it('should support modifiers', async () => {
const component = defineComponent({ const component = defineComponent({
data() { data() {
return { number: null, trim: null, lazy: null } return { number: null, trim: null, lazy: null, trimNumber: null }
}, },
render() { render() {
return [ return [
@ -229,6 +229,19 @@ describe('vModel', () => {
trim: true trim: true
} }
), ),
withVModel(
h('input', {
class: 'trim-number',
'onUpdate:modelValue': (val: any) => {
this.trimNumber = val
}
}),
this.trimNumber,
{
trim: true,
number: true
}
),
withVModel( withVModel(
h('input', { h('input', {
class: 'lazy', class: 'lazy',
@ -248,6 +261,7 @@ describe('vModel', () => {
const number = root.querySelector('.number') const number = root.querySelector('.number')
const trim = root.querySelector('.trim') const trim = root.querySelector('.trim')
const trimNumber = root.querySelector('.trim-number')
const lazy = root.querySelector('.lazy') const lazy = root.querySelector('.lazy')
const data = root._vnode.component.data const data = root._vnode.component.data
@ -261,6 +275,16 @@ describe('vModel', () => {
await nextTick() await nextTick()
expect(data.trim).toEqual('hello, world') 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' lazy.value = 'foo'
triggerEvent('change', lazy) triggerEvent('change', lazy)
await nextTick() await nextTick()

View File

@ -52,7 +52,8 @@ export const vModelText: ModelDirective<
let domValue: string | number = el.value let domValue: string | number = el.value
if (trim) { if (trim) {
domValue = domValue.trim() domValue = domValue.trim()
} else if (castToNumber) { }
if (castToNumber) {
domValue = toNumber(domValue) domValue = toNumber(domValue)
} }
el._assign(domValue) el._assign(domValue)