swift
来源:互联网 发布:微博十大网络主播投票 编辑:程序博客网 时间:2024/05/17 02:42
前言:刚学习swift4,发现很多有意思的东西。特此拿出和大家进行分享。今天主要看下swift4中wkwebView实现点击图片进入大图浏览模式的实现。先上效果图
本文swift与WKWebView交互Demo地址
其实对于swift与web进行交互也好,webview大图浏览图片也好。和oc语言发现真的很多逻辑都是相通的。今天我们来看下swift4版本中wkWebView实现大图浏览模式
为了实现我们大图浏览,需要先理清楚几个思路
1.动态往html中注入获取图片并且增加点击事件的js方法
2.拿到所有图片
3.点击做放大效果,实现大图浏览模式
因为刚学习swift4,发现好多语法都不知道怎么用,偷懒就桥接了OC语言的部分方法,如果您不知道如何在swift中使用OC,可以看下这篇文章,本文不做重点详解
如何在OC中使用Swift如何在Swift中使用OC
先上部分js注入的代码,这里使用的是OC版的代码注入的,如果那位同学有swift版本的注入js获取图片的代码,还望告知于我,非常感谢
OC版注入js获取图片并增加点击事件代码示例
static NSString * const jsGetImages = @"function getImages(){\ var objs = document.getElementsByTagName(\"img\");\ var imgScr = '';\ for(var i=0;i<objs.length;i++){\ imgScr = imgScr + objs[i].src + '+';\ };\ return imgScr;\ };function registerImageClickAction(){\ var imgs=document.getElementsByTagName('img');\ var length=imgs.length;\ for(var i=0;i<length;i++){\ img=imgs[i];\ img.onclick=function(){\ window.location.href='image-preview:'+this.src}\ }\ }";
既然动态注入,那么我们就放进当前加载的html中
userScript就是我们的js注入方法,原谅我用的oc语法桥接进swift实现的
private lazy var articleWeb : WKWebView = { let webView = WKWebView.init(frame: view.bounds, configuration: configutation) webView.allowsBackForwardNavigationGestures = true webView.navigationDelegate = self webView.uiDelegate = self webView.scrollView.delegate = self return webView }() private lazy var configutation: WKWebViewConfiguration = { let config = WKWebViewConfiguration() config.userContentController.addUserScript(String.userScript()) config.userContentController.add(WeakScriptMessageDelegate.init(delegate: self), name: "webViewApp") return config }()
2.对于正常的html来说,把动态注入js放到didfinish代理方法里边去执行再好不过。但是由于我们App的前端的特殊性。直接把js代码放到didfinishload里边是无法获取的,所以就和前端进行协商,让前端加载成功之后给我返回success字段,我再进行获取html中的图片。这种方式是可行的。并且也运用于我的上线的项目中
3.实现WKScriptMessageHandler代理,在代理方法中等待前端返回success字段,然后进行获取图片操作
extension ArticleDetialViewController: WKScriptMessageHandler{ func userContentController(_ userContentController: WKUserContentController, didReceive message: WKScriptMessage) { print(message.body) let dic = message.body as! Dictionary<String, Any> if (dic["success"] != nil) { print("有值啦...") articleWeb.evaluateJavaScript("getImages()", completionHandler: { (object, error) in let str = String.init(describing: object!) self.webImageListArray = str.components(separatedBy: "+") }) articleWeb.evaluateJavaScript("registerImageClickAction();", completionHandler: nil) } }}
这个webImageListArray是声明成了全局的,用于存储获取过来的图片 var webImageListArray : Array<Any>!
4.拿到图片,做点击事件触发就需要提到我们wkWebView的另一个代理方法了
func webView(_ webView: WKWebView, decidePolicyFor navigationAction: WKNavigationAction, decisionHandler: @escaping (WKNavigationActionPolicy) -> Void) { if (navigationAction.request.url?.scheme == "image-preview") { let miu = String.init(describing: "image-preview:") let preview = String.init(describing: navigationAction.request.url!.absoluteString) let path = preview.suffix(from:(miu.index(miu.startIndex, offsetBy: 14))) imgStr = String(path) self.previewPicture() } decisionHandler(.allow) }
以上代码主要做的操作是,获取当前点击图片的String并进行截取。目的是为了等下弹出大图时,能找到指定的currentIndex,还有一点要提一下,这个方法写好必须实现回调函数,不然会崩溃的袄
5.执行我们大图浏览的方法
func previewPicture() -> Void { var currentIndex: Int = 0 for section in 0..<webImageListArray.count{ let path = String(describing: webImageListArray![section]) if path == imgStr{ currentIndex = section } } let photoBrowserd = SDPhotoBrowserd() photoBrowserd.imageCount = webImageListArray.count photoBrowserd.currentImageIndex = currentIndex photoBrowserd.sourceImagesContainerView = view photoBrowserd.delegate = self photoBrowserd.show() } func photoBrowser(_ browser: SDPhotoBrowserd!, highQualityImageURLFor index: Int) -> URL! { return NSURL.init(string: String.init(describing: webImageListArray[index]))! as URL }
这里大图浏览用到的第三方OC语言写的SDPhotoBrowserd,进行大图浏览查看,效果还不错。有兴趣的可以下载下来demo看看
本文swift与WKWebView交互Demo地址
阅读全文
0 0
- SWIFT
- swift
- Swift
- Swift
- swift
- Swift
- swift
- Swift
- swift
- swift
- swift
- Swift
- swift
- swift
- Swift
- swift
- swift
- swift ??
- 创建模板
- linux命令初学
- 4. x86常见指令解析
- Selenium的api
- H5证件识别API/接口
- swift
- HTTP接口测试工具及使用
- Libevent源码分析
- 详解为什么32位系统只能用4G内存
- Mac上安装php56-mongo扩展
- python的flask解决xss攻击漏洞
- cocos2dx 从节点中获取图片对象
- 提醒
- cs231n笔记(8)--卷积神经网络CNN