城阳工作端uniH5前端代码
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

361 lines
13 KiB

<template>
<view class="custom-class van-sticky" :style="computed.containerStyle({ fixed, height, zIndex })">
<view :class="utils.bem('sticky-wrap', { fixed })" :style="computed.wrapStyle({ fixed, offsetTop, transform, zIndex })">
<slot />
</view>
</view>
</template>
<script module="utils" lang="wxs" src="@/miniprogram_npm/@vant/weapp/wxs/utils.wxs"></script>
<script module="computed" lang="wxs" src="@/miniprogram_npm/@vant/weapp/sticky/index.wxs"></script>
<script>
'use strict';
Object.defineProperty(exports, '__esModule', {
value: true
});
var utils_1 = require('../common/utils');
var component_1 = require('../common/component');
var validator_1 = require('../common/validator');
var page_scroll_1 = require('../mixins/page-scroll');
var ROOT_ELEMENT = '.van-sticky';
export default {
data() {
return {
height: 0,
fixed: false,
transform: 0
};
},
props: {
zIndex: {
type: Number,
default: 99
},
offsetTop: {
type: Number,
default: 0
},
disabled: {
type: Boolean
},
container: {
type: null
},
scrollTop: {
type: null
}
},
mixins: [
(0, page_scroll_1.pageScrollMixin)(function (event) {
if (this.scrollTop != null) {
return;
}
this.onScroll(event);
})
],
mounted: function () {
this.onScroll();
},
methods: {
onScroll: function (_a) {
var that = this;
var _b = _a === void 0 ? {} : _a;
var scrollTop = _b.scrollTop;
var _c = this;
var container = _c.container;
var offsetTop = _c.offsetTop;
var disabled = _c.disabled;
if (disabled) {
this.setDataAfterDiff({
fixed: false,
transform: 0
});
return;
}
this.scrollTop = scrollTop || this.scrollTop;
if (typeof container === 'function') {
Promise.all([(0, utils_1.getRect)(this, ROOT_ELEMENT), this.getContainerRect()])
.then(function (_a) {
var root = _a[0];
var container = _a[1];
if (offsetTop + root.height > container.height + container.top) {
that.setDataAfterDiff({
fixed: false,
transform: container.height - root.height
});
} else if (offsetTop >= root.top) {
that.setDataAfterDiff({
fixed: true,
height: root.height,
transform: 0
});
} else {
that.setDataAfterDiff({
fixed: false,
transform: 0
});
}
})
.catch(function () {});
return;
}
(0, utils_1.getRect)(this, ROOT_ELEMENT).then(function (root) {
if (!(0, validator_1.isDef)(root) || (!root.width && !root.height)) {
return;
}
if (offsetTop >= root.top) {
that.setDataAfterDiff({
fixed: true,
height: root.height
});
that.transform = 0;
} else {
that.setDataAfterDiff({
fixed: false
});
}
});
},
setDataAfterDiff: function (data) {
var that = this;
this.$nextTick(function () {
var diff = Object.keys(data).reduce(function (prev, key) {
if (data[key] !== that[key]) {
prev[key] = data[key];
}
return prev;
}, {});
if (Object.keys(diff).length > 0) {
that.setData(diff);
}
that.$emit('scroll', {
scrollTop: that.scrollTop,
isFixed: data.fixed || that.fixed
});
});
},
getContainerRect: function () {
var nodesRef = this.container();
if (!nodesRef) {
return Promise.reject(new Error('not found container'));
}
return new Promise(function (resolve) {
return nodesRef.boundingClientRect(resolve).exec();
});
}
},
watch: {
offsetTop: {
handler: function (_a) {
var that = this;
var _b = _a === void 0 ? {} : _a;
var scrollTop = _b.scrollTop;
var _c = this;
var container = _c.container;
var offsetTop = _c.offsetTop;
var disabled = _c.disabled;
if (disabled) {
this.setDataAfterDiff({
fixed: false,
transform: 0
});
return;
}
this.scrollTop = scrollTop || this.scrollTop;
if (typeof container === 'function') {
Promise.all([(0, utils_1.getRect)(this, ROOT_ELEMENT), this.getContainerRect()])
.then(function (_a) {
var root = _a[0];
var container = _a[1];
if (offsetTop + root.height > container.height + container.top) {
that.setDataAfterDiff({
fixed: false,
transform: container.height - root.height
});
} else if (offsetTop >= root.top) {
that.setDataAfterDiff({
fixed: true,
height: root.height,
transform: 0
});
} else {
that.setDataAfterDiff({
fixed: false,
transform: 0
});
}
})
.catch(function () {});
return;
}
(0, utils_1.getRect)(this, ROOT_ELEMENT).then(function (root) {
if (!(0, validator_1.isDef)(root) || (!root.width && !root.height)) {
return;
}
if (offsetTop >= root.top) {
that.setDataAfterDiff({
fixed: true,
height: root.height
});
that.transform = 0;
} else {
that.setDataAfterDiff({
fixed: false
});
}
});
},
immediate: true
},
disabled: {
handler: function (_a) {
var that = this;
var _b = _a === void 0 ? {} : _a;
var scrollTop = _b.scrollTop;
var _c = this;
var container = _c.container;
var offsetTop = _c.offsetTop;
var disabled = _c.disabled;
if (disabled) {
this.setDataAfterDiff({
fixed: false,
transform: 0
});
return;
}
this.scrollTop = scrollTop || this.scrollTop;
if (typeof container === 'function') {
Promise.all([(0, utils_1.getRect)(this, ROOT_ELEMENT), this.getContainerRect()])
.then(function (_a) {
var root = _a[0];
var container = _a[1];
if (offsetTop + root.height > container.height + container.top) {
that.setDataAfterDiff({
fixed: false,
transform: container.height - root.height
});
} else if (offsetTop >= root.top) {
that.setDataAfterDiff({
fixed: true,
height: root.height,
transform: 0
});
} else {
that.setDataAfterDiff({
fixed: false,
transform: 0
});
}
})
.catch(function () {});
return;
}
(0, utils_1.getRect)(this, ROOT_ELEMENT).then(function (root) {
if (!(0, validator_1.isDef)(root) || (!root.width && !root.height)) {
return;
}
if (offsetTop >= root.top) {
that.setDataAfterDiff({
fixed: true,
height: root.height
});
that.transform = 0;
} else {
that.setDataAfterDiff({
fixed: false
});
}
});
},
immediate: true
},
container: {
handler: function (_a) {
var that = this;
var _b = _a === void 0 ? {} : _a;
var scrollTop = _b.scrollTop;
var _c = this;
var container = _c.container;
var offsetTop = _c.offsetTop;
var disabled = _c.disabled;
if (disabled) {
this.setDataAfterDiff({
fixed: false,
transform: 0
});
return;
}
this.scrollTop = scrollTop || this.scrollTop;
if (typeof container === 'function') {
Promise.all([(0, utils_1.getRect)(this, ROOT_ELEMENT), this.getContainerRect()])
.then(function (_a) {
var root = _a[0];
var container = _a[1];
if (offsetTop + root.height > container.height + container.top) {
that.setDataAfterDiff({
fixed: false,
transform: container.height - root.height
});
} else if (offsetTop >= root.top) {
that.setDataAfterDiff({
fixed: true,
height: root.height,
transform: 0
});
} else {
that.setDataAfterDiff({
fixed: false,
transform: 0
});
}
})
.catch(function () {});
return;
}
(0, utils_1.getRect)(this, ROOT_ELEMENT).then(function (root) {
if (!(0, validator_1.isDef)(root) || (!root.width && !root.height)) {
return;
}
if (offsetTop >= root.top) {
that.setDataAfterDiff({
fixed: true,
height: root.height
});
that.transform = 0;
} else {
that.setDataAfterDiff({
fixed: false
});
}
});
},
immediate: true
},
scrollTop: {
handler: function (val) {
this.onScroll({
scrollTop: val
});
},
immediate: true
}
}
};
</script>
<style>
@import '../common/index.css';
.van-sticky {
position: relative;
}
.van-sticky-wrap--fixed {
left: 0;
position: fixed;
right: 0;
}
</style>