Html5跳转到APP指定页面的实现


Posted in HTML / CSS onJanuary 14, 2020

1.设置urlschemes

Html5跳转到APP指定页面的实现

urlschemes尽量设一个唯一的字符串,例如可以设为:iOS+公司英文名+ 项目工程名
比如我的设为iOSTencentTest,在浏览器中输入地址iOSTencentTest://即可跳转到我的app

2.跳转到指定页面

在使用iOSTencentTest://打开app会调用AppDelegate的代理方法

-(BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<UIApplicationOpenURLOptionsKey,id> *)options

跳转指定页面在该方法中操作
iOSTencentTest://后面是可以添加参数的,例如iOSTencentTest://goodsDetails?id=xxxxx
goodsDetails可直接通过url.host获取
id=xxxxx 参数可直接通过url.query获取
可以根据自身需求去设置不同的host和参数。

Html5跳转到APP指定页面的实现

h5那边只需要执行:

window.location.href = 'iOSTencentTest://goodsDetails?id=xxxxx'

附:

//获取Window当前显示的ViewController
- (UIViewController*)currentViewController{
    //获得当前活动窗口的根视图
    UIViewController* vc = [UIApplication sharedApplication].keyWindow.rootViewController;
    while (1)
    {
        //根据不同的页面切换方式,逐步取得最上层的viewController
        if ([vc isKindOfClass:[UITabBarController class]]) {
            vc = ((UITabBarController*)vc).selectedViewController;
        }
        if ([vc isKindOfClass:[UINavigationController class]]) {
            vc = ((UINavigationController*)vc).visibleViewController;
        }
        if (vc.presentedViewController) {
            vc = vc.presentedViewController;
        }else{
            break;
        }
    }
    return vc;
}
//NSString类别方法
//通过url.query获取参数字符 再分成字典 
-(NSMutableDictionary *)getURLParameters
{
    if (!self.length) {
        return nil;
    }
    NSMutableDictionary  *params = [NSMutableDictionary   dictionary];
    if ([self containsString:@"&"]) {
        NSArray *urlComponents = [self componentsSeparatedByString:@"&"];

        for(NSString *keyValuePair in urlComponents) {

            //生成key/value
            NSArray *pairComponents = [keyValuePair componentsSeparatedByString:@"="];
            NSString *key = [pairComponents.firstObject stringByRemovingPercentEncoding];
            NSString*value = [pairComponents.lastObject stringByRemovingPercentEncoding];

            //key不能为nil

            if(key==nil|| value ==nil) continue;

            id existValue = [params valueForKey:key];
            if(existValue !=nil) {
                //已存在的值,生成数组。
                if([existValue isKindOfClass:[NSArray class]]) {
                    //已存在的值生成数组
                    NSMutableArray*items = [NSMutableArray arrayWithArray:existValue];
                    [items addObject:value];
                    [params setValue:items forKey:key];
                }else{
                    //非数组
                    [params setValue:@[existValue,value]forKey:key];
                }

            }else{
                //设置值
                [params setValue:value forKey:key];
            }

        }
    }else {
        //单个参数生成key/value
        NSArray *pairComponents = [self componentsSeparatedByString:@"="];
        if(pairComponents.count==1) {
            return nil;
        }
        //分隔值
        NSString *key = [pairComponents.firstObject stringByRemovingPercentEncoding];
        NSString *value = [pairComponents.lastObject stringByRemovingPercentEncoding];
        //key不能为nil
        if(key ==nil|| value ==nil)return nil;
        //设置值
        [params setValue:value forKey:key];

    }
    return params;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
不同浏览器对CSS3和HTML5的支持状况
Oct 31 HTML / CSS
Web页面中八种创建多列等高(等高列布局)的实现技术
Dec 24 HTML / CSS
CSS3动画特效在活动页中的应用
Jan 21 HTML / CSS
css3实现圆锥渐变conic-gradient效果
Feb 12 HTML / CSS
详解css3使用transform出现字体模糊的解决办法
Oct 16 HTML / CSS
HTML5中FileReader接口使用方法实例详解
Aug 26 HTML / CSS
使用phonegap播放音频的实现方法
Mar 31 HTML / CSS
HTML5实现桌面通知 提示功能
Oct 11 HTML / CSS
利用Storage Event实现页面间通信的示例代码
Jul 26 HTML / CSS
HTML5实现移动端弹幕动画效果
Aug 01 HTML / CSS
canvas 基础之图像处理的使用
Apr 10 HTML / CSS
HTML5播放实现rtmp流直播
Jun 16 HTML / CSS
html5自动播放mov格式视频的实例代码
Jan 14 #HTML / CSS
html5响应式开发自动计算fontSize的方法
Jan 13 #HTML / CSS
html5 制作地图当前定位箭头的方法示例
Jan 10 #HTML / CSS
详解HTML5 Canvas标签及基本使用
Jan 10 #HTML / CSS
HTML5自定义mp3播放器源码
Jan 06 #HTML / CSS
html5 canvas手势解锁源码分享
Jan 07 #HTML / CSS
HTML5自定义视频播放器源码
Jan 06 #HTML / CSS
You might like
最贵的咖啡是怎么产生的,它的风味怎么样?
2021/03/04 新手入门
PHP的FTP学习(二)[转自奥索]
2006/10/09 PHP
php 保留字列表
2012/10/04 PHP
php实现的太平洋时间和北京时间互转的自定义函数分享
2014/08/19 PHP
php中文字符串截取方法实例总结
2014/09/30 PHP
php实现获取文件mime类型的方法
2015/02/11 PHP
浅析PHP 中move_uploaded_file 上传中文文件名失败
2019/04/17 PHP
如何让PHP编码更加好看利于阅读
2019/05/12 PHP
使用swoole 定时器变更超时未支付订单状态的解决方案
2019/07/24 PHP
Mozilla中显示textarea中选择的文字
2006/09/07 Javascript
Vue中封装input组件的实例详解
2017/10/17 Javascript
vue.js中created方法作用
2018/03/30 Javascript
JavaScript fetch接口案例解析
2018/08/30 Javascript
浅谈JavaScript节流和防抖函数
2020/08/25 Javascript
[49:59]KG vs Mineski 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/16 DOTA
python中使用smtplib和email模块发送邮件实例
2014/04/22 Python
简介Python中用于处理字符串的center()方法
2015/05/18 Python
Python利用带权重随机数解决抽奖和游戏爆装备问题
2016/06/16 Python
python数据结构之列表和元组的详解
2017/09/23 Python
python thrift搭建服务端和客户端测试程序
2018/01/17 Python
PyCharm鼠标右键不显示Run unittest的解决方法
2018/11/30 Python
Python箱型图绘制与特征值获取过程解析
2019/10/22 Python
Python Django框架模板渲染功能示例
2019/11/08 Python
Python脚本破解压缩文件口令实例教程(zipfile)
2020/06/14 Python
海淘母婴商城:国际妈咪
2016/07/23 全球购物
vue实现倒计时功能
2021/03/24 Vue.js
办加油卡单位介绍信
2014/01/09 职场文书
学年末自我鉴定
2014/01/21 职场文书
幼儿园大班毕业感言
2014/02/06 职场文书
财务部副经理岗位职责
2014/03/14 职场文书
计算机毕业生自荐信范文
2014/03/23 职场文书
课题研究阶段性总结
2015/08/13 职场文书
最新农村养殖致富:资金投入较低的创业项目有哪些?
2019/09/26 职场文书
Nginx已编译的nginx-添加新模块
2021/04/01 Servers
CSS 一行代码实现头像与国旗的融合
2021/10/24 HTML / CSS
windows server2012 R2下安装PaddleOCR服务的的详细步骤
2022/09/23 Servers