javascript - Chrome 扩展程序 - 不保存数据

标签 javascript google-chrome google-chrome-extension

我无法让 Chrome 扩展程序正确保存数据。

这是我当前的代码

function getQueryVariable(variable) {
//Split URL by variables
    var query = window.location.search.substring(1);
    var vars = query.split("&");
    for (var i=0;i<vars.length;i++) {
		var pair = vars[i].split("=");
        if(pair[0] == variable){return pair[1];}
    }
    return(false);
}


function saveTicket2(ticket, contents) {
//Save the data to local storage
	chrome.storage.local.set({ticket : contents}, function() {
	console.log('Saved', ticket, contents);
	});
}

function setData(ticketID, result) {
//If data exists. Set it.
	document.getElementsByName('message')[0].value = result[ticketID];
	document.getElementsByName('message')[1].value = result[ticketID];
	console.log(result);
}

//Grab Ticket ID	
var ticketID = getQueryVariable("id");

//Retrieve data if it exists
try  {
	chrome.storage.local.get(ticketID, function(result) {
	if (result) {
	setData(ticketID, result);
	}
	});
} catch(err) {
	console.log(err.message);
}


//Save ticket contents to local storage every 5 seconds
window.setInterval(function() {
	var contents= document.getElementsByName('message')[0].value;
	var contents= document.getElementsByName('message')[1].value;
	saveTicket2(ticketID, contents);
}, 5000);

在 saveTicket2 中,日志工作正常

Saved 222222 text

setData 中的日志记录了一个空对象

因此 chrome.storage.local.set 似乎顺利通过,但实际上并没有保存任何内容。

来自Chrome Storage Developer Page给出的例子如下

chrome.storage.sync.set({'value': theValue}, function() {
  // Notify that we saved.
  message('Settings saved');
});

这就是我所拥有的。存储权限也在我的 list 中。

如果我将以下内容添加到 saveTicket2,在 .set 之后,它还会返回一个空对象,确认我访问错误或保存错误。

	chrome.storage.local.get(ticket, function(result1) {
	console.log(result1);
	});

有人知道为什么这不保存吗?

最佳答案

在您的代码中:

chrome.storage.local.set({ticket : contents}, function() {
console.log('Saved', ticket, contents);
});

门票金额尚未设置成功。

它将以这种方式工作:

function saveTicket2(ticket, contents) {
//Save the data to local storage
var dataObj = {};
dataObj[ticketID] = contents;
chrome.storage.local.set(dataObj, function(){
    if(!chrome.runtime.lastError){
        console.log('Saved', ticket, contents);
    }   
});
}

这是我的测试代码:

function saveTicket2(ticket, contents) {
//Save the data to local storage
var dataObj = {};
dataObj[ticketID] = contents;
chrome.storage.local.set(dataObj, function(){
    if(!chrome.runtime.lastError){
        console.log('Saved', ticket, contents);
    }   
});}

function setData(ticketID, result) {
//If data exists. Set it.
console.log("setData: ", result);
}

//Grab Ticket ID    
var ticketID = "55555";

//Retrieve data if it exists
function getData(){
try{
    chrome.storage.local.get(ticketID, function(result) {
        if (result){
            console.log(result);            
            setData(ticketID, result[ticketID]);
        }
    });
}catch(err) {
    console.log(err.message);
}
}

//Save ticket contents to local storage every 5 seconds
window.setInterval(function() {
var contents= new Date().getTime();
saveTicket2(ticketID, contents);
}, 3000);
window.setInterval(function() {
getData();
}, 5000);

如果您想了解更多chrome.storage的使用方法,请访问How to set a simple dynamic variable into chrome.storage.local.set for a chrome extension?

关于javascript - Chrome 扩展程序 - 不保存数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32684346/

相关文章:

css - Chrome 中的 float div,出现错位

javascript - Object.entries 的奇怪行为

javascript - Chrome 扩展通过 chrome.runtime.onMessage 传递当前标签页 url

javascript - Chrome 扩展 - javascript 中的功能无法正常工作

javascript - 单击按钮时警报框显示表单数据

php - 使用 fancybox 打开的表单中的 textarea 元素不会清除值

javascript - Replace() 不替换选定的文本

javascript - Node.js回调,等待函数结束

javascript - "ResizeObserver - loop limit exceeded"|从未使用过 API

google-chrome - Chrome 扩展 : how to use serial port (now that apps are sunsetting)?