Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
unidocs-uni-app-x-zh
提交
c73f2ff5
U
unidocs-uni-app-x-zh
项目概览
DCloud
/
unidocs-uni-app-x-zh
通知
144
Star
2
Fork
33
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
9
列表
看板
标记
里程碑
合并请求
11
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
unidocs-uni-app-x-zh
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
9
Issue
9
列表
看板
标记
里程碑
合并请求
11
合并请求
11
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
c73f2ff5
编写于
11月 22, 2024
作者:
杜庆泉
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Update generics.md
上级
525eae9f
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
74 addition
and
1 deletion
+74
-1
docs/uts/generics.md
docs/uts/generics.md
+74
-1
未找到文件。
docs/uts/generics.md
浏览文件 @
c73f2ff5
...
@@ -90,7 +90,80 @@ function testArray<T extends Array<unknown>>(arg: T): T {
...
@@ -90,7 +90,80 @@ function testArray<T extends Array<unknown>>(arg: T): T {
### 安卓平台使用泛型注意事项
### 安卓平台使用泛型注意事项
ts本质是擦除类型的。在强类型语言中,传递泛型时如将泛型类型作为值使用,需通过特殊方式将泛型类型作为值使用,可以根据传入来动态决定返回类型。
[
详见
](
../plugin/uts-for-android.html#lost-generics
)
ts本质是擦除类型的。在强类型语言中,传递泛型时如将泛型类型作为值使用,需通过特殊方式将泛型类型作为值使用,可以根据传入来动态决定返回类型:
如果在UTS中声明一个包含泛型声明的方法,可能会出现泛型丢失,原因是因为普通的kotlin 方法没有实现泛型的传递
错误的kt代码:
```
kotlin
fun
<
T
>
getArtListByres
():
A
<
T
>?
{
var
aRet
=
UTSAndroid
.
consoleDebugError
(
JSON
.
parse
<
A
<
T
>>(
"{\"x\":111,\"y\":\"aaa\",\"t\":{\"name\":\"zhangsan\"}}"
),
" at pages/index/index.uvue:27"
);
return
aRet
;
}
```
期望得到的正确的kt代码:
```
ts
inline
fun
<
reified
T
>
getArtListByres
():
A
<
T
>
?
{
var
aRet
=
UTSAndroid
.
consoleDebugError
(
JSON
.
parse
<
A
<
T
>>
(
"
{
\"
x
\"
:111,
\"
y
\"
:
\"
aaa
\"
,
\"
t
\"
:{
\"
name
\"
:
\"
zhangsan
\"
}}
"
),
"
at pages/index/index.uvue:27
"
);
return
aRet
;
}
```
为了解决这种情况,我们可以在UTS中 添加android方法注解,来告诉编译器生成正确的代码:
```
kotlin
@UTSAndroid
.
keyword
(
"inline"
)
@UTSAndroid
.
keyword
(
'
reified
'
)
export
function
request
<
T
>(
options
:
RequestOptions
<
T
>)
:
RequestTask
{
//xxx
}
```
**注意:不要在`inline`方法中创建局部function,比如request的success回调、Promise的回调,原因是kotlin语言的限制(inline方法展开到内联位置,也会把局部方法展开过去,这是不允许的),由此把使用局部function的逻辑封装到非内联的方法中,绕过此限制。**
下面是可以完整的示例:
```
@UTSAndroid.keyword("inline")
@UTSAndroid.keyword("reified")
export function boxRequest<T>(url : string) : Promise<T> {
return innerRequest<T>(url, UTSAndroid.getGenericClassName<T>(), UTSAndroid.getGenericType<T>())
}
function innerRequest<T>(url : string, clzName : string, type : Type) : Promise<T> {
return new Promise<T>((resolve, reject) => {
uni.request<string>({
url: url,
method: "GET",
success: (e : RequestSuccess<string>) => {
const result = JSON.parse<T>(e.data!, type)
if (result != null) {
resolve(result)
} else if ("java.lang.Object".equals(clzName, true)) {// 解决泛型是any,但后端返回string的情况。
resolve(e.data! as T)
} else{
reject("parsing failure")
}
},
fail(e : RequestFail) {
reject(e)
},
} as RequestOptions<string>)
});
}
```
调用代码:
```
const respone = await boxRequest<CustomType>("xxxx")
```
此示例中,网络请求泛型为
`string`
在4.25版本以下会导致错误,此问题已在4.25进行修复
[
issue
](
https://issues.dcloud.net.cn/pages/issues/detail?id=4010
)
### iOS 平台使用泛型注意事项
### iOS 平台使用泛型注意事项
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录