Next.js使用用来做什么,具体是怎样的
Admin 2022-07-18 群英技术资讯 986 次浏览
这篇文章主要介绍“Next.js使用用来做什么,具体是怎样的”的相关知识,下面会通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Next.js使用用来做什么,具体是怎样的”文章能帮助大家解决问题。Next.js 是一个轻量级的 React 服务端渲染应用框架。
官网链接:www.nextjs.cn/
优点:
零配置
自动编译并打包。从一开始就为生产环境而优化。
混合模式: SSG 和 SSR
在一个项目中同时支持构建时预渲染页面(SSG)和请求时渲染页面(SSR)
增量静态生成
在构建之后以增量的方式添加并更新静态预渲染的页面。
支持 TypeScript
自动配置并编译 TypeScript。
快速刷新
快速、可靠的实时编辑体验,已在 Facebook 级别的应用上规模上得到验证。
基于文件系统的路由
每个 pages 目录下的组件都是一条路由。
API 路由
创建 API 端点(可选)以提供后端功能。
内置支持CSS
使用 CSS 模块创建组件级的样式。内置对 Sass 的支持。
代码拆分和打包
采用由 Google Chrome 小组创建的、并经过优化的打包和拆分算法。
mkdir nextDemo //创建项目 npm init //初始化项目 npm i react react-dom next --save //添加依赖
在package.json中添加快捷键命令
"scripts": {
"test": "echo \"Error: no test specified\" && exit 1",
"dev" : "next" ,
"build" : " next build",
"start" : "next start"
},
创建pages文件夹和文件
在项目根目录创建pages文件夹并在pages文件夹中创建index.js文件
function Index(){
return (
<div>Hello Next.js</div>
)
}
export default Index
运行项目
npm run dev
create-next-app可以快速的创建Next.js项目,它就是一个脚手架。
npm install -g create-next-app //全局安装脚手架 create-next-app nextDemo //基于脚手架创建项目 cd nextDemo npm run dev //运行项目
目录结构介绍:
在 Next.js 中,一个 page(页面) 就是一个从 .js、jsx、.ts 或 .tsx 文件导出(export)的React 组件 ,这些文件存放在 pages 目录下。每个 page(页面)都使用其文件名作为路由(route)。
如果你创建了一个命名为 pages/about.js 的文件并导出(export)一个如下所示的 React 组件,则可以通过 /about 路径进行访问。
页面跳转一般有两种形式,第一种是利用标签<Link>,第二种是用js编程的方式进行跳转,也就是利用Router组件
import React from 'react'
import Link from 'next/link'
const Home = () => (
<>
<div>我是首页</div>
<div><Link href="/pageA" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><a>去A页面</a></Link></div>
<div><Link href="/pageB" rel="external nofollow" ><a>去B页面</a></Link></div>
</>
)
export default Home
注意:用<Link>标签进行跳转是非常容易的,但是又一个小坑需要你注意一下,就是他不支持兄弟标签并列的情况。
//错误写法
<div>
<Link href="/pageA" rel="external nofollow" rel="external nofollow" rel="external nofollow" >
<span>去A页面</span>
<span>前端博客</span>
</Link>
</div>
//正确写法
<Link href="/pageA" rel="external nofollow" rel="external nofollow" rel="external nofollow" >
<a>
<span>去A页面</span>
<span>前端博客</span>
</a>
</Link>
import Router from 'next/router'
<button onClick={()=>{Router.push('/pageA')}}>去A页面</button>
在Next.js中只能通过通过query(?id=1)来传递参数,而不能通过(path:id)的形式传递参数。
import Link from 'next/link'
//传递
<Link href="/blogDetail?bid=23" rel="external nofollow" ><a>{blog.title}</a></Link>
//blog.js
import { withRouter} from 'next/router'
import Link from 'next/link'
const BlogDetail = ({router})=>{
return (
<>
<div>blog id: {router.query.name}</div>
<Link href="/" rel="external nofollow" ><a>返回首页</a></Link>
</>
)
}
//withRouter是Next.js框架的高级组件,用来处理路由用的
export default withRouter(BlogDetail)
/************************************************************************************/
import Router from 'next/router'
<button onClick={gotoBlogDetail} >博客详情</button>
function gotoBlogDetail(){
Router.push('/blogDetail?bid=23')
}
//object 形式
function gotoBlogDetail(){
Router.push({
pathname:"/blogDetail",
query:{
bid:23
}
})
}
<Link href={{pathname:'/blogDetail',query:{bid:23}}><a>博客详情</a></Link>
pages/post/[pid].js
route : /post/abc --> query : { "pid": "abc" }
pages/post/[pid]/[comment].js
route : /post/abc/a-comment --> query : { "pid": "abc", "comment": "a-comment" }
利用钩子事件是可以作很多事情的,比如转换时的加载动画,关掉页面的一些资源计数器.....
//路由发生变化时
Router.events.on('routeChangeStart',(...args)=>{
console.log('1.routeChangeStart->路由开始变化,参数为:',...args)
})
//路由结束变化时
Router.events.on('routeChangeComplete',(...args)=>{
console.log('routeChangeComplete->路由结束变化,参数为:',...args)
})
//浏览器 history触发前
Router.events.on('beforeHistoryChange',(...args)=>{
console.log('3,beforeHistoryChange->在改变浏览器 history之前触发,参数为:',...args)
})
//路由跳转发生错误时
Router.events.on('routeChangeError',(...args)=>{
console.log('4,routeChangeError->跳转发生错误,参数为:',...args)
})
/****************************hash路由***********************************/
Router.events.on('hashChangeStart',(...args)=>{
console.log('5,hashChangeStart->hash跳转开始时执行,参数为:',...args)
})
Router.events.on('hashChangeComplete',(...args)=>{
console.log('6,hashChangeComplete->hash跳转完成时,参数为:',...args)
})
在build阶段将页面构建成静态的html文件,这样线上直接访问HTML文件,性能极高。
使用getStaticProps方法在build阶段返回页面所需的数据。
如果是动态路由的页面,使用getStaticPaths方法来返回所有的路由参数,以及是否需要回落机制。
// posts will be populated at build time by getStaticProps()
function Blog({ posts }) {
return (
<ul>
{posts.map((post) => (
<li>{post.title}</li>
))}
</ul>
)
}
// This function gets called at build time on server-side.
// It won't be called on client-side, so you can even do
// direct database queries. See the "Technical details" section.
export async function getStaticProps(context) {
// Call an external API endpoint to get posts.
// You can use any data fetching library
const res = await fetch('https://.../posts')
const posts = await res.json()
// By returning { props: { posts } }, the Blog component
// will receive `posts` as a prop at build time
return {
props: {
posts,
},
}
}
export default Blog
页面中export一个async的getServerSideProps方法,next就会在每次请求时候在服务端调用这个方法。
function Page({ data }) {
// Render data...
}
// This gets called on every request
export async function getServerSideProps(context) {
// Fetch data from external API
const res = await fetch(`https://.../data`)
const data = await res.json()
// Pass data to the page via props
return { props: { data } }
}
export default Page
要将样式表添加到您的应用程序中,请在 pages/_app.js 文件中导入(import)CSS 文件。
在生产环境中,所有 CSS 文件将自动合并为一个经过精简的 .css 文件。
你应该 只在 pages/_app.js 文件中导入(import)样式表。
从 Next.js 9.5.4 版本开始,你可以在应用程序中的任何位置从 node_modules 目录导入(import) CSS 文件了。
对于导入第三方组件所需的 CSS,可以在组件中进行。
[name].module.css
//login.module.css
.loginDiv{
color: red;
}
//修改第三方样式
.loginDiv :global(.active){
color:rgb(30, 144, 255) !important;
}
import styles from './login.module.css'
<div className={styles.loginDiv}/>
Next.js 允许你导入(import)具有 .scss 和 .sass 扩展名的 Sass 文件。 你可以通过 CSS 模块以及 .module.scss 或 .module.sass 扩展名来使用组件及的 Sass
npm i sass --save
如果要配置 Sass 编译器,可以使用 next.config.js 文件中的 sassOptions 参数进行配置。
const path = require('path')
module.exports = {
sassOptions: {
includePaths: [path.join(__dirname, 'styles')],
},
}
CSS-in-JS
可以使用任何现有的 CSS-in-JS 解决方案。 最简单的一种是内联样式:
<p style={{ color: 'red' }}>hi there</p>
使用 styled-jsx 的组件就像这样
function HelloWorld() {
return (
<div>
Hello world
<p>scoped!</p>
<style jsx>{`
p {
color: blue;
}
div {
background: red;
}
@media (max-width: 600px) {
div {
background: blue;
}
}
`}</style>
<style global jsx>{`
body {
background: black;
}
`}</style>
</div>
)
}
export default HelloWorld
自定义Header
<Head>
<title>技术胖是最胖的!</title>
<meta charSet='utf-8' />
</Head>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
Vue3 在经过多个开发版本的迭代后,终于迎来了它的正式版本,下面这篇文章主要给大家介绍了关于如何使用vue3实现一个人喵交流小程序的相关资料,需要的朋友可以参考下
本篇文章带大家了解一下RPC通信,介绍一下RPC和Ajax的相同点和不同点,希望对大家有所帮助!
本篇文章给大家带来了关于JavaScript中面向对象的相关知识,其中包括面向对象、构造函数以及继承的相关问题,希望对大家有帮助。
javascript修改td值的方法:1、利用innerHTML属性,语法“指定td节点.innerHTML = "新内容";”;2、利用innerText属性,语法“指定td节点.innerText = "新内容";”。
Webpack 是一个前端资源加载/打包工具。它将根据模块的依赖关系进行静态分析,然后将这些模块按照指定的规则生成对应的静态资源,这篇文章主要介绍了JavaScript中Webpack的使用,需要的朋友可以参考下
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008