Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
hello uni-app x
提交
36f7ad31
H
hello uni-app x
项目概览
DCloud
/
hello uni-app x
通知
6018
Star
91
Fork
164
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
18
列表
看板
标记
里程碑
合并请求
1
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
H
hello uni-app x
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
18
Issue
18
列表
看板
标记
里程碑
合并请求
1
合并请求
1
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
36f7ad31
编写于
11月 29, 2023
作者:
DCloud-yyl
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
合并:更新半屏弹窗示例
上级
51b3a293
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
43 addition
and
30 deletion
+43
-30
pages/tabBar/template.uvue
pages/tabBar/template.uvue
+7
-8
pages/template/half-screen/half-screen.uvue
pages/template/half-screen/half-screen.uvue
+36
-22
未找到文件。
pages/tabBar/template.uvue
浏览文件 @
36f7ad31
...
@@ -154,14 +154,13 @@ export default {
...
@@ -154,14 +154,13 @@ export default {
open: false,
open: false,
pages: [] as Page[],
pages: [] as Page[],
},
},
// {
{
// id: 'half-screen',
id: 'half-screen',
// url: 'half-screen',
url: 'half-screen',
// name: '半屏弹窗',
name: '半屏弹窗',
// open: false,
open: false,
// enable: false,
pages: [] as Page[],
// pages: [] as Page[],
},
// },
{
{
id: 'drop-card',
id: 'drop-card',
url: 'drop-card',
url: 'drop-card',
...
...
pages/template/half-screen/half-screen.uvue
浏览文件 @
36f7ad31
<template>
<template>
<view class="page">
<view
id="page"
class="page">
<text
>TouchEvent还有细节需要优化,需支持拦截事件分发逻辑解决拖拽半屏窗口引起内容滚动的问题
</text>
<text
style="margin: 10px">半屏弹窗效果是通过监听TouchEvent实现,当半屏窗口移动时禁用scroll-view的滚动,避免两者的冲突。
</text>
<button class="bottomButton" @click="switchHalfScreen(true)">打开弹窗</button>
<button class="bottomButton" @click="switchHalfScreen(true)">打开弹窗</button>
<view
ref
="halfScreen" class="halfScreen" @touchstart="onHalfTouchStart" @touchmove="onHalfTouchMove" @touchend="onHalfTouchEnd">
<view
id
="halfScreen" class="halfScreen" @touchstart="onHalfTouchStart" @touchmove="onHalfTouchMove" @touchend="onHalfTouchEnd">
<view class="halfTitle" >半屏弹窗标题</view>
<view class="halfTitle" >半屏弹窗标题</view>
<scroll-view
ref="halfScroll" class="halfScroll" @scroll="onScroll" bounce
="true">
<scroll-view
id="halfScroll" class="halfScroll" @scroll="onScroll" rebound
="true">
<view v-for="(item,index) in list" :key="index" class="item">
<view v-for="(item,index) in list" :key="index" class="item">
half screen content-{{item}}
half screen content-{{item}}
</view>
</view>
...
@@ -39,7 +39,7 @@
...
@@ -39,7 +39,7 @@
if(this.bAnimation){//容错处理
if(this.bAnimation){//容错处理
return;
return;
}
}
let top:number = this.scrollNode?.
getAttribute('scrollTop') as number
let top:number = this.scrollNode?.
scrollTop??0;
let p = e.touches[0];
let p = e.touches[0];
this.lastY2 = this.lastY;
this.lastY2 = this.lastY;
this.lastY = p.screenY;
this.lastY = p.screenY;
...
@@ -48,26 +48,36 @@
...
@@ -48,26 +48,36 @@
this.halfScreenY = p.screenY;
this.halfScreenY = p.screenY;
}
}
let offset = p.screenY-this.halfScreenY;
let offset = p.screenY-this.halfScreenY;
if(offset > 0){
if(offset > 0){
//向下滚动
this.halfMove = true;
this.halfMove = true;
this.scrollNode?.setAttribute('scroll-y', 'false');
this.halfNode?.style?.setProperty('transform','translateY('+offset+'px)');
this.halfNode?.style?.setProperty('transform','translateY('+offset+'px)');
if(offset==0){
console.log('translateY(0px)', this.halfOffset)
}
this.halfOffset = offset;
this.halfOffset = offset;
}else if(this.
lastY2>this.lastY && this.halfOffset>0){//容错触发向下滚动的误差
}else if(this.
halfOffset>0){//向上滚动
offset = this.halfScreenY-p.screenY;
offset = this.halfScreenY-p.screenY;
if(offset>this.halfOffset){
if(offset>this.halfOffset){
offset = this.halfOffset;
offset = 0;
this.halfMove = false;
this.scrollNode?.setAttribute('scroll-y', 'true');
}
}
this.halfNode?.style?.setProperty('transform','translateY('+offset+'px)');
this.halfNode?.style?.setProperty('transform','translateY('+offset+'px)');
if(offset==0){
console.log('translateY(0px)', this.halfOffset)
}
this.halfOffset = offset;
this.halfOffset = offset;
}
}
}
}
//console.log('TouchMove', e.target);
//console.log('TouchMove', e.target);
},
},
onHalfTouchEnd(_:TouchEvent) {
onHalfTouchEnd(_:TouchEvent) {
this.halfScreenY = 0;
if(this.bAnimation){//容错处理
if(this.bAnimation){//容错处理
return;
return;
}
}
let top:number = this.scrollNode?.
getAttribute('scrollTop') as number
let top:number = this.scrollNode?.
scrollTop??0;
let bHide = (this.halfHeight-this.halfOffset)<this.halfHeight/4;
let bHide = (this.halfHeight-this.halfOffset)<this.halfHeight/4;
if(bHide){
if(bHide){
bHide = this.lastY2>0&&this.lastY2<=this.lastY;
bHide = this.lastY2>0&&this.lastY2<=this.lastY;
...
@@ -76,7 +86,7 @@
...
@@ -76,7 +86,7 @@
}
}
if(bHide){
if(bHide){
this.switchHalfScreen(false);
this.switchHalfScreen(false);
}else{
}else
if(this.halfOffset>0)
{
this.resumeHalfScreen();
this.resumeHalfScreen();
}
}
},
},
...
@@ -89,6 +99,7 @@
...
@@ -89,6 +99,7 @@
return;
return;
}
}
this.halfMove = false;
this.halfMove = false;
this.scrollNode?.setAttribute('scroll-y', 'true');
this.halfScreenY = 0;
this.halfScreenY = 0;
this.halfOffset = 0;
this.halfOffset = 0;
let top = this.totalHeight;
let top = this.totalHeight;
...
@@ -103,7 +114,7 @@
...
@@ -103,7 +114,7 @@
}
}
this.halfNode?.style?.setProperty('transitionDuration', time.toFixed(0));
this.halfNode?.style?.setProperty('transitionDuration', time.toFixed(0));
this.halfNode?.style?.setProperty('transitionProperty','top');
this.halfNode?.style?.setProperty('transitionProperty','top');
this.halfNode?.style?.setProperty('top', top.toFixed(
0
));
this.halfNode?.style?.setProperty('top', top.toFixed(
2
));
setTimeout(()=>{
setTimeout(()=>{
if(!show){
if(!show){
this.halfNode?.style?.setProperty('visibility','hidden');
this.halfNode?.style?.setProperty('visibility','hidden');
...
@@ -122,6 +133,7 @@
...
@@ -122,6 +133,7 @@
this.halfNode?.style?.setProperty('transitionProperty','transform');
this.halfNode?.style?.setProperty('transitionProperty','transform');
this.halfNode?.style?.setProperty('transform','translateY(0px)');
this.halfNode?.style?.setProperty('transform','translateY(0px)');
this.halfMove = false;
this.halfMove = false;
this.scrollNode?.setAttribute('scroll-y', 'true');
this.halfScreenY = 0;
this.halfScreenY = 0;
this.halfOffset = 0;
this.halfOffset = 0;
setTimeout(()=>{
setTimeout(()=>{
...
@@ -131,17 +143,19 @@
...
@@ -131,17 +143,19 @@
}
}
},
},
onReady() {
onReady() {
this.halfNode = this.$refs['halfScreen'] as Element;
this.halfNode = uni.getElementById('halfScreen');
this.scrollNode = uni.getElementById('halfScroll');
this.halfHeight = this.halfNode!.getBoundingClientRect().height;
this.halfHeight = this.halfNode!.getBoundingClientRect().height;
this.scrollNode = this.$refs['halfScroll'] as Element;
this.totalHeight = uni.getElementById('page')?.getBoundingClientRect()?.height??0;//uni.getWindowInfo().windowHeight;
this.halfNode?.style?.setProperty('top', this.totalHeight.toFixed(2));
this.totalHeight = uni.getWindowInfo().windowHeight;
this.halfNode?.style?.setProperty('top', this.totalHeight.toString());
},
},
// onResize() {
onResize() {
// this.halfHeight = this.halfNode!.getBoundingClientRect().height;
this.halfHeight = this.halfNode?.getBoundingClientRect()?.height??0;
// this.totalHeight = uni.getWindowInfo().windowHeight;
this.totalHeight = uni.getElementById('page')?.getBoundingClientRect()?.height??0;
// }
this.halfNode?.style?.setProperty('top', this.totalHeight.toFixed(2));
this.halfNode?.style?.setProperty('visibility','hidden');
}
}
}
</script>
</script>
...
@@ -169,11 +183,11 @@
...
@@ -169,11 +183,11 @@
align-items: center;
align-items: center;
justify-content: center;
justify-content: center;
height: 48px;
height: 48px;
background-color:
cornflowerblu
e;
background-color:
ghostwhit
e;
border-radius: 10px 10px 0 0;
border-radius: 10px 10px 0 0;
}
}
.halfScroll {
.halfScroll {
background-color:
ghost
white;
background-color: white;
}
}
.item {
.item {
height: 100px;
height: 100px;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录