Swift iOS開發小書 ,幫你快速上手開發 epub.ituring.com.cn/946java
使用UIWebView裝載一個網頁後,可能須要提取其內的信息,比較好的方法是使用JavaScript。方法UIWebView.stringByEvaluatingJavaScript能夠執行一個腳本。bash
執行以下代碼,點擊頁面左上方的run js按鈕,能夠顯示一個對話框,內容爲當前網頁的標題(title):app
import UIKit
class Page: UIViewController{
var c : UIWebView!
override func viewDidLoad() {
super.viewDidLoad()
c = UIWebView()
c.frame = super.view.frame
view.addSubview(c)
c.frame.origin.y += 100
c.frame.size.height = 300
let url = URL(string:"http://apple.com")
let ro = URLRequest(url:url!)
c.loadRequest(ro)
let button = UIButton()
button.setTitle("run js", for: .normal)
button.addTarget(self, action: #selector(tap), for: .touchDown)
button.frame = CGRect(x: 0, y: 70, width: 100, height: 20)
view.addSubview(button)
}
func tap(){
c.stringByEvaluatingJavaScript(from: "function showtitle(){alert(document.title)};showtitle()")
}
}
@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {
var window: UIWindow?
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
self.window = UIWindow(frame: UIScreen.main.bounds)
self.window!.rootViewController = Page()
self.window?.makeKeyAndVisible()
return true
}
}複製代碼
若是javas使用的函數或者模塊比較大,能夠把它們放到一個文件內,做爲資源包含,啓動時加載並求值。這樣是很方便的。接下來的案例,把上面案例的js函數showtitle()做爲資源文件。首先func tap內修改成從資源中加載:ide
func tap(){
let jsCode = try! String(contentsOf: URL(fileURLWithPath: Bundle.main.path(forResource: "pack", ofType: "js")!))
c.stringByEvaluatingJavaScript(from: jsCode)
c.stringByEvaluatingJavaScript(from: "showtitle()")
}複製代碼
其次,建立一個資源文件,名爲pack.js ,內容爲:函數
function showtitle(){alert(document.title)};複製代碼
代碼運行後,點擊run js按鈕,效果和前一個案例相同。ui
有時候,須要截獲WebView的手勢操做到當前代碼內,在此代碼中獲取當前手勢觸控的位置上的元素。這個場景下,就能夠把js模塊代碼放到資源文件內,在觸控代碼中對此js調用和求值,得到它的輸出:lua
import UIKit
class Page: UIViewController,UIGestureRecognizerDelegate{
var c : UIWebView!
var tapGesture : UITapGestureRecognizer!
override func viewDidLoad() {
super.viewDidLoad()
c = UIWebView()
c.frame = super.view.frame
view.addSubview(c)
c.frame.origin.y += 100
c.frame.size.height = 300
let url = URL(string:"https://httpbin.org/image/png")//must be a https url ,otherwise iOS will fobidden it
let ro = URLRequest(url:url!)
c.loadRequest(ro)
let button = UIButton()
button.setTitle("run js", for: .normal)
button.addTarget(self, action: #selector(tap), for: .touchDown)
button.frame = CGRect(x: 0, y: 70, width: 100, height: 20)
view.addSubview(button)
tapGesture = UITapGestureRecognizer(target: self, action:#selector(tapHandler(_:)))
self.tapGesture!.delegate = self
self.c.addGestureRecognizer(self.tapGesture!);
}
func tap(){
let jsCode = try! String(contentsOf: URL(fileURLWithPath: Bundle.main.path(forResource: "pack", ofType: "js")!))
c.stringByEvaluatingJavaScript(from: jsCode)
c.stringByEvaluatingJavaScript(from: "showtitle()")
}
func gestureRecognizer(_: UIGestureRecognizer, shouldRecognizeSimultaneouslyWith shouldRecognizeSimultaneouslyWithGestureRecognizer:UIGestureRecognizer) -> Bool
{
return true
}
func tapHandler(_ tap :UITapGestureRecognizer){
let tapPoint = tap.location(in: tap.view)
print(tapPoint)
let script = String(format: "getHTMLElementAtPoint(%i,%i)", Int(tapPoint.x),Int(tapPoint.y))
let imgSrc = self.c.stringByEvaluatingJavaScript(from: script)
print(imgSrc)
}
}
@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {
var window: UIWindow?
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
self.window = UIWindow(frame: UIScreen.main.bounds)
self.window!.rootViewController = Page()
self.window?.makeKeyAndVisible()
return true
}
}複製代碼
執行代碼,點擊頁面的圖片,就能夠看到控制檯上的輸出:url
(168.0, 65.0)
Optional("https://httpbin.org/image/png,100,100,110,0")複製代碼
委託方法 gestureRecognizer(:shouldRecognizeSimultaneouslyWith)是很是必要的,沒有它的話,WebView會本身處理手勢,而不是轉移控制器給tapHandler(:)。spa