[bugfix] Popup: may cause event uncancelable warning (#3150)

This commit is contained in:
neverland 2019-04-15 17:10:39 +08:00 committed by GitHub
parent 0e45d05ce2
commit ae73af819d
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 18 additions and 8 deletions

View File

@ -160,10 +160,10 @@ export const PopupMixin = {
}
},
onTouchMove(e) {
this.touchMove(e);
onTouchMove(event) {
this.touchMove(event);
const direction = this.deltaY > 0 ? '10' : '01';
const el = getScrollEventTarget(e.target, this.$el);
const el = getScrollEventTarget(event.target, this.$el);
const { scrollHeight, offsetHeight, scrollTop } = el;
let status = '11';
@ -176,12 +176,13 @@ export const PopupMixin = {
/* istanbul ignore next */
if (
event.cancelable &&
status !== '11' &&
this.direction === 'vertical' &&
!(parseInt(status, 2) & parseInt(direction, 2))
) {
e.preventDefault();
e.stopPropagation();
event.preventDefault();
event.stopPropagation();
}
},

View File

@ -46,7 +46,16 @@ function Rate(
slots: DefaultSlots,
ctx: RenderContext<RateProps>
) {
const { size, icon, voidIcon, color, voidColor, disabled, disabledColor } = props;
const {
icon,
size,
color,
voidIcon,
readonly,
disabled,
voidColor,
disabledColor
} = props;
const list: RateStatus[] = [];
for (let i = 1; i <= props.count; i++) {
@ -54,14 +63,14 @@ function Rate(
}
function onSelect(index: number) {
if (!disabled && !props.readonly) {
if (!disabled && !readonly) {
emit(ctx, 'input', index);
emit(ctx, 'change', index);
}
}
function onTouchMove(event: TouchEvent) {
if (!document.elementFromPoint || props.readonly || props.disabled) {
if (readonly || disabled || !document.elementFromPoint) {
return;
}