- 基本和 Next.js 一样,可以不需要引入 react-jsx
- 页面跳转也是一样的用
<Link to="/syntax">
标签
createElement(
import_remix3.Link,
{
to: '/syntax',
},
'Syntax'
);
出乎意料,在remix里竟然用 <Outlet />
完成嵌套路由,但有个前提就是url前缀要一致
/syntax/sp1
✅/syntax1/sp1
❎
说实话初次使用,并没发现有什么好的?可能要再用用才知道作者的用意。
这样的获取数据方式我喜欢。
export let loader = () => {
return {
podcaseName: 'The Syntax Podcase',
episodes: [
{
title: 'Episode 1',
link: 'episode-1',
},
{
title: 'Episode 2',
link: 'episode-2',
},
],
};
};
export default function () {
let { podcaseName, episodes } = useLoaderData();
return <></>
}
获取路由参数也是loader,竟然那么巧妙。
export let loader = ({ params }: any) => {
return params.slug;
};
export default function () {
const slug = useLoaderData();
return <div>({slug})</div>;
}
说实话,这API真够简洁的,真是出来新轮子,你不解决点问题,没人鸟啊。
export let loader = async ({ params }: any) => {
const response = await fetch('https://syntax.fm/api/shows/' + params.show);
return response.json();
};
export default function () {
const show = useLoaderData();
}
我靠,remix真是另辟蹊径,以前大家都是局部最优解,老哥直接全局最优解,这个方式好,我认可。
原来remix分治分得那么溜,把各大疑难问题分散了来解决。
import styles from '~/styles/syntax.css';
// in page file
export function links() {
return [
{
rel: "stylesheet",
href: styles
}
]
}
// incordination with useMatches()
export const handle = {
// object you can anything in
}
// Sets the meta data for a route
export function meta() {
return {
title: 'The Syntax Podcast',
'og:title': 'The Syntax Podcase',
};
}
export function headers() {
// return http headers
// mose common use is caching
}