国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > HTML5 > 正文

h5頁面喚起app如果沒安裝就跳轉下載(iOS和Android)

2024-09-05 07:23:32
字體:
來源:轉載
供稿:網友

h5頁面喚起app如果沒安裝就跳轉下載(iOS和Android)

瀏覽器和app沒有通信協議,所以h5不知道用戶的手機釋放安裝了app。因此只能是h5去嘗試喚起app,若不能喚起,引導用戶去下載我們的app。

微信里屏蔽了 schema 協議,如果在微信中打開h5,則會提示用戶在瀏覽器中打開。<!doctype html>

<html><head><title></title><meta charset="utf-8"><meta content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no;" name="viewport" /> <script>     // 檢查是否安裝app    function openApp(e){        var u = window.navigator.userAgent;        var isAndroid = u.indexOf('Android') > -1 || u.indexOf('Linux') > -1; //android終端或者uc瀏覽器        var isiOS = !!u.match(//(i[^;]+;( U;)? CPU.+Mac OS X/);        if(isAndroid){            android();        }        if(isiOS){            ios();        }    }    function android(){        var _clickTime = new Date().getTime();        window.location.href = '??????????????????'; /***打開app的協議,有安卓同事提供***/             //啟動間隔20ms運行的定時器,并檢測累計消耗時間是否超過3000ms,超過則結束        var _count = 0, intHandle;        intHandle = setInterval(function(){            _count++;            var elsTime = new Date().getTime() - _clickTime;            if (_count>=100 || elsTime > 3000 ) {                console.log(_count)                console.log(elsTime)                clearInterval(intHandle);                //檢查app是否打開                if ( document.hidden || document.webkitHidden) {                    // 打開了                    window.close();                } else {                    // 沒打開                    alert('沒打開')                    // window.location.href = "??????????????";//下載鏈接                }            }        }, 20);     }     function ios(){        var _clickTime = +(new Date());        var ifr = document.createElement("iframe");        ifr.src = "??????????????"; /***打開app的協議,有ios同事提供***/        ifr.style.display = "none";        document.body.appendChild(ifr);        //啟動間隔20ms運行的定時器,并檢測累計消耗時間是否超過3000ms,超過則結束        var _count = 0, intHandle;        intHandle = setInterval(function(){            _count++;            var elsTime =  +(new Date()) - _clickTime;            console.log(_count,elsTime,+(new Date()),_clickTime)            if (_count>=100 || elsTime > 3000 ) {                clearInterval(intHandle);                document.body.removeChild(ifr);                //檢查app是否打開                if ( document.hidden || document.webkitHidden) {                    // 打開了                    window.close();                } else {                    // 沒打開                    alert('沒打開')                    // window.location.href = "???????????????";//下載鏈接                }            }        },20);    }     var objbtn=document.getElementById('btn');    objbtn.onclick=function(){        openApp()    } </script></head> <body style="background-color: #fff;" >     <!--測試app調起-->    <div id="btn" style="font-size: 40px;background: blue;color: #fff;height: 56px;text-align: center;">btn</div>    <!--測試app調起over-->     </body></html>  

重要的是 安裝了app打開app,但是 不能讓用戶在點擊確定的時候,跳轉到下載頁。

沒安裝app的用戶,不能等待太久,還不到app下載頁。

若通過url scheme 打開app成功,那么當前h5會進入后臺,通過計時器會有明顯延遲。利用時間來判斷。

由于安卓手機,頁面進入后臺,定時器setTimeout仍會不斷運行,所以這里使用setInterval,較小間隔時間重復多次。來根據累計時間判斷。

document.hidden對大于4.4webview支持很好,為頁面可見性api。

ios

window.location.href='rtjr://app.rongtuojinrong.com?flag=23&pid={$pid}';

js無法調起 這種協議的url

<a  href="rtjr://app.rongtuojinrong.com?flag=23&pid={$pid}" ></a>

只能用 a標簽,或者 iframe

到此這篇關于h5頁面喚起app如果沒安裝就跳轉下載(iOS和Android)的文章就介紹到這了,更多相關h5頁面喚起app內容請搜索武林網以前的文章或繼續瀏覽下面的相關文章,希望大家以后多多支持武林網!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 微山县| 潍坊市| 申扎县| 十堰市| 银川市| 农安县| 万载县| 博爱县| 会宁县| 西城区| 方城县| 外汇| 蕉岭县| 公主岭市| 高要市| 独山县| 青海省| 大港区| 隆德县| 山阳县| 奇台县| 金阳县| 香格里拉县| 高州市| 扬中市| 石台县| 大名县| 延川县| 南乐县| 杭锦旗| 成安县| 平舆县| 平罗县| 军事| 乌审旗| 萝北县| 西青区| 新津县| 呈贡县| 交口县| 旬阳县|