重複の可能性:
Chrome拡張機能の遅延状態
拡張機能の初心者で、あちこちからコードを収集することで、タブのURL(特定のWebサイトで機能)を収集し、データベースに保存するためにajaxImを使用してサーバーに送信する簡単なコードを作成しました。私がやろうとしているのは、タイマーを追加して、前のクリックが5秒以内に発生した場合にブラウザーボタンが無効になる(または何もしない)ようにすることです。
以下は拡張機能の構造です。
マニフェスト:
{
"name": "The name",
"icons": { "16": "Big.png",
"48": "Big.png",
"128": "Big.png" },
"version": "1.0",
"manifest_version": 2,
"description": "and the description",
"browser_action": {
"default_icon": "icon.png",
"default_popup": "popup.html"
},
"permissions": ["tabs", "<all_urls>"]
}
popup.js:
chrome.tabs.getSelected(null,function(tab) {
var Mp=tab.url
if(Mp=='http://www.examplesite.com')
{
var xhr=new XMLHttpRequest();
var Params;
xhr.open("POST", "http://myserver.com/post_from_extension.asp", true);
xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
Params='Url=' + tab.url;
xhr.onreadystatechange=function()
{
if(xhr.readyState==4)
{
message.innerHTML=xhr.responseText;
}
}
xhr.send(Params);
}
else
{
message.innerHTML='<span style="font-family: Segoe UI, Tahoma;color: #f00">This is not a valid url</span>';
}
});
popup.html
<!DOCTYPE html>
<html style=''>
<head>
<script src='popup.js'></script>
</head>
<body style="width:400px;">
<div id='message'><span style="font-family: Segoe UI, Tahoma;color: #00f">Sending request</span></div>
</body>
</html>
副次的な質問として、Ajaxを使用しない場合、データベースにURLを投稿する他の方法はありますか?
私を読んでくれてありがとう。