Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
hello uni-app x
提交
ebaefb23
H
hello uni-app x
项目概览
DCloud
/
hello uni-app x
通知
5995
Star
90
Fork
162
代码
文件
提交
分支
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看板
提交
ebaefb23
编写于
9月 02, 2023
作者:
H
hdx
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
long-list: request 改为泛型
上级
e5f50b28
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
20 addition
and
9 deletion
+20
-9
pages/template/long-list/long-list-page.uvue
pages/template/long-list/long-list-page.uvue
+3
-4
pages/template/long-list/long-list.uvue
pages/template/long-list/long-list.uvue
+17
-5
未找到文件。
pages/template/long-list/long-list-page.uvue
浏览文件 @
ebaefb23
...
...
@@ -103,16 +103,15 @@
this.loading = true
// TODO request data 没有拼接到 url 中,暂时手动拼接
uni.request({
uni.request
<ResponseDataType>
({
url: `${SERVER_URL}?type=${this.type}&page=${this.$currentPage}&page_size=${PAGE_SIZE}`,
data: {
type: this.type,
page: this.$currentPage,
page_size: PAGE_SIZE
},
dataType: '',
success: (res) => {
const responseData =
JSON.parse<ResponseDataType>(res.data as string)
const responseData =
res.data
if (responseData == null) {
return
}
...
...
@@ -238,4 +237,4 @@
text-align: center;
background-color: #f8f8f8;
}
</style>
\ No newline at end of file
</style>
pages/template/long-list/long-list.uvue
浏览文件 @
ebaefb23
...
...
@@ -40,6 +40,18 @@
preload : Boolean,
}
/**
* 根据权重在两个值之间执行线性插值.
* @constructor
* @param {number} value1 - 第一个值,该值应为下限.
* @param {number} value2 - 第二个值,该值应为上限.
* @param {number} amount - 应介于 0 和 1 之间,指示内插的权重.
* @returns {number} 内插值
*/
function lerpNumber(value1 : number, value2 : number, amount : number) : number {
return (value1 + (value2 - value1) * amount)
}
export default {
components: {
longPage
...
...
@@ -148,14 +160,14 @@
// 计算指示线
const current_size = this.$swiperTabsRect[current_index]
const move_to_size = this.$swiperTabsRect[move_to_index]
const indicator_line_
l = current_size.x + (move_to_size.x - current_size.x) * percentage
const indicator_line_w =
current_size.w + (move_to_size.w - current_size.w) * percentage
const indicator_line_
x = lerpNumber(current_size.x, move_to_size.x, percentage)
const indicator_line_w =
lerpNumber(current_size.w, move_to_size.w, percentage)
// 更新指示线
const x = indicator_line_
l
+ indicator_line_w / 2
const x = indicator_line_
x
+ indicator_line_w / 2
this.$indicatorNode?.style?.setProperty('transform', `translateX(${x}px) scaleX(${indicator_line_w})`)
//
将指示线
滚动到水平中心位置
// 滚动到水平中心位置
const scroll_x = x - this.$swiperWidth / 2
this.$tabScrollView?.setAttribute('scrollLeft', scroll_x)
},
...
...
@@ -214,4 +226,4 @@
.swiper-item {
flex: 1;
}
</style>
</style>
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录