Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DCloud
hello uni-app x
提交
26b51eb9
H
hello uni-app x
项目概览
DCloud
/
hello uni-app x
通知
5977
Star
89
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看板
体验新版 GitCode,发现更多精彩内容 >>
提交
26b51eb9
编写于
7月 26, 2024
作者:
lizhongyi_
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
实现iOS 平台 uts-get-native-view插件逻辑
(cherry picked from commit
ae73164d
)
上级
7232f8f5
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
42 addition
and
83 deletion
+42
-83
pages/component/web-view/web-view.uvue
pages/component/web-view/web-view.uvue
+2
-2
uni_modules/uts-get-native-view/utssdk/app-ios/DCGetElementByID.swift
...uts-get-native-view/utssdk/app-ios/DCGetElementByID.swift
+22
-0
uni_modules/uts-get-native-view/utssdk/app-ios/index.uts
uni_modules/uts-get-native-view/utssdk/app-ios/index.uts
+18
-81
未找到文件。
pages/component/web-view/web-view.uvue
浏览文件 @
26b51eb9
...
...
@@ -112,8 +112,6 @@
},
loading(event : UniWebViewLoadingEvent) {
console.log(JSON.stringify(event.detail));
this.canGoBack = canWebViewGoBack('web-view');
this.canGoForward = canWebViewGoForward('web-view');
if (this.autoTest) {
this.eventLoading = {
"tagName": event.target?.tagName,
...
...
@@ -124,6 +122,8 @@
},
load(event : UniWebViewLoadEvent) {
console.log(JSON.stringify(event.detail));
this.canGoBack = canWebViewGoBack('web-view');
this.canGoForward = canWebViewGoForward('web-view');
if (this.autoTest) {
this.eventLoad = {
"tagName": event.target?.tagName,
...
...
uni_modules/uts-get-native-view/utssdk/app-ios/DCGetElementByID.swift
0 → 100644
浏览文件 @
26b51eb9
//
// DCUni.swift
// DCGetElementByID
//
// Created by DCloud-iOS-XHY on 2024/7/8.
//
import
DCloudUniappRuntime
public
class
DCGetElementByID
{
/// 返回一个匹配特定 ID 的元素, 如果不存在,返回 null 规则同 https://doc.dcloud.net.cn/uni-app-x/api/get-element.html#getelementbyid
public
static
func
dcGetElementById
(
_
id
:
String
)
->
UniElement
?
{
let
appManager
=
UniSDKEngine
.
self
.
getAppManager
()
if
let
app
=
appManager
.
getCurretApp
(),
let
pageManager
=
app
.
pageManager
as?
UniPageManagerImpl
,
let
page
=
pageManager
.
getTopPage
(),
let
domManager
=
page
.
document
as?
UniDomManager
{
return
domManager
.
getElementById
(
id
)
}
return
nil
}
}
uni_modules/uts-get-native-view/utssdk/app-ios/index.uts
浏览文件 @
26b51eb9
/**
* 引用 iOS 系统库,示例如下:
* import { UIDevice } from "UIKit";
* [可选实现,按需引入]
*/
/* 引入 interface.uts 文件中定义的变量 */
import { MyApiOptions, MyApiResult, MyApi, MyApiSync } from '../interface.uts';
/* 引入 unierror.uts 文件中定义的变量 */
import { MyApiFailImpl } from '../unierror';
/**
* 引入三方库
* [可选实现,按需引入]
*
* 在 iOS 平台引入三方库有以下两种方式:
* 1、通过引入三方库framework 或者.a 等方式,需要将 .framework 放到 ./Frameworks 目录下,将.a 放到 ./Libs 目录下。更多信息[详见](https://uniapp.dcloud.net.cn/plugin/uts-plugin.html#ios-平台原生配置)
* 2、通过 cocoaPods 方式引入,将要引入的 pod 信息配置到 config.json 文件下的 dependencies-pods 字段下。详细配置方式[详见](https://uniapp.dcloud.net.cn/plugin/uts-ios-cocoapods.html)
*
* 在通过上述任意方式依赖三方库后,使用时需要在文件中 import:
* 示例:import { LottieLoopMode } from 'Lottie'
*/
/**
* UTSiOS 为平台内置对象,不需要 import 可直接调用其API,[详见](https://uniapp.dcloud.net.cn/uts/utsios.html)
*/
/**
* 异步方法
*
* uni-app项目中(vue/nvue)调用示例:
* 1、引入方法声明 import { myApi } from "@/uni_modules/uts-api"
* 2、方法调用
* myApi({
* paramA: false,
* complete: (res) => {
* console.log(res)
* }
* });
*
*/
export const myApi : MyApi = function (options : MyApiOptions) {
if (options.paramA == true) {
// 返回数据
const res : MyApiResult = {
fieldA: 85,
fieldB: true,
fieldC: 'some message'
};
options.success?.(res);
options.complete?.(res);
} else {
// 返回错误
let failResult = new MyApiFailImpl(9010001);
options.fail?.(failResult)
options.complete?.(failResult)
import { CanWebViewGoBack, CanWebViewGoForward } from "../interface";
import { WKWebView } from 'WebKit';
export const canWebViewGoBack : CanWebViewGoBack = function (elementId : string) : boolean {
// const element = uni.getElementById(elementId)
const element = DCGetElementByID.dcGetElementById(elementId)
const view = element?.getIOSView();
if (view != null && view instanceof WKWebView) {
return (view! as WKWebView).canGoBack;
}
return false;
}
/**
* 同步方法
*
* uni-app项目中(vue/nvue)调用示例:
* 1、引入方法声明 import { myApiSync } from "@/uni_modules/uts-api"
* 2、方法调用
* myApiSync(true);
*
*/
export const myApiSync : MyApiSync = function (paramA : boolean) : MyApiResult {
// 返回数据,根据插件功能获取实际的返回值
const res : MyApiResult = {
fieldA: 85,
fieldB: paramA,
fieldC: 'some message'
};
return res;
export const canWebViewGoForward : CanWebViewGoForward = function (elementId : string) : boolean {
// const element = uni.getElementById(elementId)
const element = DCGetElementByID.dcGetElementById(elementId)
const view = element?.getIOSView();
if (view != null && view instanceof WKWebView) {
return (view! as WKWebView).canGoForward;
}
return false;
}
/**
* 更多插件开发的信息详见:https://uniapp.dcloud.net.cn/plugin/uts-plugin.html
*/
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录