gh-qqnews-downapp v1.0.3
腾讯系打开和下载 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 地址时直接进行跳转 |
packageName | APP 的包名 | - |
downloadUrl | Android 系统里 APP 的下载地址 | - |
appleStoreId | iOS 系统里跳转到 app store 的 ID | - |
appName | Android 微信的中间下载页展示的标题 | - |
downLogo | Android 微信的中间下载页展示的 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
表示未安装。
同时,有几个额外的情况要明确下:
- 不在白名单中的 APP,使用当前方法检测,会直接返回
false
,不论当前设备是否已安装了 APP; - 浏览器中,默认返回 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
4 years ago