• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Rozszerzenie w Chrome nie robi to co powinno

0 głosów
68 wizyt
pytanie zadane 14 czerwca w JavaScript, jQuery, AJAX przez TeslaX93 Użytkownik (840 p.)

Piszę swoje pierwsze rozszerzenie (które wykorzystuje API) do Google Chrome, którego zadaniem jest dopisanie parametru do adresu url strony, do której użytkownik przechodzi. Dla przykładu, użytkownik klika na link prowadzący do http://example.org/test.php, a rozszerzenie dopisuje do tego adresu mój parametr i ostatecznie użytkownik ląduje na przyklad na http://example.org/test.php?parametr=1

Wzorowałem się na tym: https://stackoverflow.com/a/21194661/8344646 - z tym, że niestety nic to nie daje, albo źle zrozumiałem jak działa technologia, której używa onet (przejdźcie sobie na zapytaj.onet.pl, kliknijcie na dowolne pytanie sprawdzając jak wygląda link, a gdy zostaniecie przekierowani na główną onetu kliknijcie na zobacz pytanie - voila, trzy nagłówki GET więcej i już. Teoretycznie).

Problem tylko w tym, że to co napisałem nie działa w żaden sposób i straciłem już sporo czasu na googlowanie co może być nie tak. W pasku adresu nic się nadal nie zmienia.

Mój plik manifest.json:

{
 "manifest_version": 2,
 "name": "Zapytaj naprawa",
 "description": "Naprawia zepsuty przez Onet Zapytaj",
     "background": {
      "scripts": ["background.js"],
      "persistent": true
    },
 "version": "1",
 "author": "test",
 "permissions": [
				"tabs",
				"*://zapytaj.onet.pl/*"
				]
}

Oraz background.js:

var customParam = encodeURI('?utm_source=zapytaj_viasg&utm_medium=nitro&utm_campaign=zapytaj_nitro');
chrome.browserAction.onClicked.addListener(function (tab) {
  var url = tab.url;
  var hashStart = (url.indexOf('#') === -1) ? url.length : url.indexOf('#');
  var querySymbol = (url.indexOf('?') === -1) ? '?' : '&';
  var newUrl = url.substring(0, hashStart) + querySymbol + customParam +
               url.substring(hashStart);

  chrome.tabs.update(tab.id, {url: newUrl});
});

 

Zaloguj lub zarejestruj się, aby odpowiedzieć na to pytanie.

Podobne pytania

0 głosów
0 odpowiedzi 63 wizyt
0 głosów
1 odpowiedź 85 wizyt
pytanie zadane 18 maja 2017 w JavaScript, jQuery, AJAX przez Bania77 Nowicjusz (150 p.)
+1 głos
1 odpowiedź 109 wizyt
pytanie zadane 28 kwietnia 2016 w JavaScript, jQuery, AJAX przez Majkel Nowicjusz (200 p.)
Porady nie od parady
Zadając pytanie postaraj się o poprawną pisownię i czytelne formatowanie tekstu.Kompozycja

51,027 zapytań

93,344 odpowiedzi

189,543 komentarzy

24,885 pasjonatów

Przeglądających: 290
Pasjonatów: 14 Gości: 276

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto dwie polecane książki warte uwagi. Pełną listę znajdziesz tutaj.

...