NEW: Pre-order my Vapor book and learn server-side Swift! >>

How to load a HTML string into a WKWebView or UIWebView: loadHTMLString()

Written by Paul Hudson    @twostraws

If you want to generate HTML locally and show it inside your app, it's easy to do in both UIWebView and WKWebView. First, here's the code for UIWebView:

let webView1 = UIWebView()
webView1.loadHTMLString("<html><body><p>Hello!</p></body></html>", baseURL: nil)

And now here's the code for WKWebView:

let webView2 = WKWebView()
webView2.loadHTMLString("<html><body><p>Hello!</p></body></html>", baseURL: nil)

If you want to load resources from a particular place, such as JavaScript and CSS files, you can set the baseURL parameter to any URL. This could, for example, be the resource path for your app bundle, which would allow you to use local images and other assets alongside your generated HTML.

Available from iOS 2.0 – see Hacking with Swift tutorial 7

Did this solution work for you? Please pass it on!

Other people are reading…

About the Swift Knowledge Base

This is part of the Swift Knowledge Base, a free, searchable collection of solutions for common iOS questions.

Download for free!

Want a free 75-minute video teaching functional programming, protocol-oriented programming, and more? This is your lucky day!

Click here to visit the Hacking with Swift store >>