Всем привет, прошу поомочь, т.к. плохо знаю JS суть в слудующем :
Пишу плагин для хрома, который выполняет поиск по странице, навесил на кнпоку обработчик, но политикой хрома запрещено использовать инлайновые скрипты.
вот так было изначально:
<input type="text" id="text-to-find" placeholder="поиск">
<input type="button" value="найти" onclick="FindOnPage('text-to-find'); return false; "/>
соответственно хром ругается на инлайновые скрипты:
onclick="FindOnPage('text-to-find'); return false;
сам скрипт поиска:
var lastResFind=""; // последний удачный результат
var copy_page=""; // копия страницы в ихсодном виде
function TrimStr(s) {
s = s.replace( /^\s+/g, '');
return s.replace( /\s+$/g, '');
}
function FindOnPage(inputId) {//ищет текст на странице, в параметр передается ID поля для ввода
var obj = window.document.getElementById(inputId);
var textToFind;
if (obj) {
textToFind = TrimStr(obj.value);//обрезаем пробелы
} else {
alert("Введенная фраза не найдена");
return;
}
if (textToFind == "") {
alert("Вы ничего не ввели");
return;
}
if(document.body.innerHTML.indexOf(textToFind)=="-1")
alert("Ничего не найдено, проверьте правильность ввода!");
if(copy_page.length>0)
document.body.innerHTML=copy_page;
else copy_page=document.body.innerHTML;
document.body.innerHTML = document.body.innerHTML.replace(eval("/name="+lastResFind+"/gi")," ");//стираем предыдущие якори для скрола
document.body.innerHTML = document.body.innerHTML.replace(eval("/"+textToFind+"/gi"),"<a name="+textToFind+" style='background:red'>"+textToFind+"</a>"); //Заменяем найденный текст ссылками с якорем;
lastResFind=textToFind; // сохраняем фразу для поиска, чтобы в дальнейшем по ней стереть все ссылки
window.location = '#'+textToFind;//перемещаем скрол к последнему найденному совпадению
все работает, все ищет, НО В ПЛАГИНЕ НЕ РАБОТАЕТ ибо инлайн нельзя, знаю, что можно сделать как динамический обработчик, что-то вроде:
document.getElementById('btn-text-to-find').addEventListener('click',FindOnPage('text-to-find'))
но как все это прикрутить хзхз, будте добры подскажите как все это заставить работать, что-бы в pupup.html не было JS