iOS APP中HTML预览图片 PPHTMLImagePreviewDemo

码农软件 · 软件分类 · 图像(Image) · 2019-05-29 21:12:53

软件介绍

该DEMO主要用于演示iOS APP中点击HTML的图片来预览图片,效果可以查看下面的演示图 image

原理阐述

1. 背景知识

在了解该原理之前,需要知道如下内容

  • html中的点击动作一般都是通过javascript来实现的,如下面代码:

    var img = document.getElementById('test');
    img.onclick = function() {
    alert("test");
    }

    PS: 以上代码实现的: 点击< img>来弹出含test的提示框.

  • javascript与objc交互

在iOS APP开发过程中,是通过UIWebView来加载html页面,因此javascript要与objc交互,桥梁应该就在UIWebview提供的API中,可以发现如下一些接口:

//objc 传参给javascript
- (NSString *)stringByEvaluatingJavaScriptFromString:(NSString *)script;

//javascript 传参给objc, 参数是存在于request中
 - (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType;

2. 实现细节

  • 在UIWebview加载完html后,调用stringByEvaluatingJavaScriptFromString来执行如下javascript代码,可以使用javascript压缩工具压缩下

    function assignImageClickAction() {
    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
        }
    }
    }
    assignImageClickAction();
  • 在webView:shouldStartLoadWithRequest:navigationType处理image-preview

许可

该代码遵循MIT许可.

联系方式

email: lvyexuwenfa100@126.com

本文地址:https://codercto.com/soft/d/6833.html

区块链革命

区块链革命

[加]唐塔普斯科特(Don Tapscott)、[加]亚力克斯·塔普斯科特(Alex Tapscott) / 中信出版集团股份有限公司 / 2016-9 / 69

(1)国际大腕“数字经济之父”继畅销书《维基经济学》之后再出力作! (2)一本真正全景式描述区块链理论及应用的巨著! (3)苹果共同创始人史蒂夫·沃兹尼亚克、世界经济论坛创始人和论坛主席克劳斯·施瓦布、网景及硅谷安德森·霍洛维茨风险投资公司创始人马克·安德森、麦肯锡董事长兼全球总裁鲍达民、 百事公司首席执行官卢英德、丹·舒尔曼 Paypal公司首席执行官等全球政治界、学术界和商界精英联......一起来看看 《区块链革命》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码