如果您是想讓js來實現web app桌面提示消息數量那就是不可能的了...沒許可權。但是如果您只是想做這內個效果容那就簡單了
<divstyle="position:relitive;width:60px;height:60px;border-radius:8px;background-color:#ddd;"><pstyle="posotion:absolute;top:-5px;right:-5px;width:10px;height:10px;background-color:#f00;color:#fff;line-height:10px;border-radius:10px;">1</p>
</div>
2. Js如何調用本地應用程序
一般情況下,瀏覽器中是無法直接和本機的其他的程序進行交互的,在IE中,我們可以通過ActiveX對象的方式進行。但是這個方式只適用於IE瀏覽器,另一種比較通用的方式便是URL協議的方式,我們將某種URL的協議注冊給某個程序來進行處理,比如將tencent://這樣的協議注冊給QQ程序來進行處理,當瀏覽器需要訪問這樣的協議的時候就轉給QQ程序進行處理。這種URL協議的方式是可以跨平台的,比如在Windows上你需要添加註冊表項。
首先先看看js應該如何調用qq客戶端。
window .open(" tencent://message/?uin=346915968 ")
window.open顧名思義,打開。Tencent就不用多說了吧 BAT之T。上述能直接打開qq帳號對應的對話框。由此可以知道網頁上的在線客服功能是如何實現了吧。
那要是不需要打開對話框,就想要登陸qq應該如何實現呢?很簡單呀:
window .open(" tencent://message/?uin=qq ") 不過調用應用這種跟黑客沒什麼差別的行為,瀏覽器一般都是禁止的,
選擇允許後,
啟動應用,qq客戶端就會被調起。
為什麼說這個呢,老闆又給了個需求,想讓調起qq客戶端一樣,想通過演示頁面的一個按鈕,調起售票系統的各種程序...
什麼都不說了,先看看什麼是自定義協議。
Pluggable Protocol,又叫URL Protocol,有時會叫Shell命令,通用的Protocol有http、ftp、mailto等,這些都是windows安裝時自帶的協議。
接著也實現一個簡單的自己的自定義協議吧。
1,運行window,輸入regedit打開注冊表。 在HKEY_CLASSES_ROOT下面建一個自己起的名字的表。
用如下格式把各項值添上:
js打開qq音樂.exe
啟動應用
end.
3. autojs模仿QQ長按彈窗菜單
要在Autojs中模仿QQ長按彈窗菜單,你可以按照以下步驟進行:
1. 創建基礎布局
2. 設置RecyclerView適配器
3. 處理長按事件
4. 實現彈窗菜單
5. 測試與迭代
注意事項:
通過以上步驟,你就可以在Autojs中模仿QQ長按彈窗菜單的功能了。
4. 微信分享jssdk無法分享到qq是怎麼回事
登錄你的微信平台,點擊「公眾號設置」。
2
點擊「功能設置」,然後點擊「設置」。
3
設置JS介面安全域名。這里填寫的是一級域名,不帶www和http。最多可以設置三個域名。設置完後點擊確定。(多說一句,相比以前的分享沒有任何域名限制,這里設置安全域名,目的是為了當發現此公眾平台發現誘導分享行為時,可以根據此域名追溯到所有分享出去的鏈接,以及通過這些鏈接增加的粉絲。這樣,微信就可以牢牢控制了你的微信平台,一旦發現違規,讓分享鏈接失效,刪除掉誘導行為增加的粉絲,是瞬間就可以完成的。因此,微信平台的開發者,一定要合理來使用分享功能,不要因小失大。等到你的微信平台被封,估計哭都來不及)
4
在開發者中心中獲取你的AppID和AppSecret,接下來在獲取令牌時,需要這兩個信息。
5
獲取令牌。在伺服器端完成,代碼如下:
function wx_get_token() {
$token = S('access_token');
if (!$token) {
$res = file_get_contents('https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=' .'你的AppID'.'&secret=' .'你的AppSecret');
$res = json_decode($res, true);
$token = $res['access_token'];
// 注意:這里需要將獲取到的token緩存起來(或寫到資料庫中)
// 不能頻繁的訪問https://api.weixin.qq.com/cgi-bin/token,每日有次數限制
// 通過此介面返回的token的有效期目前為2小時。令牌失效後,JS-SDK也就不能用了。
// 因此,這里將token值緩存1小時,比2小時小。緩存失效後,再從介面獲取新的token,這樣
// 就可以避免token失效。
// S()是ThinkPhp的緩存函數,如果使用的是不ThinkPhp框架,可以使用你的緩存函數,或使用資料庫來保存。
S('access_token', $token, 3600);
}
return $token;
}
注意:返回的access_token長度至少要留夠512位元組。介面返回值:
{"access_token":"ACCESS_TOKEN","expires_in":7200}
{"access_token":"vdlThyTfyB0N5eMoi3n_aMFMKPuwkE0MgyGf_0h0fpzL8p_-0kVHY33BykRC0YXZZZ-WdxEic4","expires_in":7200}
6
獲取jsapi的ticket。jsapi_ticket是公眾號用於調用微信JS介面的臨時票據。正常情況下,jsapi_ticket的有效期為7200秒,通過access_token來獲取。
function wx_get_jsapi_ticket(){
$ticket = "";
do{
$ticket = S('wx_ticket');
if (!empty($ticket)) {
break;
}
$token = S('access_token');
if (empty($token)){
wx_get_token();
}
$token = S('access_token');
if (empty($token)) {
logErr("get access token error.");
break;
}
$url2 = sprintf("https://api.weixin.qq.com/cgi-bin/ticket/getticket?access_token=%s&type=jsapi",
$token);
$res = file_get_contents($url2);
$res = json_decode($res, true);
$ticket = $res['ticket'];
// 注意:這里需要將獲取到的ticket緩存起來(或寫到資料庫中)
// ticket和token一樣,不能頻繁的訪問介面來獲取,在每次獲取後,我們把它保存起來。
S('wx_ticket', $ticket, 3600);
}while(0);
return $ticket;
}
介面返回值:
{"errcode":0,"errmsg":"ok","ticket":"-I98-_YWtOQg","expires_in":7200}
7
簽名,將jsapi_ticket、noncestr、timestamp、分享的url按字母順序連接起來,進行sha1簽名。
noncestr是你設置的任意字元串。
timestamp為時間戳。
$timestamp = time();
$wxnonceStr = "任意字元串";
$wxticket = wx_get_jsapi_ticket();
$wxOri = sprintf("jsapi_ticket=%s&noncestr=%s×tamp=%s&url=%s",
$wxticket, $wxnonceStr, $timestamp,
'要分享的url(從http開始,如果有參數,包含參數)'
);
$wxSha1 = sha1($wxOri);
END
步驟2 添加JS代碼
生成簽名後,就可以使用js代碼了。在你的html中,進行如下設置即可。
<script type="text/javascript" src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>
<script type="text/javascript">
// 微信配置
wx.config({
debug: false,
appId: "你的AppID",
timestamp: '上一步生成的時間戳',
nonceStr: '上一步中的字元串',
signature: '上一步生成的簽名',
jsApiList: ['onMenuShareTimeline', 'onMenuShareAppMessage'] // 功能列表,我們要使用JS-SDK的什麼功能
});
// config信息驗證後會執行ready方法,所有介面調用都必須在config介面獲得結果之後,config是一個客戶端的非同步操作,所以如果需要在 頁面載入時就調用相關介面,則須把相關介面放在ready函數中調用來確保正確執行。對於用戶觸發時才調用的介面,則可以直接調用,不需要放在ready 函數中。
wx.ready(function(){
// 獲取「分享到朋友圈」按鈕點擊狀態及自定義分享內容介面
wx.onMenuShareTimeline({
title: '分享標題', // 分享標題
link:"分享的url,以http或https開頭",
imgUrl: "分享圖標的url,以http或https開頭" // 分享圖標
});
// 獲取「分享給朋友」按鈕點擊狀態及自定義分享內容介面
wx.onMenuShareAppMessage({
title: '分享標題', // 分享標題
desc: "分享描述", // 分享描述
link:"分享的url,以http或https開頭",
imgUrl: "分享圖標的url,以http或https開頭", // 分享圖標
type: 'link', // 分享類型,music、video或link,不填默認為link
});
});
</script>
5. js 判斷是不是在手機qq打開
[javascript] view plain
<script>
var online= new Array(); //全局變數,
</script>
<script src=" http://webpresence.qq.com/getonline?Type=1&qq號:"></script> //網路返回一個online數組正好覆蓋上面定義的online 如:online[0]=1;
<script>
if (online[0]==0)
document.write("不在線");
else
document.write("在線");
</script>
注意qq號後面要加「:」