S
SolidJS6mo ago
Joe Pea

how to make SSG use dynamic client-side routing instead of full page refresh?

I tried pre-rendering with server.prerender.crawLinks = true in app.config.ts, but when I change pages, each page does a non-ideal full page refresh. I'm guessing this means solid-start doesn't have client-side routing in SSG mode?
21 Replies
Brendonovich
Brendonovich6mo ago
this should work fine, can you tell if reactivity is working on the page?
Joe Pea
Joe PeaOP6mo ago
It looks like its just a basic static MPA. Here's a reproduction: https://github.com/lume/showcase/tree/prerender-full-page-refresh the prerender-full-page-refresh branch After you npm run build then launch with npx five-server .output/public, when you click the nav items to change routes, it does a full page refresh. What I was hoping for is that the initial payload would be from pre-render, but then the client-side rendering and routing would take over.
Brendonovich
Brendonovich6mo ago
Yeah that's the expected behaviour, Start isn't an MPA framework. It usually means that hydration or just regular js execution failed at a first glance could the top level import be failing?
Joe Pea
Joe PeaOP6mo ago
Not sure, I don't see any errors. I put a console.log at the top of app.tsx but that never runs. Do you mean the top-level await import()? Yeah not sure, but the log before that line doen't run so looks like it doesn't get that far Could it be tripping something up in the prerender step of the build? npm run dev works well, that shows how the expected result should be I was hoping to deploy something tomorrow as a static site for free on GitHub, but worse case I'll just deploy a server.
Brendonovich
Brendonovich6mo ago
doing this seems to fix it
No description
Joe Pea
Joe PeaOP6mo ago
Hmm, are you sure? Seems to work the same when I do that, still refreshes But also that gets a little tricky when we need to do this:
let Scene
if (globalThis.window?.document) {
;({Scene/*, etc*/} = await import('lume'))
}
let Scene
if (globalThis.window?.document) {
;({Scene/*, etc*/} = await import('lume'))
}
Brendonovich
Brendonovich6mo ago
yeah seems to be working, though since there's no lockfile in the repo i may have a bunch of updated dependencies
Joe Pea
Joe PeaOP6mo ago
Wish just regular import would work, but that has some issues to iron out, f.e. it imports some things from solid-js/web that don't exist when running in Node.js
Brendonovich
Brendonovich6mo ago
it might be better to do the import in a createResource so you can pause rendering with Show until it's loaded or maybe clientOnly could work
Joe Pea
Joe PeaOP6mo ago
yeah, it's just cumbersome because I need to set the types of the variables that I will import f.e.
import type {Scene} from 'lume'

//...
const [Scene, setScene] = createSignal<typeof Scene>()
setScene(await import('lume'))
import type {Scene} from 'lume'

//...
const [Scene, setScene] = createSignal<typeof Scene>()
setScene(await import('lume'))
or similar Hmm, really the main issue is if you just put import 'lume' at the top of the module, that breaks during build. Because in that case solid-js does not export the same things as in browser
Joe Pea
Joe PeaOP6mo ago
You said you changed package lock? Do I need to update deps for it to work?
Brendonovich
Brendonovich6mo ago
ohhh you're not using pnpm my bad
Joe Pea
Joe PeaOP6mo ago
Oh, how can that make a difference?
Brendonovich
Brendonovich6mo ago
with pnpm it just fetched all the latest versions since there isn't a lockfile for it to use
Joe Pea
Joe PeaOP6mo ago
Hmm, I deleted package-lock and node_modules right before making that repro, created package lock fresh with npm install
Brendonovich
Brendonovich6mo ago
works fine with npm too so idk
Joe Pea
Joe PeaOP6mo ago
whaaaaa
Joe Pea
Joe PeaOP6mo ago
Here's what I see:
Brendonovich
Brendonovich6mo ago
yeah idk what's going on there, try using the npx serve command from the build output?
Joe Pea
Joe PeaOP5mo ago
same issue with npx serve .output/public. looks like there's an issue in the .output

Did you find this page helpful?