URL schemes, 通过超链接打开App应用

var mobileAppInstall = (function () {
var ua = navigator.userAgent,
loadIframe,
win = window,
isIPad = ua.match(/iPad/i) != null,
isIphone = !isIPad && ((ua.match(/iPhone/i) != null) || (navigator.userAgent.match(/iPod/i) != null)),
isIOS = isIPad || isIphone,
isAndroid = !isIOS && ua.match(/android/i) != null,
isMobile = isIOS || isAndroid; function getIntentIframe() {
if (!loadIframe) {
var iframe = document.createElement("iframe");
iframe.style.cssText = "display:none;width:0px;height:0px;";
document.body.appendChild(iframe);
loadIframe = iframe;
}
return loadIframe;
}
function getPlayUrl(iVideoID, sLy) {
var videoplayURL = iVideoID == "" ? "" : "http://m.video.baomihua.com/m/" + iVideoID;
videoplayURL = videoplayURL == "" ? "" : videoplayURL + (sLy == "" ? "" : "_ly=" + sLy);
return videoplayURL;
}
var appInstall = {
isChrome: ua.match(/Chrome\/([\d.]+)/) || ua.match(/CriOS\/([\d.]+)/),
isAndroid: ua.match(/(Android);?[\s\/]+([\d.]+)?/),
isWeixin: ua.match(/MicroMessenger/i) != null,
isUC: ua.match(/UCBrowser/i) != null,
timeout: 500,
/**
* 尝试跳转appurl,如果跳转失败,进入h5url
* @param {Object} appurl 应用地址
* @param {Object} chromeurl 应用地址
* @param {Object} h5url http地址
*/
open: function (appurl, chromeurl, h5url) {
var t = Date.now();
appInstall.openApp(appurl);
setTimeout(function () {
if (Date.now() - t < appInstall.timeout * 2 + 100) {
h5url && appInstall.openH5(h5url);
}
}, appInstall.timeout) },
openApp: function (appurl) {
if (appInstall.isChrome) {
if (appInstall.isAndroid) {
win.location.href = chromeurl;
} else {
win.location.href = appurl;
}
} else {
getIntentIframe().src = appurl;
}
},
openH5: function (h5url) {
win.location.href = h5url;
},
playvideo: function (ivideoid, ichannelid, sLy) {
var videoplayURL = getPlayUrl(ivideoid, sLy);
if (sLy == "uc" || sLy == "bdqyy") {
window.location = videoplayURL;
return;
}
if (!isAndroid || appInstall.isWeixin || appInstall.isUC) {
window.location = videoplayURL;
return;
} appurl = getAndroidAppUrl(ichannelid, ivideoid, sLy);
chromeurl = getChromeIntent(ichannelid, ivideoid, sLy);
var sRedirect = getDownLoadURL(ichannelid, ivideoid, sLy);
mobileAppInstall.open(appurl, chromeurl, sRedirect);
}
} return appInstall;
function getDownLoadURL(iChannelid, iVideoid, sLy) {
var downloadUrl = "http://m.video.baomihua.com/play2/player/dlVideoApp.htm?videoid=" + iVideoid;
downloadUrl = downloadUrl + (iChannelid == "" ? "" : "&channelid=" + iChannelid);
downloadUrl = downloadUrl + (sLy == "" ? "" : "&ly=" + sLy);
return downloadUrl;
}
function getAndroidAppUrl(iChannelid, iVideoid, sLy) {
var dl = "pmhapp://video.view/play";
switch (parseInt(iChannelid)) {
case 13:
dl = "pmhapp://video.view/play";
break;
case 3:
dl = "pmhapp://video.view/play";
break;
case 55:
dl = "pmhgcw://video.view/play";
break;
default:
dl = "pmhapp://video.view/play";
break;
}
return dl + "?id=" + iVideoid + (sLy ? "&ly=" + sLy : "");
}
function getChromeIntent(iChannelid, iVideoid, iLy) {
// 根据自己的产品修改吧
var dl = "intent://video.view/play?id=" + iVideoid + (iLy ? "&ly=" + iLy : "") + "#Intent;scheme=pmhapp;package=com.com.baomihuawang.androidclient;end";
switch (parseInt(iChannelid)) {
case 13:
dl = "intent://video.view/play?id=" + iVideoid + (iLy ? "&ly=" + iLy : "") + "#Intent;scheme=pmhapp;package=com.com.baomihuawang.androidclient;end";
break;
case 3:
dl = "intent://video.view/play?id=" + iVideoid + (iLy ? "&ly=" + iLy : "") + "#Intent;scheme=pmhapp;package=com.com.baomihuawang.androidclient;end";
break;
case 55:
dl = "intent://video.view/play?id=" + iVideoid + (iLy ? "&ly=" + iLy : "") + "#Intent;scheme=pmhgcw;package=com.com.baomihuawang.androidclient;end";
break;
default:
dl = "intent://video.view/play?id=" + iVideoid + (iLy ? "&ly=" + iLy : "") + "#Intent;scheme=pmhapp;package=com.com.baomihuawang.androidclient;end";
}
return dl;
}
})();
<a class="link" href="javascript:mobileAppInstall.playvideo(35846544,8,'');"></a>

通过超链接打开App应用的更多相关文章

  1. Android应用安全开发之浅谈网页打开APP

    一.网页打开APP简介 Android有一个特性,可以通过点击网页内的某个链接打开APP,或者在其他APP中通过点击某个链接打开另外一个APP(AppLink),一些用户量比较大的APP,已经通过发布 ...

  2. 微信扫描打开APP下载链接提示代码优化

    上一次我发了一篇文章叫“微信打开网址添加在浏览器中打开提示”,里面我发出来了三个代码,分别是纯JS.js+html.jQuery+HTML代码.今天来一个简化版带可以关闭的按钮操作.使用的是纯JS+H ...

  3. 微信扫描打开APP下载链接提示代码优化(转)

    上一次我发了一篇文章叫“微信打开网址添加在浏览器中打开提示”,里面我发出来了三个代码,分别是纯JS.js+html.jQuery+HTML代码.今天来一个简化版带可以关闭的按钮操作.使用的是纯JS+H ...

  4. 使用扫描二维码打开app

    应该不少人遇到过这种需求,扫描二维码打开app如果用户没有这个app则提示它跳转. 用网页直接来调用app是不打可能的,必须原生那边先做一些配置. 首先,安卓和苹果的调用方法是不同的. 所以我们需要先 ...

  5. 实现微信浏览器内打开App Store链接(已被和谐,失效了)

    微信浏览器是不支持打开App Store 页面的,不知道微信为什么这么做.比如你页面写 <a href=”http://itunes.apple.com/us/app/id399608199″& ...

  6. h5分享页面打开APP

    项目中 直播app分享出来的直播h5页面 点击进入按钮:已下载app 就进入app,未下载跳转到下载页面 判断是安卓还是ios var u = navigator.userAgent; var isA ...

  7. Android按下home键后重新打开app进入主activity的问题

    问题阐述: 当我们写一款App的时候,势必会有这种情况:用户已经进行了多级的操作,现返回栈中已存在多个activity,那么这个时候我们想回到最初的activity难道要一层层的返回吗,对用户来说 无 ...

  8. 手机浏览网页或打开App时莫名弹出支付宝领红包界面的原因及应对措施

    自从支付宝推出扫码领红包活动后,这种模式独特的赏金机制,短时间内吸引了大量的关注,但是随之也产生了很多的问题,比由于如在赏金的驱动下,微信群里铺天盖地的红包口令,朋友圈里各式各样的领红包二维码图片, ...

  9. Android 网页打开app(或者打开指定页面)并且接收参数

    网页打开app 现实描述场景: 1.短信通知中通知内容,比如信息中一个咨询详情,流程步骤,信息中的地址打开的是一个网页,网页打开就指定app或者app中的指定页面 html代码 <html> ...

随机推荐

  1. 用Eclipse+xdebug调试PHP总是在首行自动断点解决方法

    问题描述: 使用Eclipse+PDT+xdebug调试PHP程序时,总是在程序的第一行(首行)自动断点,不方便调试. 解决方法: 分别在下面3个位置配置,取消 Break at First Line ...

  2. 在后台CS文件里面,隐藏和显示Repeater里面控件

    <asp:Repeater ID="Repeater1" runat="server"><ItemTemplate><asp:Pa ...

  3. Delphi 类方法和普通方法的区别 .

    //类声明  TMyClass = class  public    class procedure MyProc;  //类方式    constructor Create;      //Crea ...

  4. 读懂IL代码(三)

    由于要写毕业论文的缘故,最近比较没有时间写,总是要抽出时间抽出时间.诶,这样的生活比较烦躁. 这一篇主要写委托.类.方法的IL代码,一一来说明. 委托:搞过C#的都应该清楚,委托实际上是一个类.编译器 ...

  5. Spring Security Encryption三种加密方式

    Encryption One-way encryption       单项加密,客户端将要传递的值先加密(使用特定的加密方法),将原值和加密好的值传递过去,服务器端将原始数据也进行一次加密(两者加密 ...

  6. a-b(高精度)

    我现在已经是才语言中的一员了,我在此献上今日的佳作——a-b(高精度),以下是我的程序及其注释,欢迎各位来观赏,耶! 程序: #include<stdio.h> #include<s ...

  7. 【POJ1707】【伯努利数】Sum of powers

    Description A young schoolboy would like to calculate the sum for some fixed natural k and different ...

  8. angularJs 页面筛选标签小功能

    页面html: <div class="bar bar-calm bar-header"> <div class="title">新闻分 ...

  9. ASP.NET前台JS与后台CS函数如何互相调用

    摘要: 在实际的Web开发中,我们可能会常常遇到后台调用前台JS代码或者前台JS调用后台代码的情况.今天就把比较实用的前后台相互调用的方法总结出来和大家分享. 在实际的Web开发中,我们可能会常常遇到 ...

  10. dotnet core 开发体验之Routing

    开始 回顾上一篇文章:dotnet core开发体验之开始MVC 里面体验了一把mvc,然后我们知道了aspnet mvc是靠Routing来驱动起来的,所以感觉需要研究一下Routing是什么鬼. ...