using just `next dev` not that i know of
using just
next dev
not that i know of but may be possible, im a huge donkey so hope im not leading you down the wrong direction, even now im wondering if i actually did create the KV in wrangler, or if it didn't just automatically do that,
you probably already saw this but the internal github doc:
that says it generates from miniflare, so i feel like you may not need it locally, but can't remember how i set it up last time hehe54 Replies
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
i installed wrangler locally then:
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
next dev:
server component:
edit: getkv
it reads for me using this,
hmm only difference i see is you did import instead of require, but not sure why that would impact anything
i think you will need to set up dashboard when you deploy, but not necessary for local, i also think wrangler defaults to local, hmmm
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
not sure on the first question im a donkey sir,
i believe preview is a separate deployment like staging
i hate to @Better James , because its not his job to be in the discords, but he would know all the answers here, he is on EU time i believe, but maybe he will see it lol
oh okay yeah hmm, what version of next-on-pages are you on?
i just reset the binding to a new ID and it worked out of box, so i dont think we need wrangler very sorry to lead you down wrong path
The name of the object is what you would use to access it, e.g.
process.env.MY_KV_BINDING_VAR
You don't need to create a kv namespace to run it. It should be created automatically if it doesn't exist.thank you so much for responding!
okay yeah, totally makes sense, so curiously in his original post he said
process.env.TESTKV
was undefined, but he set up
what would be a likely cause then? hmm i am baffledUnknown User•12mo ago
Message Not Public
Sign In & Join Server To View
My assumption would be next-on-pages version being old - his code snippet worked fine when I tried it
Yeah
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
Yup
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
Just going to ask it for the sake of asking it even thought the answer is probably yes, but you do have the latest next-on-pages as a dependency right?
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
if it's not too much trouble
hmm super baffling, can't wait to see it!
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
Please can you opt the page that you're using the binding in to use the edge runtime
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
Also, KV.put is async so probably best to await it
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
wowwww okay, did not know the
runtime
was required in local, it all makes sense now!!If you have server functionality on a route, it should be opted into the edge runtime
if you are going to access cloudflare bindings in local yes, also if you deploy its all edge i believe
thank you for the help sir!
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
Yeah if you want server functionality on Pages it will need to be edge. You can still let routes that don't need server functionality be prerendered/SSG'd at build time (which Next.js tries to do by default), and we'll just serve the html/rsc files when a request comes in, but if a route needs server functionality, it'll need to be the edge runtime since it'll be running in workerd
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
So when you deploy a route to Vercel that uses the edge runtime, that'll get sent to cloudflare, since the edge runtime (Vercel's project) is basically just a wrapper essentially to add some extra compat to workers for Vercel's deployments. That's a very simple way of thinking about it anyway
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
Afraid not. Pages dev with wrangler doesn't support remote mode so you're already limited in that aspect, but we're actually using miniflare to deal with all this which does it locally in workerd
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
No worries, have fun 🙂
little tip, in NextJS you could set the runtime on the root
layout.tsx
and it will use the same runtime for all the child pages as wellI would generally advise against that unless every single route will have server functionality. It's preferable to let routes be prerendered unless they absolutely need SSR
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
yea true, might need to be careful
Next has like 3 different caching mechanisms right? That are all on by default 😵💫
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
No, you won't be able to access it at build time
just to be sure, if you set
revalidate
it will just be SSR with caching right?Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
I think pulling in dynamic data on build time is not very common though?
Unknown User•12mo ago
Message Not Public
Sign In & Join Server To View
the
export const revalidate = true
only works on non-edge routes IIRC. You can set fetch(..., { next: { revalidate: ... } })
on edge routes to cache fetch requests for x amount of time, which is a new form of ISR in app dir landyea, was talking about the latter
err meant to reply to james ; p
thanks for the info guys!
one last question (couldn't find it in the docs so guess not) I am playing around with sveltekit (and liking the svelte 5 changes so far : D), is there something similar to
next-dev
for local binding? Or am I better off using cf-bindings-proxy
for now?Ah nice, it calls directly into miniflare, kinda similar to what
next-dev
does?
I would still use your library if it would let me spin up two proxies (one with --remote
and one with --local
(I have a use case where I want to develop against a remote D2, but rest local)
And with a bit of config on the pages side of things, it would know to which proxy it should forward the request toHi everyone! I came here for the same issue after reading the documentation a couple of times. Maybe adding
export const runtime = 'edge';
to the documentation would help few people?