1.0.3 • Published 4 years ago

gh-qqnews-downapp v1.0.3

Weekly downloads
3
License
ISC
Repository
-
Last release
4 years ago

腾讯系打开和下载 APP

在微信,手机 QQ,腾讯视频等各种 APP 中的网页,能检测本地是否有安装 app,若已安装则打开 app,若未安装,则按指定的地址进行下载。

请注意:当前功能只能在*.qq.com域名的网页中使用,其他域名调用当前模块是没有效果的

demo 页面地址:https://news.qq.com/FERD/tool/downapp-demo.htm ,当前链接可在微信、手 Q、腾讯新闻、新闻极速版、QQ 音乐和浏览器中打开测试!

安装

使用 tnpm:

$ tnpm install tencent-downapp --save

使用 npm:

$ npm install tencent-downapp --save

使用 bower:

$ bower install tencent-downapp

使用 yarn:

$ yarn add tencent-downapp

使用 jsDelivr 的 CDN 地址:

<script src="https://cdn.jsdelivr.net/npm/tencent-downapp@1.0.0/dist/index.js"></script>

使用 unpkg 的 CDN 地址:

<script src="https://unpkg.com/tencent-downapp@1.0.0/dist/index.js"></script>

使用

使用方法,以 ES2015 的方式为例:

import AppDownload from "tencent-downapp";

var downapp = new AppDownload({
    openUrl: "qqnews://article_9527?nm=RSS2018061501588400",
    packageName: "com.tencent.news",
    downloadUrl: "http://dldir1.qq.com/dlomg/inews/channel/TencentNews_3932.apk",
    wxAppId: "wx073f4a4daff0abe8",
    appleStoreId: "399363156",
    appName: "腾讯新闻--百万现金红包派发中...",
    downLogo: "http://mat1.gtimg.com/news/news/logo.png",
});

// 监听是否开始下载
downapp.on("downloadStart", function () {
    // 开始下载
    alert("开始下载");
});

// 获取APP的安装状态
downapp.checkAppIsInstalled(function (status) {
    if (status) {
        document.querySelector(".btn").innerText = "打开新闻客户端";
    }
});

document.querySelector(".btn").addEventListener("click", function () {
    downapp.run();
});

参数和方法的说明

1. 参数

以下参数均为必填参数

名称说明备注
openUrl打开地址可以是 scheme 地址或者 http 地址,http 地址时直接进行跳转
packageNameAPP 的包名-
downloadUrlAndroid 系统里 APP 的下载地址-
appleStoreIdiOS 系统里跳转到 app store 的 ID-
appNameAndroid 微信的中间下载页展示的标题-
downLogoAndroid 微信的中间下载页展示的 logo-
title可选-
wxAppId在微信公众号注册的 ID,打开时能显示要打开 APP 的名称-

2. 可监听的事件:

2.1 downloadStart

Android 下开始安装时触发

// 开始下载时触发
downapp.on("downloadStart", function () {
    // 开始下载
    alert("开始下载");
});

2.2 downloadSteps

在下载过程中执行,目前仅在 Android 版的手机 QQ 和腾讯视频里支持进度展示;iOS 里会自动跳转到 app store 里下载,无法监听到进度

// 下载过程中
downapp.on("downloadSteps", function (step) {
    // step为当前的进度,取值0-100
    console.log(step);
});

2.3 cancel

Android 版微信的下载中间页里,点击左上角的返回按钮取消下载

// 点击左上角返回
downapp.on("cancel", function () {
    alert("返回啦");
});

2.4 removed

Android 版微信的下载中间页里,已经开始下载,然后点击“取消下载”触发

// 取消下载
downapp.on("removed", function () {
    alert("取消下载");
});

3. 方法

3.1 checkAppIsInstalled

checkAppIsInstalled 的回调函数里,会返回一个 boolean 类型的数据,表示要检测 APP 的安装状态:true表示已安装, false表示未安装。

同时,有几个额外的情况要明确下:

  1. 不在白名单中的 APP,使用当前方法检测,会直接返回false,不论当前设备是否已安装了 APP;
  2. 浏览器中,默认返回 false!
// 获取APP的安装状态
downapp.checkAppIsInstalled(function (isInstalled) {
    if (isInstalled) {
        alert("已安装");
    } else {
        alert("未安装");
    }
});

并且支持 Promise 类型:

async function AA() {
    let isInstalled = await downapp.checkAppIsInstalled();
    console.log(isInstalled);
}

3.2 run

调用run()方法后,若本设备已安装 APP,则直接打开指定的 openUrl;若未安装,则执行下载动作。当前方法不传参时,则打开初始化配置的 openUrl;否则打开传入的链接地址。

在打开未检测到安装状态的 APP 时,思路是首先尝试去拉起 APP,然后延迟下载。当拉起失败时,则执行到下载操作。在有时候操作过程中,会偶现明明已经拉起了客户端,但比如 QQ、浏览器中依然跳转到了下载的步骤!说明定时器没有被及时地清理!

document.querySelector(".btn").addEventListener("click", function () {
    downapp.run(); // 打开
});

document.querySelector(".btn").addEventListener("click", function () {
    downapp.run("qqnews://article_9527?nm=20190307A0WEXN00"); // 打开
});

3.3 openApp

只打开或尝试打开 APP,打开失败时,没有任何后续的操作。使用方式与run()方法一样,既可以传入参数,也可以不传!

在微信中打开时,若成功打开,则返回Promise.resolve的结果;若没有要打开的 APP,则会返回Promise.reject;

document.querySelector(".btn").addEventListener("click", function () {
    downapp.openApp(); // 打开
});

document.querySelector(".btn").addEventListener("click", function () {
    downapp.openApp("qqnews://article_9527?nm=20190307A0WEXN00"); // 打开
});

3.4 download

只下载初始化时配置的 APP,该方法无参数!

// 下载
document.querySelector(".btn").addEventListener("click", function () {
    downapp.download();
});

3.5 getNetworkType

获取网络的状态,type 有 3 个返回值:

  • none: 无连接;
  • wifi: wifi 状态
  • wwan: 流量状态
// 回调函数的方式
downapp.getNetworkType(function (type) {
    alert(type);
});

// Promise的方式
downapp.getNetworkType().then((type) => {
    alert(type);
});

可能会出现的问题

在使用这个 js 文件过程中,有可能会曲线下面的几个问题:

4.1 在微信或 QQ 中,没有任何反应

答: 请确认您项目当前的域名为*.qq.com

4.2 微信中正常,QQ 中不能正常的打开或下载

答: QQ 中有一些特殊的 api 属于敏感 jsapi,需要将域名加入到他们的白名单中,才可以正常的使用

changelog

CHANGELOG