作者要加載本地的一個js組件作用于WKWebView中,如下:
加載的HTML代碼:
let html = """
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
<title>Editor</title>
<style type="text/css" media="screen">
body {
overflow: hidden;
}
#editor {
margin: 0;
position: absolute;
top: 0;
bottom: 0;
left: 0;
right: 0;
}
</style>
</head>
<body>
<pre id="editor">function foo(items) {
var i;
for (i = 0; i < items.length; i++) {
alert("Ace Rocks " + items[i]);
}
}</pre>
<script src="ace.js" type="text/javascript" charset="utf-8"></script>
<script>
var editor = ace.edit("editor");
editor.setTheme("ace/theme/twilight");
editor.session.setMode("ace/mode/javascript");
</script>
</body>
</html>
"""
但是問題來了兴溜,HTML引用本地的資源文件中的js庫坑资,該怎么注入進去呢?
這個需要使用loadHTMLString:的第二個參數(shù)了
contentWebView.loadHTMLString(html, baseURL: Bundle.main.resourceURL?.appendingPathComponent("Ace"))
通過第二個參數(shù)的URL可以指定所有js引用的路徑另玖,設(shè)置它就OK拉