내 PWA에서 사용자의 활동을 추적하려고합니다. 현재 URI로 각 사이트 노출에 대한 요청을 내 서버로 보낼 수 있습니까?서비스 작업자의 현재 URL 변경 사항을 추적하는 방법은 무엇입니까?
시나리오 : 현재 URI로 PWA -> 요청을 엽니 다. 사용자가 현재 URI로 서브 페이지 -> 보내기 요청을 엽니 다.
내 예를 들어 서비스 worker.js는 :
var cacheName = 'weatherPWA-step-6-2';
var filesToCache = [
'/',
'/index.html',
'/scripts/app.js',
'/styles/inline.css',
'/images/clear.png',
'/images/cloudy-scattered-showers.png',
'/images/cloudy.png',
'/images/fog.png',
'/images/ic_add_white_24px.svg',
'/images/ic_refresh_white_24px.svg',
'/images/partly-cloudy.png',
'/images/rain.png',
'/images/scattered-showers.png',
'/images/sleet.png',
'/images/snow.png',
'/images/thunderstorm.png',
'/images/wind.png'
];
self.addEventListener('install', function(e) {
console.log('[ServiceWorker] Install');
e.waitUntil(
caches.open(cacheName).then(function(cache) {
console.log('[ServiceWorker] Caching app shell');
return cache.addAll(filesToCache);
})
);
});
self.addEventListener('activate', function(e) {
console.log('[ServiceWorker] Activate');
e.waitUntil(
caches.keys().then(function(keyList) {
return Promise.all(keyList.map(function(key) {
if (key !== cacheName) {
console.log('[ServiceWorker] Removing old cache', key);
return caches.delete(key);
}
}));
})
);
return self.clients.claim();
});
self.addEventListener('fetch', function(e) {
console.log('[ServiceWorker] Fetch', e.request.url);
console.log("Url", Client.url);
e.respondWith(
caches.match(e.request).then(function(response) {
return response || fetch(e.request);
})
);
});
당신은 단지 창에서'hashchange' 이벤트를 듣고 원하는대로 할 수 있습니다. –
@JPrakash : 감사합니다! – CYGS