mirror of
https://gitee.com/vant-contrib/vant.git
synced 2025-04-06 03:57:59 +08:00
breaking change(Checkbox): need @click.stop inside a cell #7023
This commit is contained in:
parent
839b8654ee
commit
c0ea21dcd3
@ -172,6 +172,10 @@ Vue 3.0 中增加了 `Teleport` 组件,提供将组件渲染到任意 DOM 位
|
||||
- 绿色按钮对应的类型由 `primary` 调整为 `success`
|
||||
- `native-type` 的默认值由 `submit` 调整为 `button`
|
||||
|
||||
#### Checkbox
|
||||
|
||||
- 在 Cell 内部使用时,现在需要手动添加 `@click.stop` 来阻止事件冒泡
|
||||
|
||||
#### Dialog
|
||||
|
||||
- 默认关闭 `allow-html` 属性
|
||||
|
@ -64,15 +64,8 @@ export default defineComponent({
|
||||
|
||||
if (!disabled.value && (iconClicked || !props.labelDisabled)) {
|
||||
emit('toggle');
|
||||
|
||||
// wait for toggle method to complete
|
||||
// so we can get the changed value in the click event listener
|
||||
setTimeout(() => {
|
||||
emit('click', event);
|
||||
});
|
||||
} else {
|
||||
emit('click', event);
|
||||
}
|
||||
emit('click', event);
|
||||
};
|
||||
|
||||
const renderIcon = () => {
|
||||
|
@ -184,7 +184,11 @@ export default {
|
||||
@click="toggle(index)"
|
||||
>
|
||||
<template #right-icon>
|
||||
<van-checkbox :name="item" :ref="el => checkboxes[index] = el" />
|
||||
<van-checkbox
|
||||
:name="item"
|
||||
:ref="el => checkboxes[index] = el"
|
||||
@click.stop
|
||||
/>
|
||||
</template>
|
||||
</van-cell>
|
||||
</van-cell-group>
|
||||
|
@ -204,7 +204,11 @@ export default {
|
||||
@click="toggle(index)"
|
||||
>
|
||||
<template #right-icon>
|
||||
<van-checkbox :name="item" :ref="el => checkboxes[index] = el" />
|
||||
<van-checkbox
|
||||
:name="item"
|
||||
:ref="el => checkboxes[index] = el"
|
||||
@click.stop
|
||||
/>
|
||||
</template>
|
||||
</van-cell>
|
||||
</van-cell-group>
|
||||
|
@ -96,7 +96,7 @@
|
||||
@click="toggle(index)"
|
||||
>
|
||||
<template #right-icon>
|
||||
<van-checkbox :ref="setRefs(index)" :name="item" />
|
||||
<van-checkbox :ref="setRefs(index)" :name="item" @click.stop />
|
||||
</template>
|
||||
</van-cell>
|
||||
</van-cell-group>
|
||||
|
@ -62,15 +62,8 @@ export default createComponent({
|
||||
},
|
||||
});
|
||||
|
||||
let toggleTimer;
|
||||
const toggle = (newValue = !checked.value) => {
|
||||
// When toggle method is called multiple times at the same time,
|
||||
// only the last call is valid.
|
||||
// This is a hack for usage inside Cell.
|
||||
clearTimeout(toggleTimer);
|
||||
toggleTimer = setTimeout(() => {
|
||||
checked.value = newValue;
|
||||
});
|
||||
checked.value = newValue;
|
||||
};
|
||||
|
||||
watch(
|
||||
|
Loading…
x
Reference in New Issue
Block a user