麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

UIWebView的HTML5擴展

2019-11-14 20:11:21
字體:
來源:轉載
供稿:網友
http://blog.csdn.net/duzixi/article/details/36047201

 

對于不少iOS開發者來說,HTML5的內容比較陌生。

尤其是UIWebView類的 stringByEvaluatingjavaScriptFromString 方法

讓很多人覺得又得學一種新的語言。

而這一部分也是項目中學生常問的問題之一。

本文以Category(類目)的方式擴展了UIWebView類,將一些常用的Javascript操作封裝成UIWebView類方法。

 

最新源代碼下載地址:https://github.com/duzixi/UIWebView-HTML5(持續維護)

 頭文件(UIWebView+HTML5.h)

////  UIWebView+HTML5.h//  WebViewJS////  Created by 杜子兮(duzixi) on 14-6-30.//  Edited  by 杜子兮(duzixi) on 14-7-11. 修改網頁圖片顯示大小//                                       添加(jQuery)//  Copyright (c) 2014年 lanou3g.com 藍鷗. All rights reserved.//#import <UIKit/UIKit.h>@interface UIWebView (JavaScript)#PRagma mark -#pragma mark 獲取網頁中的數據///  獲取某個標簽的結點個數- (int)nodeCountOfTag:(NSString *)tag;///  獲取當前頁面URL- (NSString *) getCurrentURL;///  獲取標題- (NSString *) getTitle;///  獲取圖片- (NSArray *) getImgs;///  獲取當前頁面所有鏈接- (NSArray *) getOnClicks;#pragma mark -#pragma mark 改變網頁樣式和行為///  改變背景顏色- (void) setBackgroundColor:(UIColor *)color;///  為所有圖片添加點擊事件(網頁中有些圖片添加無效)- (void) addClickEventOnImg;///  改變所有圖像的寬度- (void) setImgWidth:(int)size;///  改變所有圖像的高度- (void) setImgHeight:(int)size;///  改變指定標簽的字體顏色- (void) setFontColor:(UIColor *) color withTag:(NSString *)tagName;///  改變指定標簽的字體大小- (void) setFontSize:(int) size withTag:(NSString *)tagName;@end

 實現文件(UIWebView+HTML5.m):

////  UIWebView+HTML5.m////  Created by 杜子兮(duzixi) on 14-6-30.//  Edited  by 杜子兮(duzixi) on 14-7-11. 修改網頁圖片顯示大小//                                       添加(jQuery)//  Copyright (c) 2014年 lanou3g.com 藍鷗. All rights reserved.//#import "UIWebView+HTML5.h"#import "UIColor+Change.h"@implementation UIWebView (JavaScript)#pragma mark -#pragma mark 獲取網頁中的數據///  獲取某個標簽的結點個數- (int)nodeCountOfTag:(NSString *)tag{    NSString *jsString = [NSString stringWithFormat:@"document.getElementsByTagName('%@').length", tag];    int len = [[self stringByEvaluatingJavaScriptFromString:jsString] intValue];    return len;}///  獲取當前頁面URL- (NSString *)getCurrentURL{    return [self stringByEvaluatingJavaScriptFromString:@"document.location.href"];}///  獲取標題- (NSString *)getTitle{    return [self stringByEvaluatingJavaScriptFromString:@"document.title"];}///  獲取所有圖片鏈接- (NSArray *)getImgs{    NSMutableArray *arrImgURL = [[NSMutableArray alloc] init];        for (int i = 0; i < [self nodeCountOfTag:@"img"]; i++) {        NSString *jsString = [NSString stringWithFormat:@"document.getElementsByTagName('img')[%d].src", i];        [arrImgURL addObject:[self stringByEvaluatingJavaScriptFromString:jsString]];    }    return arrImgURL;}///  獲取當前頁面所有點擊鏈接- (NSArray *)getOnClicks{    NSMutableArray *arrOnClicks = [[NSMutableArray alloc] init];        for (int i = 0; i < [self nodeCountOfTag:@"a"]; i++) {        NSString *jsString = [NSString stringWithFormat:@"document.getElementsByTagName('a')[%d].getAttribute('onclick')", i];        NSString *clickString = [self stringByEvaluatingJavaScriptFromString:jsString];        NSLog(@"%@", clickString);        [arrOnClicks addObject:clickString];    }    return arrOnClicks;}#pragma mark -#pragma mark 改變網頁樣式和行為///  改變背景顏色- (void)setBackgroundColor:(UIColor *)color{    NSString * jsString = [NSString stringWithFormat:@"document.body.style.backgroundColor = '%@'",[color webColorString]];    [self stringByEvaluatingJavaScriptFromString:jsString];}///  為所有圖片添加點擊事件(網頁中有些圖片添加無效,需要協議方法配合截取)- (void)addClickEventOnImg{    for (int i = 0; i < [self nodeCountOfTag:@"img"]; i++) {        //利用重定向獲取img.src,為區分,給url添加'img:'前綴        NSString *jsString = [NSString stringWithFormat:            @"document.getElementsByTagName('img')[%d].onclick = /              function() { document.location.href = 'img' + this.src; }",i];        [self stringByEvaluatingJavaScriptFromString:jsString];    }}///  改變所有圖像的寬度- (void) setImgWidth:(int)size{    for (int i = 0; i < [self nodeCountOfTag:@"img"]; i++) {        NSString *jsString = [NSString stringWithFormat:@"document.getElementsByTagName('img')[%d].width = '%d'", i, size];        [self stringByEvaluatingJavaScriptFromString:jsString];    }}///  改變所有圖像的高度- (void) setImgHeight:(int)size{    for (int i = 0; i < [self nodeCountOfTag:@"img"]; i++) {        NSString *jsString = [NSString stringWithFormat:@"document.getElementsByTagName('img')[%d].height = '%d'", i, size];        [self stringByEvaluatingJavaScriptFromString:jsString];    }}///  改變指定標簽的字體顏色- (void)setFontColor:(UIColor *)color withTag:(NSString *)tagName{    NSString *jsString = [NSString stringWithFormat:        @"var nodes = document.getElementsByTagName('%@'); /          for(var i=0;i<nodes.length;i++){/              nodes[i].style.color = '%@';}", tagName, [color webColorString]];    [self stringByEvaluatingJavaScriptFromString:jsString];}///  改變指定標簽的字體大小- (void)setFontSize:(int)size withTag:(NSString *)tagName{    NSString *jsString = [NSString stringWithFormat:        @"var nodes = document.getElementsByTagName('%@'); /          for(var i=0;i<nodes.length;i++){/              nodes[i].style.fontSize = '%dpx';}", tagName, size];    [self stringByEvaluatingJavaScriptFromString:jsString];}@end

 原文出處:http://blog.csdn.net/duzixi/article/details/36047201


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 日韩黄色片网站 | 最近免费观看高清韩国日本大全 | 亚洲精品久久久久久久久久久 | 国产午夜免费不卡精品理论片 | 女人裸体让男人桶全过程 | 海外中文字幕在线观看 | 欧美精品一区二区三区在线 | 亚洲射逼 | 福利在线免费 | www.91tv| 国产精品v片在线观看不卡 成人一区二区三区在线 | 免费啪视频在线观看 | 久久久青 | 欧美成人精品一区二区 | 伊人成人免费视频 | 欧美性生活视频免费 | 欧美精品激情在线 | 欧美视频99 | 日本黄色一级视频 | 91精品国产乱码久久久久久久久 | 精品少妇v888av | 黄色免费入口 | 成人影片在线免费观看 | 久久成人免费观看 | 亚洲亚色| 中文亚洲视频 | av日韩一区二区 | www.成人在线 | 久草手机在线观看视频 | 热久久91 | 免费99热在线观看 | 99麻豆久久久国产精品免费 | 亚洲成人在线视频网 | 成人黄色小视频在线观看 | 成年人在线视频 | 手机av免费电影 | 免费视频观看 | 国产久草视频在线 | 毛片三区 | 欧美一区二区三区中文字幕 | 国产成人精品二区 |