在html页面中判断本地app是否安装并打开

原创 2014年07月24日 12:43:26

html中其实是无法判断应用是否安装,除非在webview中通过js bridge,这里通过一种方式达到此目的。

1、编辑AndroidManifest.xml:

    主要是增加第二个<intent-filter>,myapp用来标识schema,最好能保证手机系统唯一,那样就可以打开应用,而不是弹出一个选择框。

    android:pathPrefix标识url的path,可以附带自己的数据通过string传递到activity,比如完整url为 myapp://xxx/openwith?data=mydata

          <activity
            android:name="com.abc.MainActivity"
            android:configChanges="orientation|keyboardHidden|navigation|screenSize"
            android:screenOrientation="landscape"
            android:theme="@android:style/Theme.NoTitleBar.Fullscreen" >
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
            <intent-filter>
                <action android:name="android.intent.action.VIEW" />
                <category android:name="android.intent.category.BROWSABLE" />
                <category android:name="android.intent.category.DEFAULT"/>
                <data android:scheme="myapp" android:pathPrefix="/xxx/openwith" />
            </intent-filter>
        </activity>
   然后通过activity获得data数据:

    public void onCreate(Bundle savedInstanceState) {
        Uri uridata = this.getIntent().getData();
        String mydata = uridata.getQueryParameter("data");
        ...
   }

  2、编写html页面:

   整个页面也许是某个app的详细介绍,这里只写出关键的js代码:

   function openApp() {

           if (/android/i.test(navigator.userAgent)) {
                var isrefresh = getUrlParam('refresh'); // 获得refresh参数
                if(isrefresh == 1) {
                    return
                }
                window.location.href = 'myapp://xxx/openwith?data=mydata';
                window.setTimeout(function () {
                        window.location.href += '&refresh=1' // 附加一个特殊参数,用来标识这次刷新不要再调用myapp:// 了
                }, 500);
            }

   }
  上面代码可以达到这样一个目的,先请求 myapp:// ,如果系统能处理,或者说已经安装了myapp表示的应用,那么就可以打开,另外,如果不能打开,直接刷新一下当前页面,等于是重置location。

  

Android H5判断是否安装app和唤起APP

H5中是无法直接判断应用是否安装的,但是可以间接判断。 第一种方式, if(...){ document.location = ''; setTimeout(function(){    //此处如果...
  • robertcpp
  • robertcpp
  • 2016年05月05日 18:35
  • 11175

HTML中判断手机是否安装某APP,跳转或下载该应用

手机浏览器下判断是否安装某app,并判断是否打开该应用 有些时候在做前端输出的时候,需要和app的做些对接工作。就是在手机浏览器中下载某app时,能判断该用户是否安装了该应用。如果安...
  • Bruce__Liu
  • Bruce__Liu
  • 2015年11月14日 10:04
  • 5677

js判断是否安装app,安装打开app

Title document.addEventListener('DOMContentLoaded', function () { document....
  • qq_26744901
  • qq_26744901
  • 2016年08月22日 18:23
  • 1617

浏览器判断是否安装APP

前段时间遇到一个小需求:要求在分享出来的h5页面中,有一个立即打开的按钮,如果本地安装了我们的app,那么点击就直接唤起本地app,如果没有安装,则跳转到下载。 因为从来没有做过这个需求,因此这注定...
  • henrywulibin
  • henrywulibin
  • 2016年08月01日 16:47
  • 11307

iOS-判断是否安装某个App并从另一个App中启动该App(未安装跳转到AppStore)

前言: 非越狱设备,在你的应用里无法知道系统安装了什么别的应用。  如果想要准确的通过程序控制和发现本地安装的应用,目前只能在破解版的ios 上开始显示,但是我们可以通过一些其他...
  • kashjack
  • kashjack
  • 2016年12月06日 15:13
  • 1213

手机浏览器下判断是否安装某app,并判断是否打开该应用

今天在做前端输出的时候,需要和app的做些对接工作。就是在手机浏览器中下载某app时,能判断该用户是否安装了该应用。如果安装了该应用,就直接打开该应用;如果没有安装该应用,就下载该应用。那么下面就对在...
  • pjk1129
  • pjk1129
  • 2015年04月10日 17:44
  • 25306

在html页面中判断本地app是否安装并打开

http://blog.csdn.net/vinrex/article/details/38082759 html中其实是无法判断应用是否安装,除非在webview中通过js bridge,这里...
  • tropicofcancer9
  • tropicofcancer9
  • 2017年07月10日 15:31
  • 222

iOS_如何判断是否安装某个App并从另一个App中启动该App(未安装跳转到AppStore)

前言: 非越狱设备,在你的应用里无法知道系统安装了什么别的应用。  如果想要准确的通过程序控制和发现本地安装的应用,目前只能在破解版的ios 上开始显示,但是我们可以通过一些其他...
  • Delegate_M
  • Delegate_M
  • 2016年04月27日 17:42
  • 4005

ionic开发——检测是否安装某APP,如果安装打开该APP

首先,我们需要安装cordova插件 cordova plugin add com.lampa.startapp //打开第三方APP cordova plugin add cordova-plu...
  • yu17310133443
  • yu17310133443
  • 2017年06月14日 09:46
  • 2038

点击页面判断是否安装app并打开,否则跳转app store的方法

常常有这样的场景,咱们开发出来的APP需要进行推广,比如在页面顶部来一张大Banner图片,亦或一张二维码。但往往我们都是直接给推广图片加了一个下载链接(App Store中的)。所以咱们来模拟一下用...
  • xyxjn
  • xyxjn
  • 2014年12月08日 16:40
  • 79077
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:在html页面中判断本地app是否安装并打开
举报原因:
原因补充:

(最多只允许输入30个字)