我在 background.js 中有以下这段代码。
appAPI.contextMenu.add("key2", "Add", function (data) {
var key=0;
alert('hi'+data.selectedText);
var tableRow = $("td").filter(function() {
return $(this).text() == data.selectedText;
}).closest("tr");
alert("1");
alert(tableRow+'sds');
if(tableRow===null)
{
alert("Please select proper text so that course can be selected, this would title or coursenumber");
return;
}
var title=tableRow.find('td').eq(7).text();
var days=tableRow.find('td').eq(8).text();
var time=tableRow.find('td').eq(9).text();
timeSplit=time.split('-');
var startTime,endTime;
startTime=getTime(timeSplit[0]);
endTime=getTime(timeSplit[1]);
var loc=tableRow.find('td').eq(10).text();
var instructor=tableRow.find('td').eq(12).text();
key=key+1;
courseData=[{'id':key,'title':title,'days':days,'startTime':startTime,'endTime':endTime,'loc':loc,'instructor':instructor}];
var dbData=appAPI.db.get('course_Data');
if(dbData===null)
{
dbData=courseData;
}
else
{
dbData.push({'id':key,'title':title,'days':days,'startTime':startTime,'endTime':endTime,'loc':loc,'instructor':instructor});
}
alert(dbData[key-1]['title']);
appAPI.db.set('course_Data',dbData);
}, ["all"]);
当我保留在 extension.js 中时,相同的代码与 appAPI selectedText 方法完美配合,但在后台 jquery 部分似乎不起作用。我这么说是因为我无法使用 jquery 代码到达 alert('1') 语句,然后根据所选值过滤掉表拖。