admin管理员组文章数量:1406052
I have learned to implement push notifications for a Web Application using chrome and successfully ran the sample code mentioned in the blog.
Unfortunately, I couldn't replicate the success with Django. It never goes into the ready method of the service worker,(navigator.serviceWorker.ready.then) ie, the service worker is never ready.
As per /
One subtlety with the register method is the location of the service worker file. You'll notice in this case that the service worker file is at the root of the domain. This means that the service worker's scope will be the entire origin. In other words, this service worker will receive fetch events for everything on this domain. If we register the service worker file at /example/sw.js, then the service worker would only see fetch events for pages whose URL starts with /example/ (i.e. /example/page1/, /example/page2/).
In Django, how to put a JS a file under root of the application? Currently,scope of the service worker is: http://127.0.0.1:8000/static/ (When I use chrome://serviceworker-internals/)
I have learned to implement push notifications for a Web Application using chrome https://developers.google./web/updates/2015/03/push-notifications-on-the-open-web?hl=en and successfully ran the sample code mentioned in the blog.
Unfortunately, I couldn't replicate the success with Django. It never goes into the ready method of the service worker,(navigator.serviceWorker.ready.then) ie, the service worker is never ready.
As per http://www.html5rocks./en/tutorials/service-worker/introduction/
One subtlety with the register method is the location of the service worker file. You'll notice in this case that the service worker file is at the root of the domain. This means that the service worker's scope will be the entire origin. In other words, this service worker will receive fetch events for everything on this domain. If we register the service worker file at /example/sw.js, then the service worker would only see fetch events for pages whose URL starts with /example/ (i.e. /example/page1/, /example/page2/).
In Django, how to put a JS a file under root of the application? Currently,scope of the service worker is: http://127.0.0.1:8000/static/ (When I use chrome://serviceworker-internals/)
Share Improve this question edited Dec 21, 2015 at 7:05 Tevin Joseph K O asked Dec 21, 2015 at 5:31 Tevin Joseph K OTevin Joseph K O 2,65423 silver badges25 bronze badges2 Answers
Reset to default 5Follow this method...
- put the
sw.js
file intemplate
folder configure view to serve as static file
#urls url(r'^sw(.*.js)$', views.sw_js, name='sw_js'), #views from django.views.decorators.cache import never_cache from django.template.loader import get_template @never_cache def sw_js(request, js): template = get_template('sw.js') html = template.render() return HttpResponse(html, content_type="application/x-javascript")
Similar to the accepted answer, but shorter:
- Place
service_worker.js
in root of thetemplate
folder. Add to your routings:
from django.conf.urls import url from django.views.generic import TemplateView urlpatterns = [ # Other urls url(r'^service_worker(.*.js)$', TemplateView.as_view(template_name='service_worker.js', content_type='application/x-javascript')) ]
Update: I ended up needing to pass authentication credentials to the service_worker.js
file, so this was my final route:
url(r'^service_worker(.*.js)(?:/(?P<params>[a-zA-Z]+)/)?',
TemplateView.as_view(template_name='service_worker.js', content_type='application/x-javascript'))
This allows passing parameters like so: domainbase./service_worker.js?foo=bar...
The javascript to then access the params is:
var url_params = location.search.substring(1);
console.log(url_params);
=> "foo=bar..."
本文标签: javascriptImplementing push notification using chrome in DjangoStack Overflow
版权声明:本文标题:javascript - Implementing push notification using chrome in Django - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1744966114a2634957.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论