通过超链接打开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应用的更多相关文章
- Android应用安全开发之浅谈网页打开APP
一.网页打开APP简介 Android有一个特性,可以通过点击网页内的某个链接打开APP,或者在其他APP中通过点击某个链接打开另外一个APP(AppLink),一些用户量比较大的APP,已经通过发布 ...
- 微信扫描打开APP下载链接提示代码优化
上一次我发了一篇文章叫“微信打开网址添加在浏览器中打开提示”,里面我发出来了三个代码,分别是纯JS.js+html.jQuery+HTML代码.今天来一个简化版带可以关闭的按钮操作.使用的是纯JS+H ...
- 微信扫描打开APP下载链接提示代码优化(转)
上一次我发了一篇文章叫“微信打开网址添加在浏览器中打开提示”,里面我发出来了三个代码,分别是纯JS.js+html.jQuery+HTML代码.今天来一个简化版带可以关闭的按钮操作.使用的是纯JS+H ...
- 使用扫描二维码打开app
应该不少人遇到过这种需求,扫描二维码打开app如果用户没有这个app则提示它跳转. 用网页直接来调用app是不打可能的,必须原生那边先做一些配置. 首先,安卓和苹果的调用方法是不同的. 所以我们需要先 ...
- 实现微信浏览器内打开App Store链接(已被和谐,失效了)
微信浏览器是不支持打开App Store 页面的,不知道微信为什么这么做.比如你页面写 <a href=”http://itunes.apple.com/us/app/id399608199″& ...
- h5分享页面打开APP
项目中 直播app分享出来的直播h5页面 点击进入按钮:已下载app 就进入app,未下载跳转到下载页面 判断是安卓还是ios var u = navigator.userAgent; var isA ...
- Android按下home键后重新打开app进入主activity的问题
问题阐述: 当我们写一款App的时候,势必会有这种情况:用户已经进行了多级的操作,现返回栈中已存在多个activity,那么这个时候我们想回到最初的activity难道要一层层的返回吗,对用户来说 无 ...
- 手机浏览网页或打开App时莫名弹出支付宝领红包界面的原因及应对措施
自从支付宝推出扫码领红包活动后,这种模式独特的赏金机制,短时间内吸引了大量的关注,但是随之也产生了很多的问题,比由于如在赏金的驱动下,微信群里铺天盖地的红包口令,朋友圈里各式各样的领红包二维码图片, ...
- Android 网页打开app(或者打开指定页面)并且接收参数
网页打开app 现实描述场景: 1.短信通知中通知内容,比如信息中一个咨询详情,流程步骤,信息中的地址打开的是一个网页,网页打开就指定app或者app中的指定页面 html代码 <html> ...
随机推荐
- 用Eclipse+xdebug调试PHP总是在首行自动断点解决方法
问题描述: 使用Eclipse+PDT+xdebug调试PHP程序时,总是在程序的第一行(首行)自动断点,不方便调试. 解决方法: 分别在下面3个位置配置,取消 Break at First Line ...
- 在后台CS文件里面,隐藏和显示Repeater里面控件
<asp:Repeater ID="Repeater1" runat="server"><ItemTemplate><asp:Pa ...
- Delphi 类方法和普通方法的区别 .
//类声明 TMyClass = class public class procedure MyProc; //类方式 constructor Create; //Crea ...
- 读懂IL代码(三)
由于要写毕业论文的缘故,最近比较没有时间写,总是要抽出时间抽出时间.诶,这样的生活比较烦躁. 这一篇主要写委托.类.方法的IL代码,一一来说明. 委托:搞过C#的都应该清楚,委托实际上是一个类.编译器 ...
- Spring Security Encryption三种加密方式
Encryption One-way encryption 单项加密,客户端将要传递的值先加密(使用特定的加密方法),将原值和加密好的值传递过去,服务器端将原始数据也进行一次加密(两者加密 ...
- a-b(高精度)
我现在已经是才语言中的一员了,我在此献上今日的佳作——a-b(高精度),以下是我的程序及其注释,欢迎各位来观赏,耶! 程序: #include<stdio.h> #include<s ...
- 【POJ1707】【伯努利数】Sum of powers
Description A young schoolboy would like to calculate the sum for some fixed natural k and different ...
- angularJs 页面筛选标签小功能
页面html: <div class="bar bar-calm bar-header"> <div class="title">新闻分 ...
- ASP.NET前台JS与后台CS函数如何互相调用
摘要: 在实际的Web开发中,我们可能会常常遇到后台调用前台JS代码或者前台JS调用后台代码的情况.今天就把比较实用的前后台相互调用的方法总结出来和大家分享. 在实际的Web开发中,我们可能会常常遇到 ...
- dotnet core 开发体验之Routing
开始 回顾上一篇文章:dotnet core开发体验之开始MVC 里面体验了一把mvc,然后我们知道了aspnet mvc是靠Routing来驱动起来的,所以感觉需要研究一下Routing是什么鬼. ...