SwiftUI入门 - 18. WebView的基本使用

置顶

菜鸟入门,各位大佬轻喷,如有谬误之处欢迎讨论建议,也欢迎各位道友与我同行

“不积跬步,无以至千里;不积小流,无以成江海”

上一篇时间有点久了,快两周了,不是断更,是阳了😂,最近才勉强恢复过来。

继续

本文我们来讨论 WebView 的基本使用。

WebView在很多场景都是避免不了的技术,毕竟有的东西在web上实现还是相对比较快速容易的。

更何况我原本的技术栈几乎都集中在web上,要不是需要前期入门积累,我都想直接第一篇就搞 WebView 了😂。

本文将实现WebView的基本加载,示例如下:

在这里插入图片描述

思考

SwiftUI中是没有webview的,单独去引个包肯定也不划算

所以我们需要从 WebKit 中引入 WKWebView

让它在SwiftUI中可用作 View ,并且可以拿到webview的操作句柄

毕竟 webview 展示出来之后肯定是会有交互的。

实现

新增 webview.swift 文件,内容如下:

import SwiftUI
import WebKit

// 这里我理解是把 WebKit 里面的 WkWebView 转成了 SwiftUI可以使用的View类型
struct WebView:UIViewRepresentable{
    let webview:WKWebView;
    
    // 当然也可以直接在这个方法里面初始化 WKWebView,但是这样的话就拿不到操作句柄了
    // 不方便后续操作
    func makeUIView(context: Context) -> WKWebView {
        return webview;
    }
    // 这两个方法都是 UIViewRepresentable 里面规定的
    func updateUIView(_ uiView: WKWebView, context: Context) {}
}

// 制定一个数据模型,这里面有webview的操作句柄
// 后续我们可以把与webview 的交互写到这个类里面
class webviewModel: ObservableObject{
    
    let webview:WKWebView;
    
    init() {
        // 实例化 WkWebView
        self.webview = WKWebView(frame: .zero)
        
        // 加载本地HTML
        // 这个例子加载的是本地 Resource文件夹下的 index.html
        // let HTMLSTRING = try! String(contentsOfFile: Bundle.main.path(forResource: "index", ofType: "html")!,encoding: .utf8)
        // self.webview.loadHTMLString(HTMLSTRING, baseURL: Bundle.main.resourceURL);
        
        // 加载远程HTML
        let url = URL(string: "https://cn.bing.com/")!
        webview.load(URLRequest(url: url))
    }
}


// 显示webview的页面
struct webviewPage:View{
    // 数据模型使用
    @ObservedObject var web = webviewModel();
    var body: some View{
        VStack{
            // webview
            WebView(webview: web.webview)
            // 点击按钮在webview内执行JavaScript
            Button("here is a test button"){
                web.webview.evaluateJavaScript("changeName()"){(response,error) in
                    // 打印返回或者报错,没有时两个值为 nil
                    print("执行返回:\(String(describing: response))")
                    print("执行报错:\(String(describing: error))")
                }
            }
        }
    }
}

修改 IndexView.swift文件,将webview页面放入tabview中:

// ... 省略
VStack{
    // 一个简单的tabview,底部导航栏
    TabView {
        TodoView()
            .tabItem {
                Image(systemName: "list.dash")
                Text("TODO")
            }.tag(0)        
        SettingView()
            .tabItem {
                Image(systemName: "gear.circle")
                Text("设置")
            }.tag(1)    
        webviewPage()
            .tabItem{
                Image(systemName: "globe")
                Text("网页")
            }.tag(2)
        }
        .font(.headline)
    }
}
// ... 省略

踩坑

一开始我将 WebView 直接放到了 @main 即入口文件的 View 中,想着可以快速调试修改。

结果 webview 点击一次过后就直接崩溃,点击其他地方却不影响。

后经排查发现 webview 不能直接放到 @main 里面😂。

做成一个页面就没有问题。

但是如果是在实现UIViewRepresentablewebview 里面直接初始化的 WkWebView 就没有问题。

总结

  1. SwiftUIwebview 的基本使用。
  2. 两种加载方式,本地加载和远程网址。
  3. 踩坑点击一次 webviewApp 直接崩溃。

欢迎关注公zhong号【思跃喵】,一起探讨。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,222评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,455评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,720评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,568评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,696评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,879评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,028评论 3 409
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,773评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,220评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,550评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,697评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,360评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,002评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,782评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,010评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,433评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,587评论 2 350

推荐阅读更多精彩内容