IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> IOS开发之——彩票-帮助(11) -> 正文阅读

[移动开发]IOS开发之——彩票-帮助(11)

一 概述

  • 设置页面点击帮助,跳转帮助TableViewController页面
  • 点击帮助列表中的每一项,打开WebView显示具体信息

二 设置页面点击帮助,跳转帮助TableViewController页面

2.1 页面结构及功能分析

  • 帮助页面是一个列表,构建ILHelpViewController继承ILBaseTableViewController
  • 列表数据从Data下的help.json中获取,构建ILHtml Model存储help中的列表项
  • 重写tableView的didSelectRowAtIndexPath方法,ILHtmlViewController的view(WebView)展示信息
  • ILHtmlViewController中多个信息在同一个页面需要跳转时,使用window.location.href跳转id的指定位置

三 设置页面点击帮助,跳转帮助ableViewController页面

3.1 ILHtml(help.json)Model

ILHtml.h

#import <Foundation/Foundation.h>

@interface ILHtml : NSObject
@property(nonatomic,copy) NSString *title;
@property(nonatomic,copy) NSString *ID;
@property(nonatomic,copy) NSString *html;

+(instancetype)htmlWithDict:(NSDictionary *)dict;

@end

ILHtml.m

#import "ILHtml.h"

@implementation ILHtml

+ (instancetype)htmlWithDict:(NSDictionary *)dict
{
    ILHtml *html=[[ILHtml alloc]init];
    
    html.title=dict[@"title"];
    html.ID=dict[@"id"];
    html.html=dict[@"html"];
    return html;
}
@end

3.2 ILHelpViewController(帮助页面)

#import "ILHelpViewController.h"
#import "ILSettingItem.h"
#import "ILSettingGroup.h"
#import "ILSettingCell.h"
#import "ILSettingArrowItem.h"
#import "ILSettingSwitchItem.h"
#import "ILScoreNoticeViewController.h"
#import "ILHtml.h"
#import "ILHtmlViewController.h"
#import "ILUINavigationController.h"


@interface ILHelpViewController ()
//存储help.json
@property (nonatomic,strong) NSMutableArray *htmls;

@end

@implementation ILHelpViewController

-(NSMutableArray *)htmls
{
    if (_htmls==nil) {
        _htmls=[NSMutableArray array];
        
        NSString *fileName=[[NSBundle mainBundle]pathForResource:@"MyResource/Data/help.json" ofType:nil];
        NSData *data=[NSData dataWithContentsOfFile:fileName];
        NSArray *jsonArr=[NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingAllowFragments error:nil];

        for (NSDictionary *dict in jsonArr) {
            ILHtml *html=[ILHtml htmlWithDict:dict];
            [_htmls addObject:html];
        }
    }
    return _htmls;
}

- (void)viewDidLoad {
    [super viewDidLoad];
    [self addGroup0];

}
-(void)addGroup0
{
    //第0组
//    ILSettingItem *item1=[ILSettingArrowItem itemWithIcon:nil title:@"如何领奖?" destVcClass:nil];
//    ILSettingItem *item2=[ILSettingArrowItem itemWithIcon:nil title:@"如何充值?"];
//    ILSettingItem *item3=[ILSettingArrowItem itemWithIcon:nil title:@"如何提现?"];
//    ILSettingItem *item4=[ILSettingArrowItem itemWithIcon:nil title:@"如何购彩?"];
//    ILSettingItem *item5=[ILSettingArrowItem itemWithIcon:nil title:@"如何连续多期购买?"];
//
//    ILSettingGroup *group0=[[ILSettingGroup alloc]init];
//    group0.items=@[item1,item2,item3,item4,item5];
//    group0.header=@"标题头部-1";
//    group0.footer=@"标题尾部-1";
//
//    [self.dataList addObject:group0];
    
    NSMutableArray *items=[NSMutableArray array];
    //遍历模型
    for(ILHtml *html in self.htmls)
    {
        ILSettingArrowItem *item=[ILSettingArrowItem itemWithIcon:nil title:html.title destVcClass:nil];
        [items addObject:item];
        
    }
    ILSettingGroup *group0=[[ILSettingGroup alloc]init];
    group0.items=items;
    [self.dataList addObject:group0];

}

//重写tableView的点击跳转
-(void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath
{
    
    //取出每一行对应的Html模型
    ILHtml *html=self.htmls[indexPath.row];
    ILHtmlViewController *htmlVc=[[ILHtmlViewController alloc]init];
    htmlVc.html=html;
    htmlVc.title=html.title;
    
    ILUINavigationController *nav=[[ILUINavigationController alloc]initWithRootViewController:htmlVc];
    
    [self presentViewController:nav animated:YES completion:nil];
}

@end

说明:

  • 跳转时使用ILUINavigationController,已经定义好了标题颜色和样式
  • ILUINavigationController通过initWithRootViewController关联ILHtmlViewController

四 点击帮助列表中的每一项,打开WebView显示具体信息

4.1 ILHtmlViewController.h

#import <UIKit/UIKit.h>
@class ILHtml;
@interface ILHtmlViewController : UIViewController
@property(nonatomic,strong) ILHtml *html;

@end

4.2 ILHtmlViewController.m

#import "ILHtmlViewController.h"
#import "ILHtml.h"
@interface ILHtmlViewController ()<UIWebViewDelegate>

@end

@implementation ILHtmlViewController

-(void)loadView
{
    self.view=[[UIWebView alloc]init];
}
- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view.
    self.view.backgroundColor=[UIColor whiteColor];
    
    UIBarButtonItem *cancle=[[UIBarButtonItem alloc]initWithTitle:@"取消" style:UIBarButtonItemStyleBordered target:self action:@selector(cancel)];
    
    self.navigationItem.leftBarButtonItem=cancle;
    
    UIWebView *webView=(UIWebView *)self.view;
    NSURL *url=[[NSBundle mainBundle]URLForResource:[NSString stringWithFormat:@"MyResource/Html/%@",_html.html] withExtension:nil];
    NSURLRequest *request=[NSURLRequest requestWithURL:url];
    webView.delegate=self;
    [webView loadRequest:request];
}

-(void)cancel
{
    //回到上一个控制器
    [self dismissViewControllerAnimated:YES completion:nil];
}
-(void)webViewDidFinishLoad:(UIWebView *)webView
{
    NSString *js=[NSString stringWithFormat:@"window.location.href='#%@';",_html.ID];
    [webView stringByEvaluatingJavaScriptFromString:js];
}
@end

五 效果图

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2022-02-14 21:17:24  更:2022-02-14 21:19:52 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 14:56:23-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码