mirror of
https://gitee.com/vant-contrib/vant-weapp.git
synced 2025-04-06 03:58:05 +08:00
refactor(rect): remove getRect behavior (#3795)
This commit is contained in:
parent
0343307825
commit
9725ec336b
@ -1,3 +1,4 @@
|
|||||||
|
import { getRect } from '../common/utils';
|
||||||
import { VantComponent } from '../common/component';
|
import { VantComponent } from '../common/component';
|
||||||
|
|
||||||
VantComponent({
|
VantComponent({
|
||||||
@ -70,11 +71,9 @@ VantComponent({
|
|||||||
|
|
||||||
updateStyle(expanded: boolean) {
|
updateStyle(expanded: boolean) {
|
||||||
const { inited } = this;
|
const { inited } = this;
|
||||||
this.getRect('.van-collapse-item__content')
|
getRect
|
||||||
.then(
|
.call(this, '.van-collapse-item__content')
|
||||||
(rect: WechatMiniprogram.BoundingClientRectCallbackResult) =>
|
.then((rect) => rect.height)
|
||||||
rect.height
|
|
||||||
)
|
|
||||||
.then((height: number) => {
|
.then((height: number) => {
|
||||||
const { animation } = this;
|
const { animation } = this;
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import { VantComponent } from '../common/component';
|
import { VantComponent } from '../common/component';
|
||||||
import { addUnit } from '../common/utils';
|
import { addUnit, getRect } from '../common/utils';
|
||||||
|
|
||||||
type TrivialInstance = WechatMiniprogram.Component.TrivialInstance;
|
type TrivialInstance = WechatMiniprogram.Component.TrivialInstance;
|
||||||
let ARRAY: TrivialInstance[] = [];
|
let ARRAY: TrivialInstance[] = [];
|
||||||
@ -101,23 +101,20 @@ VantComponent({
|
|||||||
getChildWrapperStyle() {
|
getChildWrapperStyle() {
|
||||||
const { zIndex, direction } = this.data;
|
const { zIndex, direction } = this.data;
|
||||||
|
|
||||||
return this.getRect('.van-dropdown-menu').then(
|
return getRect.call(this, '.van-dropdown-menu').then((rect) => {
|
||||||
(rect: WechatMiniprogram.BoundingClientRectCallbackResult) => {
|
const { top = 0, bottom = 0 } = rect;
|
||||||
const { top = 0, bottom = 0 } = rect;
|
const offset = direction === 'down' ? bottom : this.windowHeight - top;
|
||||||
const offset =
|
|
||||||
direction === 'down' ? bottom : this.windowHeight - top;
|
|
||||||
|
|
||||||
let wrapperStyle = `z-index: ${zIndex};`;
|
let wrapperStyle = `z-index: ${zIndex};`;
|
||||||
|
|
||||||
if (direction === 'down') {
|
if (direction === 'down') {
|
||||||
wrapperStyle += `top: ${addUnit(offset)};`;
|
wrapperStyle += `top: ${addUnit(offset)};`;
|
||||||
} else {
|
} else {
|
||||||
wrapperStyle += `bottom: ${addUnit(offset)};`;
|
wrapperStyle += `bottom: ${addUnit(offset)};`;
|
||||||
}
|
|
||||||
|
|
||||||
return wrapperStyle;
|
|
||||||
}
|
}
|
||||||
);
|
|
||||||
|
return wrapperStyle;
|
||||||
|
});
|
||||||
},
|
},
|
||||||
|
|
||||||
onTitleTap(event: WechatMiniprogram.TouchEvent) {
|
onTitleTap(event: WechatMiniprogram.TouchEvent) {
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
import { getRect } from '../common/utils';
|
||||||
import { VantComponent } from '../common/component';
|
import { VantComponent } from '../common/component';
|
||||||
|
|
||||||
VantComponent({
|
VantComponent({
|
||||||
@ -20,18 +21,12 @@ VantComponent({
|
|||||||
|
|
||||||
methods: {
|
methods: {
|
||||||
scrollIntoView(scrollTop) {
|
scrollIntoView(scrollTop) {
|
||||||
this.getBoundingClientRect().then(
|
getRect.call(this, '.van-index-anchor-wrapper').then((rect) => {
|
||||||
(rect: WechatMiniprogram.BoundingClientRectCallbackResult) => {
|
wx.pageScrollTo({
|
||||||
wx.pageScrollTo({
|
duration: 0,
|
||||||
duration: 0,
|
scrollTop: scrollTop + rect.top - this.parent.data.stickyOffsetTop,
|
||||||
scrollTop: scrollTop + rect.top - this.parent.data.stickyOffsetTop,
|
});
|
||||||
});
|
});
|
||||||
}
|
|
||||||
);
|
|
||||||
},
|
|
||||||
|
|
||||||
getBoundingClientRect() {
|
|
||||||
return this.getRect('.van-index-anchor-wrapper');
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
@ -13,23 +13,5 @@ export const basic = Behavior({
|
|||||||
|
|
||||||
return new Promise((resolve) => wx.nextTick(resolve));
|
return new Promise((resolve) => wx.nextTick(resolve));
|
||||||
},
|
},
|
||||||
|
|
||||||
getRect(selector: string, all: boolean) {
|
|
||||||
return new Promise((resolve) => {
|
|
||||||
wx.createSelectorQuery()
|
|
||||||
.in(this)
|
|
||||||
[all ? 'selectAll' : 'select'](selector)
|
|
||||||
.boundingClientRect((rect) => {
|
|
||||||
if (all && Array.isArray(rect) && rect.length) {
|
|
||||||
resolve(rect);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!all && rect) {
|
|
||||||
resolve(rect);
|
|
||||||
}
|
|
||||||
})
|
|
||||||
.exec();
|
|
||||||
});
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
import { getAllRect } from '../common/utils';
|
||||||
import { VantComponent } from '../common/component';
|
import { VantComponent } from '../common/component';
|
||||||
import { canIUseModel } from '../common/version';
|
import { canIUseModel } from '../common/version';
|
||||||
|
|
||||||
@ -82,19 +83,17 @@ VantComponent({
|
|||||||
|
|
||||||
const { clientX } = event.touches[0];
|
const { clientX } = event.touches[0];
|
||||||
|
|
||||||
this.getRect('.van-rate__icon', true).then(
|
getAllRect.call(this, '.van-rate__icon').then((list) => {
|
||||||
(list: WechatMiniprogram.BoundingClientRectCallbackResult[]) => {
|
const target = list
|
||||||
const target = list
|
.sort((item) => item.right - item.left)
|
||||||
.sort((item) => item.right - item.left)
|
.find((item) => clientX >= item.left && clientX <= item.right);
|
||||||
.find((item) => clientX >= item.left && clientX <= item.right);
|
if (target != null) {
|
||||||
if (target != null) {
|
this.onSelect({
|
||||||
this.onSelect({
|
...event,
|
||||||
...event,
|
currentTarget: target,
|
||||||
currentTarget: target,
|
});
|
||||||
});
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
);
|
});
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import { VantComponent } from '../common/component';
|
import { VantComponent } from '../common/component';
|
||||||
import { touch } from '../mixins/touch';
|
import { touch } from '../mixins/touch';
|
||||||
import { canIUseModel } from '../common/version';
|
import { canIUseModel } from '../common/version';
|
||||||
|
import { getRect } from '../common/utils';
|
||||||
|
|
||||||
VantComponent({
|
VantComponent({
|
||||||
mixins: [touch],
|
mixins: [touch],
|
||||||
@ -60,13 +61,11 @@ VantComponent({
|
|||||||
this.touchMove(event);
|
this.touchMove(event);
|
||||||
this.dragStatus = 'draging';
|
this.dragStatus = 'draging';
|
||||||
|
|
||||||
this.getRect('.van-slider').then(
|
getRect.call(this, '.van-slider').then((rect) => {
|
||||||
(rect: WechatMiniprogram.BoundingClientRectCallbackResult) => {
|
const diff = (this.deltaX / rect.width) * 100;
|
||||||
const diff = (this.deltaX / rect.width) * 100;
|
this.newValue = this.startValue + diff;
|
||||||
this.newValue = this.startValue + diff;
|
this.updateValue(this.newValue, false, true);
|
||||||
this.updateValue(this.newValue, false, true);
|
});
|
||||||
}
|
|
||||||
);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
onTouchEnd() {
|
onTouchEnd() {
|
||||||
@ -83,13 +82,11 @@ VantComponent({
|
|||||||
|
|
||||||
const { min } = this.data;
|
const { min } = this.data;
|
||||||
|
|
||||||
this.getRect('.van-slider').then(
|
getRect.call(this, '.van-slider').then((rect) => {
|
||||||
(rect: WechatMiniprogram.BoundingClientRectCallbackResult) => {
|
const value =
|
||||||
const value =
|
((event.detail.x - rect.left) / rect.width) * this.getRange() + min;
|
||||||
((event.detail.x - rect.left) / rect.width) * this.getRange() + min;
|
this.updateValue(value, true);
|
||||||
this.updateValue(value, true);
|
});
|
||||||
}
|
|
||||||
);
|
|
||||||
},
|
},
|
||||||
|
|
||||||
updateValue(value: number, end: boolean, drag: boolean) {
|
updateValue(value: number, end: boolean, drag: boolean) {
|
||||||
|
@ -1,10 +1,9 @@
|
|||||||
|
import { getRect } from '../common/utils';
|
||||||
import { VantComponent } from '../common/component';
|
import { VantComponent } from '../common/component';
|
||||||
import { pageScrollMixin } from '../mixins/page-scroll';
|
import { pageScrollMixin } from '../mixins/page-scroll';
|
||||||
|
|
||||||
const ROOT_ELEMENT = '.van-sticky';
|
const ROOT_ELEMENT = '.van-sticky';
|
||||||
|
|
||||||
type BoundingClientRect = WechatMiniprogram.BoundingClientRectCallbackResult;
|
|
||||||
|
|
||||||
VantComponent({
|
VantComponent({
|
||||||
props: {
|
props: {
|
||||||
zIndex: {
|
zIndex: {
|
||||||
@ -66,29 +65,30 @@ VantComponent({
|
|||||||
this.scrollTop = scrollTop || this.scrollTop;
|
this.scrollTop = scrollTop || this.scrollTop;
|
||||||
|
|
||||||
if (typeof container === 'function') {
|
if (typeof container === 'function') {
|
||||||
Promise.all([this.getRect(ROOT_ELEMENT), this.getContainerRect()]).then(
|
Promise.all([
|
||||||
([root, container]: BoundingClientRect[]) => {
|
getRect.call(this, ROOT_ELEMENT),
|
||||||
if (offsetTop + root.height > container.height + container.top) {
|
this.getContainerRect(),
|
||||||
this.setDataAfterDiff({
|
]).then(([root, container]) => {
|
||||||
fixed: false,
|
if (offsetTop + root.height > container.height + container.top) {
|
||||||
transform: container.height - root.height,
|
this.setDataAfterDiff({
|
||||||
});
|
fixed: false,
|
||||||
} else if (offsetTop >= root.top) {
|
transform: container.height - root.height,
|
||||||
this.setDataAfterDiff({
|
});
|
||||||
fixed: true,
|
} else if (offsetTop >= root.top) {
|
||||||
height: root.height,
|
this.setDataAfterDiff({
|
||||||
transform: 0,
|
fixed: true,
|
||||||
});
|
height: root.height,
|
||||||
} else {
|
transform: 0,
|
||||||
this.setDataAfterDiff({ fixed: false, transform: 0 });
|
});
|
||||||
}
|
} else {
|
||||||
|
this.setDataAfterDiff({ fixed: false, transform: 0 });
|
||||||
}
|
}
|
||||||
);
|
});
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.getRect(ROOT_ELEMENT).then((root: BoundingClientRect) => {
|
getRect.call(this, ROOT_ELEMENT).then((root) => {
|
||||||
if (offsetTop >= root.top) {
|
if (offsetTop >= root.top) {
|
||||||
this.setDataAfterDiff({ fixed: true, height: root.height });
|
this.setDataAfterDiff({ fixed: true, height: root.height });
|
||||||
this.transform = 0;
|
this.transform = 0;
|
||||||
|
@ -70,7 +70,7 @@ VantComponent({
|
|||||||
const { items, mainActiveIndex } = this.data;
|
const { items, mainActiveIndex } = this.data;
|
||||||
const { children = [] } = items[mainActiveIndex] || {};
|
const { children = [] } = items[mainActiveIndex] || {};
|
||||||
|
|
||||||
return this.set({ subItems: children });
|
this.setData({ subItems: children });
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
Loading…
x
Reference in New Issue
Block a user