• 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
75 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 67 wizyt
0 głosów
1 odpowiedź 114 wizyt
pytanie zadane 18 maja 2017 w JavaScript, jQuery, AJAX przez Bania77 Nowicjusz (150 p.)
+1 głos
1 odpowiedź 116 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 odpowiedni tytuł, kategorię oraz tagi.Tagi

54,442 zapytań

98,327 odpowiedzi

202,258 komentarzy

26,744 pasjonatów

Przeglądających: 179
Pasjonatów: 6 Gości: 173

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.

...