-
Notifications
You must be signed in to change notification settings - Fork 27.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
next/prefetch doesn't prefetch data #740
Comments
I'm not totally sure if this answer your question @sedubois but I implemented the log function on the prefetch service worker and this is what you see (look that about is fetched from cache) This is with |
@impronunciable thanks but I don't have that behaviour in my case, the cache doesn't seem to be hit (didn't confirm with logs but is obvious from the behaviour). Looks like either I'm missing something or there's a bug. |
@sedubois let me check on this. |
@sedubois are you using |
@sedubois I couldn't reproduce the issue. It's working pretty well for me. Also check at the network tab too. If you see a hit with |
@arunoda the links to code and deployment on now are in the OP. Didn't use "as" because there are no dynamic routes (no custom server). |
@sedubois @arunoda just to be clear it's this app: https://github.com/RelateNow/relate |
I can confirm this issue in my next apollo example as well. If you load the |
@ads1018 prefetch only does JSON page prefetching.(Basically the JS code) Not data. I'll check that app too. |
Ah ok good to know. This would be a good disclaimer to add to the docs. It would be a very useful/cool/powerful feature to enable optional prefetching of data as well. |
Yes I think it would make sense to prefetch whatever kind of page there is. And if that's not possible for some reason the doc should make it clear. I think this prefetch is a very important feature which would also open the way to offer some kind of offline mode and low-bandwidth friendly experience; it's also essential to the experience of progressive web apps I guess. So I'm very much looking forward to adding prefetching to my app :-) especially as im working on a mindfulness app, where people will for sure want to be able to use airplane mode to reduce their distractions (and also to download the audio/video contents in advance for a smoother and more mobile experience). |
@ads1018 your app works fine. If data prefetching needed, you need to do it yourself. |
@sedubois I tried your app (the deployed version). Prefetching works fine. (check the network tab) BTW: I couldn't run your app. It needs a graphql server. Can I get a minimal repo I can test this case in more detail? |
@arunoda how is that data prefetching then done? Could we have an example? If as a user we need to do something special about data, the doc should be updated, because it makes it sound right now like there's nothing special to do about data: "Since Next.js server-renders your pages, this allows all the future interaction paths of your app to be instant. Effectively Next.js gives you the great initial download performance of a website, with the ahead-of-time download capabilities of an app."
I don't know. There's also no response status in @ads1018's app, and it also doesn't prefetch data in his app (you can see that by first loading the /about page, then navigating to the home). So you can use his app to repro the issue if easier (or I'll PM you the graphql backend URL if you need it). |
Data PrefetchingI think Next.js is about the app infrastructure, we always want user to handle the data. Relay, Apollo and others should take care of the data logic. We know nothing about the data in your app, so we can't prefetch. You might say, we could just call That's wrong. Data could change time to time. So, doing that is wrong since we don't know nothing about data. What you can do is, rather using I think having an example would be nice too. @rauchg @nkzawa @impronunciable could you guys add something here. |
@arunoda I'm fetching data myself as you can see here. I just figured the service worker would reach this code. Perhaps, I need to check that the execution environment is a service worker? Edit: As you explained above, I didn't realize the service worker doesn't call |
@ads1018 nope. Service Workers just don't read this code. It just download the source code. |
I think we should write more about how Next.js works internally :) |
@arunoda I still think prefetch should call getInitialProps. Even if the data changes meanwhile, it's a great "best guess" to instantly-render the page. And as soon as we navigate to the page, the data will be refreshed anyway because getInitialProps will be called again! Wouldn't that be the best of both worlds? |
FYI, Gatsby 1.0 prefetches both code and data (ref). IMHO Next.js should too. As a user, I'd very much want that. I don't agree that Next.js "knows nothing about the data in your app", it actually explicitly created an API for it ( |
@sedubois If we decide to do it, it should be explicit. For example: <Link prefetchProps={true} /> Otherwise it won't scale |
Ooo @rauchg that would be nice. And agreed, developers run the risk of running up a user's data usage bill if the API is not explicit lol |
@rauchg I think that'd be great 👍 🙂 ! And anyway if someone would want to prefetch all data, they could always alias Link to add prefetchProps automatically. |
@ads1018 not just that bill, but the server's data computations can be very expensive, and only meant to be executed on-demand. |
Hey! |
@gmaliandi interesting, do you foreseen any way to achieve this without using eval? |
@sedubois as far as I know, all you get in that response is the code of your page, i.e. the same code you are actually prefetching and storing for later execution - and next.js uses If you definitely want to avoid using eval, you could technically parse only the subset of the code that you want. For example, you could add some sort of metadata in comments that indicate which stuff should be cached and then parse only that. But I think that would be less elegant. In my opinion, this approach I commented makes sense mostly when you do caching in Eventually it would be cool to have some |
@gmaliandi using eval doesn't seem so fine, see #1301 I agree that prefetching the page then pre-rendering its HTML would be a great feature to explore. |
Indeed, it would be a great feature to explore. I created an issue for this specific feature - see #1175 |
Maybe this code can help for Apollo case: |
Hi! We just blogged about the approach I mentioned above. Hope this helps! Fortunately since next.js no longer uses |
That's a pretty impressive way of using |
Thanks @arunoda! We just published this to npm: data-prefetch-link. |
Going to close this issue. Core support is not needed thanks to @gmaliandi's brilliant work 👍 |
It would be nice to bring this concept into core support now that it has been battle tested and matured for a while. I worry many new and existing Next.js users don't know that data-prefetch-link even exists. Having the "withData" option in the documentation would make it much more likely that the community would benefit from this brilliant concept. |
Has anyone tested this with now? For some reason, its working just fine on localhost, but when pushed to now, its not prefetching. |
It is my understanding that replacing an
import 'next/link'
withimport next/prefetch'
should "just work", however I don't see this behaviour in my app. It doesn't use dynamic routes, and just has three links in its header which should be prefetched.Locally, I see three pages in the cache with an "OK" response, which seems to be the desired behaviour:
When deployed with Now, I see the three pages in the cache, but there's no OK response (even when waiting several minutes):
But in both cases (local and deployed), I still see a "Loading..." indicator when I then click on the Discover link (and in general "feel slow", compared to when I return to the page a second time).
The text was updated successfully, but these errors were encountered: