文档:https://nextjs.org/docs/getting-started
1 创建项目TS
yarn create next-app --typescript nextjs_demo
2. 配置项目
修改_app.tsx
, 各种Provider
都可以写在这里
import '../styles/globals.css'
import 'antd/dist/antd.css'
import type { AppProps } from 'next/app'
import { ThemeProvider } from 'styled-components'
function MyApp({ Component, pageProps }:AppProps) {
return <ThemeProvider theme={{
color:'red',
fontSize:'40px'
}}>
<Component {...pageProps} />
</ThemeProvider>
}
export default MyApp
3. next/image
的使用
<Image
src={'https://gimg2.baidu.com/image_search/src=http%3A%2F%2Fi2.hdslb.com%2Fbfs%2Farchive%2F3c90eb673244c95ff63bf3255230d1070a56a8e5.jpg&refer=http%3A%2F%2Fi2.hdslb.com&app=2002&size=f9999,10000&q=a80&n=0&g=0n&fmt=auto?sec=1664009576&t=b38110e63b3bf95d420e63b9c9c81f53'}
width={800}
height={312}
placeholder="blur"
blurDataURL=''
/>
4. 静态资源放到public
文件夹下
5.getServerSideProps 和 getStaticProps 的区别
getStaticProps
:构建时就会执行,服务器上运行,生成静态HTML,每个人请求就会很快返回,不会白屏
https://nextjs.org/docs/basic-features/data-fetching/get-static-props
- 纯静态页面
- 页面数据基本不变、许久变一次
export async function getStaticProps() {
const res = await fetch('https://.../posts')
const posts = await res.json()
return {
props: {
posts,
},
revalidate: 24*60*60, //1天更新一次 (单位秒)
}
}
getServerSideProps
:预渲染数据,每次页面请求都会执行
https://nextjs.org/docs/basic-features/data-fetching/get-server-side-props
- 预渲染数据,先请求一屏的数据缓存起来(看起来页面加载快、无白屏)
6.页面动态导入(取消服务器渲染,比如本地判断window、isMobile等)
页面中的各种组件也可以动态导入(先显示loading)
index.tsx
import dynamic from 'next/dynamic'
export default dynamic(
()=>import('./views/home'),
{
ssr:false,
loading:()=><></>
}
)
7. 安装styled-components
yarn add babel-plugin-styled-components --dev
.babelrc
{
"presets": ["next/babel"],
"plugins": [
["styled-components", { "ssr": true, "displayName": true }],
[
"import",
{
"libraryName":"antd"
}
]
]
}
8.导入google字体,创建_document.tsx
import Document, { Html, Head, Main, NextScript } from "next/document";
class MyDocument extends Document {
static async getInitialProps(ctx:any) {
const initialProps = await Document.getInitialProps(ctx);
return { ...initialProps };
}
render() {
return (
<Html>
<Head>
<link
href="https://fonts.googleapis.com/css2?family=Lobster"
rel="stylesheet"
/>
<link
href="https://fonts.googleapis.com/css2?family=Roboto Condensed"
rel="stylesheet"
/>
</Head>
<body>
<Main />
<NextScript />
</body>
</Html>
);
}
}
export default MyDocument;
9.部署服务器nginx
1. 部署到自己的服务器上(联系后台人员进行配置)
http://www.shanhuxueyuan.com/news/detail/111.html
nextjs打包后的文件存储在.next文件夹,但是只有这个文件夹下的内容是不够的,因为要在node端运行,还需要next以及react及reactDom等,简单起见,我们可以把整个项目都传到服务器。这样的缺点就是node_modules比较大,不过这样最简单。 在服务器端,进入项目路径 依次执行 npm run build ,npm run start即可将项目运行在服务器端,默认是localhost:3000,我们肯定是要通过域名访问项目,因此还需要进行域名配置,可通过nginx反向代理来实现。
server {
listen 80;
server_name yourdomain.com;
error_log /var/log/nginx/yourdomain_error.log;
location / {
proxy_pass
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
}
}
现在可以通过域名访问了,但是还是存在一个问题,就是我们刚才执行的npm run start命令,必须打开命令行才有效,一旦关闭命令行,进程也终止了,简单的做法就是通过nohup在后台执行 npm run start ,这样关闭命令行仍然有效。
nohup npm run start &
- PM2是node进程管理工具,可以利用它来简化很多node应用管理的繁琐任务,如性能监控、自动重启、负载均衡等,而且使用非常简单
npm install -g pm2
为了简单的使用pm2,我们先把项目下的package.json中添加一个server指令,server指令依次执行next build和next start
"scripts": {
"dev": "next",
"build": "next build",
"start": "next start",
"server":"next build && next start", //添加server指令
},
进入到项目所在目录
执行如下命令
pm2 start npm --name yourName -- run server --watch
将yourName换成你的项目名,这个是给这个进程起的名称,可以随意
--watch代表监听项目文件,当文件发生变化是,自动重新加载如下指令,这样就很方便了,当我们更改代码之后,只需要传到服务器即可,pm2会自动监听,重新执行 npm run server
这样就完成服务器部署了,可能有的同学还想服务器重启之后自动运行这个命令,使用pm2也很简单只需执行如下命令即可
pm2 startup
2. 部署到vercel
上(最后的链接如此:https://nextjs-demo-self.vercel.app/)
- 将代码
push
到自己的github
上
- 将代码
- 2.打开
https://vercel.com/dashboard
用自己的github
账号登录,选择项目 - 如果自定义了输出目录这里也要改成一致
const nextConfig = {
reactStrictMode: true,
swcMinify: true,
images: {
domains: ['gimg2.baidu.com'],
},
// distDir: 'build',
exportPathMap: async function (
defaultPathMap,
{ dev, dir, outDir, distDir, buildId }
) {
return {
'/': { page: '/' },
};
},
images: {
loader: 'akamai',
path:'',
}
}
- deploy