首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

使用 NextJS 和 TailwindCSS 重构我的博客

+ TailwindCSS + Postgresql 优点: 服务端渲染(SSR) + 静态生成, 访问速度极快,全新 UI 支持换肤; TailwindCSS 在国外如火如荼,但是在国内却很少看到在生产上应用...4、之前写了《使用 CSS variables 和 Tailwind css 实现主题换肤》也运用到了我的博客中。...接下来介绍下 NextJS 主要 API: getServerSideProps 服务端渲染 下面是最简单的客户端渲染代码 import React, { ReactElement, useEffect...id 获取文章详情 export async function getStaticProps({ params }) { // 如果页面的路由是 /posts/1, 这 params.id 的值就是...喜欢的同学可以 fork 一下,免费部署到 Heroku 中,Heroku 支持免费的 Postgresql 数据库,也可以将程序部署到 https://vercel.app/ (国内比较快,不支持数据库

2.4K20

如何在JavaScript中获取单选按钮组的值?

在实际业务开发中,我们常常需要获取用户选择的单选按钮的值,比如用户在注册时选择性别、问卷调查时选择答案等。今天,我们就来聊聊如何在JavaScript中获取单选按钮组的值。...id="genderf" name="gender" value="female" checked /> 女 在这个例子中,...获取单选按钮组的值 在JavaScript中,我们可以使用document.querySelector方法来获取被选中的单选按钮,然后通过它的value属性来获取对应的值。....value:通过value属性获取该单选按钮的值。 所以,当我们运行这段代码时,selectedGender的值会是“female”,因为默认情况下“女”按钮是选中的。...结束 在业务开发中,使用JavaScript来获取单选按钮组的值非常简单。我们只需要利用document.querySelector方法来获取被选中的单选按钮,然后通过value属性来获取其值。

18310
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    使用 NextJS 和 TailwindCSS 重构我的个人博客

    + TailwindCSS + Postgresql 优点: 服务端渲染(SSR) + 静态生成, 访问速度极快,全新 UI 支持换肤; TailwindCSS 在国外如火如荼,但是在国内却很少看到在生产上应用...{js,ts,jsx,tsx}']打包时只会提取使用到的样式,让应用css最小化。 4、之前写了《使用 CSS variables 和Tailwind css实现主题换肤》也运用到了我的博客中。...接下来介绍下 NextJS 主要 API: getServerSideProps 服务端渲染 下面是最简单的客户端渲染代码 import React, { ReactElement, useEffect...}], // 开启其他页面的静态生成 // For example: `/posts/3` fallback: true, } } // 在构建时运行,根据params中的...id 获取文章详情 export async function getStaticProps({ params }) { // 如果页面的路由是 /posts/1, 这 params.id 的值就是

    2.7K20

    Next.js的创建与使用

    NextJs是React的服务器渲染框架,区别于官方SSRNext最大的特点是可以渲染出Ajax异步请求渲染出来的结果,本网站目前使用的前端框架就是NextJs 本文章默认你已将学会了React,如果你不会...),状态管理(redex),或者css(css in js、scss)方案都由社区提供,而Next和React最大的区别就是路由以及成果物的渲染方式,核心库基本没有区别因为在NextJs官网声明了NextJs...在Next中没有单独的文件去配置path和components对应 Next中遵循组件及路由的原则 在page文件夹中: image.png 这样的配置就说明我们注册了5个常规路由一个错误时显示的路由...也可以使用*路由 在对应的文件夹中使用[...all].tsx 在本项目我使用了 image.png 这样就相当于注册了article中的所有路由在访问blogweb.cn/article/* 中凡是...onclick事件,相当于Vue中router-link的tag属性 CSS解决方案 想React一样NextJs支持CSS in Js和CSS模块化引入,但是与React不同的是import '.

    4K20

    如何将NextJs中的File docx保存到Prisma ORM

    背景/引言在现代 Web 开发中,Next.js 是一个备受欢迎的 React 框架,它具有许多优点,如:服务器端渲染 (SSR):Next.js 支持服务器端渲染,可以提高页面加载速度,改善 SEO,...在本文中,我们将探讨如何在 Next.js 应用中处理上传的 Word 文档 (.docx) 文件,并将其内容保存到 Prisma ORM 中。...同时,我们还将介绍如何使用爬虫技术,通过代理 IP 从外部源获取数据。正文1. 设置NextJs项目首先,我们需要创建一个新的NextJs项目,并安装所需的依赖包。...处理文件上传在NextJs中,使用multer中间件来处理文件上传。创建一个API路由来接收上传的文件。...同时,展示了如何使用爬虫代理进行采集,并将爬取到的数据存储到数据库中。通过这些示例代码,开发者可以更好地理解文件处理和数据存储的流程,并灵活应用代理IP技术来扩展数据获取能力。

    15410

    React 设计模式 0x5:服务端渲染 SSR

    相对于客户端渲染(CSR,Client-Side Rendering),SSR 可以提高页面的首屏加载速度和搜索引擎优化(SEO),因为它可以在服务器端直接生成 HTML,并将静态资源(如 CSS、JavaScript...零配置 优秀的开发者体验 使用 NextJS,我们花更多的时间编写功能,而不是在构建工具和 Webpack 上挣扎 自动路由 NextJS 将项目结构化为页面,并添加路由 数据获取 根据应用程序的用例以不同的方式呈现内容...SEO 相关的因素 性能 # 缺点 研发管理 如果你想使用 NextJS 构建一个在线商店,但是你没有内部的开发团队,你将需要一个专门负责开发和管理的人员 路由问题 由于基于文件的路由限制了...Next.js 在节点路由方面的能力,因此如果你的项目需要动态路由,你将不得不使用 Node.js 服务器 没有状态管理器 Next.js 框架中没有内置的状态管理器 为了充分利用状态管理器,你将需要另一个工具来完成它...通过导出名为 getServerSideProps 的异步函数,可以在每个请求时生成 HTML。

    3.9K10

    梳理NextJS13两种路由下的不同渲染方式:SSG,ISR,SSR,RSC

    前言 NextJS是一款基于 React 进行全栈开发的框架,是当下非常火的React全栈框架之一,在去年NextJS发布了V13版本,而本文将基于V13版本的app路由,来梳理它的几种不同的渲染方式的实现...官方文档传送门:nextjs.org/docs SSR SSR也就是服务端渲染,页面在后端先获取到数据,然后发回前端注水渲染,如果你不是很熟悉,可以先看一下SSR相关的文章介绍。...这个API,在请求页面的时候,提前获取到数据,然后传入组件中。...,只需要直接在组件中获取数据即可。...Nextjs在组件中指定了dynamicParams的值(true默认),当dynamicParams设置为true时,当请求尚未生成的路由段时,我们的页面将通过SSR这种方式来进行渲染。

    1.9K31

    Next.js静态页面渲染技术(静态生成和服务端渲染):BSRSSRSSG

    适合前后端交互不多的页面,如CMS(文章管理系统)生成静态页面、SSR(服务端渲染)是每次请求都生产新HTML(传统BS框架PHP、Python、Ruby、Java后台的基本功能)Sever Site...一般来说,静态内容在代码里写死的,动态内容是来自数据库的。在next中,图上的静态内容会在服务器渲染一次,客户端再渲染一次,为什么?...客户端渲染的缺点:白屏:在ajax得到响应之前,页面中之后Loading。...getServerSideProps:运行时机:无论是开发环境还是生产环境都是在请求到来之后运行getServerSideProps。.../SSG》,请注明出处:https://www.zhoulujun.cn/html/webfront/server/nextjs/8793.html

    3.8K20

    助力ssr,使用concent为nextjs应用加点料

    开源不易,感谢你的支持,❤ star concent^_^ [image.png] 序言 nextjs是一个非常流行的 React 服务端渲染应用框架,它很轻量,简单易上手,社区活跃,所以当我们使用react...写一个需要ssr(server side render)的应用的话,基本都会首选nextjs,concent是一个新生代的react状态管理方案,它内置依赖收集系统,同时兼具有0入侵、可预测、渐进式、高性能的特点...Demo(){ // 如 state 和 moduleComputed 是按需读取的,推荐延迟解构的写法 const { state: { num, numBig }, moduleComputed...// 此函数在每次请求改页面时被调用 export async function getServerSideProps() { // 调用外部 API 获取博文列表 const res = await...store即可 // 此函数在每次请求时被调用 export async function getServerSideProps() { // 调用外部 API 获取博文列表 await delay

    2.5K81

    如何在 WPF 中获取所有已经显式赋过值的依赖项属性

    获取 WPF 的依赖项属性的值时,会依照优先级去各个级别获取。这样,无论你什么时候去获取依赖项属性,都至少是有一个有效值的。有什么方法可以获取哪些属性被显式赋值过呢?...如果是 CLR 属性,我们可以自己写判断条件,然而依赖项属性没有自己写判断条件的地方。 本文介绍如何获取以及显式赋值过的依赖项属性。...---- 需要用到 DependencyObject.GetLocalValueEnumerator() 方法来获得一个可以遍历所有依赖项属性本地值。...} } 这里的 value 可能是 MarkupExtension 可能是 BindingExpression 还可能是其他一些可能延迟计算值的提供者。...因此,你不能在这里获取到常规方法获取到的依赖项属性的真实类型的值。 但是,此枚举拿到的所有依赖项属性的值都是此依赖对象已经赋值过的依赖项属性的本地值。如果没有赋值过,将不会在这里的遍历中出现。

    21040

    Web3 全栈指南

    在这篇文章中,我们将了解如何在前端应用中,使用 HTML 和 JavaScript 与链上应用(智能合约或其他应用)交互。...如何在网站上调用我的智能合约执行交易? 最好的实践都在做什么工具? 我在问自己这个问题时,看了几乎所有最流行的解决方案,并试图弄清楚应该向开发者推荐什么。...如何将使用 Metamask 连接到智能合约 当然也可以是其他的钱包,如浏览器中的另一个钱包,如 Phantom、Walletconnect 等。...用 HTML 和 JavaScript 连接到加密货币钱包 我们将首先展示这一切是如何在 HTML 和 JavaScript 中完成的,然后我们将转向使用 Nextjs/React 例子。...我们用NextJS[39]来做这些工作,因为ReactJS[40]是目前地球上最流行的前端框架,而 NextJS 是建立在它之上的,在我看来,它比原始的 ReactJS 更方便使用。

    5K21

    React 应用架构实战 0x5:集成 API 到应用中

    我们将学习如何在客户端和服务器上获取数据,对于 HTTP 客户端,我们将使用 Axios,并使用 React Query 库来处理获取到的数据,它允许我们在 React 应用程序中处理 API 请求和响应...(null); const [loading, setLoading] = useState(false); const [error, setError] = useState(null);...,那么这样做是可以的,但在大多数情况下,我们需要从许多不同的地方获取数据。...React Query 的另一个好处是它的缓存机制。对于每个查询,我们需要提供相应的查询键,用于将数据存储在缓存中。 这也有助于请求的去重。...它仅在开发中工作,对于调试非常有用。 # 给功能逻辑添加 API 层 每个功能的 API 层将在 api 文件夹中定义。API 请求可以是查询或更新。

    1.6K20

    基于 Next.js 的 SSRSSG 方案了解一下?

    async function getStaticProps() { // 获取数据,例如从数据库、API、文件等 const data = ... // 返回的参数将会按照 key 值赋值到...SEO 优化的,其数据通常需要实时更新获取,因此采用 SSR 的方式,而 SSR 在服务端获取数据可以借助 getServerSideProps 方法 和构建时获取数据方法类似: export default...function HomePage(props) { ... } // 导出异步获取数据方法 export async function getServerSideProps() { // 获取数据...,例如从数据库、API、文件等 const data = ... // 返回的参数将会按照 key 值赋值到 HomePage 组件的同名入参中 return { props: ....id 找不到对应值,则指向 404 页面 } } export async function getStaticProps({ params }) { // 通过 params.id 获取必要的文章数据

    5.5K30

    动手练一练,使用 React 和 Next.js 做一个简单的博客网站(下)

    (上)》和 《动手练一练,使用 React 和 Next.js 做一个简单的博客网站(中)》这两篇文章里,我们一起完成了一个基于 MakeDown 文档为内容页源的博客网站,学习了动态路由(Dynamic...1、我们现在 /pages/about.js 页面里添加 getServerSideProps() 函数,这个方法里我们使用 node-fetch 模块,获取 API 数据后,通过 props 将返回的数据通过组件属性进行传递...const [href, setHref] = React.useState(window.location.href); 为了修复这个问题,我们可以将初始值赋值null。...styles.themetoggle + ' ' + styles[theme] } title="switch theme" /> ); } 由于服务端无法访问客户端模式的初始值...,使用 React 和 Next.js 做一个简单的博客网站(中)》 结束语 到这里,本案例就介绍完了,本案例的完整源码,你可以点击阅读原文下载本案例的完整源码。

    1.6K31

    React项目中如何实现一个简单的锚点目录定位

    前言 锚点目录定位功能在长页面和文档类网站中非常常见,它可以让用户快速定位到页面中的某个章节 如何在React中实现锚点定位和平滑滚动 目录自动高亮的实现思路 处理顶部导航遮挡锚点的解决方案 服务端渲染下的实现方案...在使用了服务端渲染(SSR)的框架如Next.js等情况下,实现锚点定位和目录联动也会有一些不同。...服务端渲染的静态HTML中,并没有绑定滚动事件,所以无法自动高亮。 预取数据 首先,我们需要解决点击目录链接的问题。 既然服务端无法获取组件ref,那就需要在客户端去获取元素位置。...简单来说就是: 在服务端渲染时,读取路由参数,提前计算高亮状态 将高亮数据注入到响应中 客户端拿到注水的数据后渲染,不会出现高亮错位 实现步骤: 1.服务端获取参数和数据 // 在getServerSideProps...中 export async function getServerSideProps(context) { const { hashtag } = context.query; const

    1.2K20

    Next.js 14 App Router引入 farmer-motion 初始化异常解决,顺带学点知识

    在 App Router 中,NextJS 将会区分 Client Components和 Server Components, Server Components 是一种特殊的 React 组件,它不是在浏览器端运行...又因为它们没有状态,所以不能使用只存在于客户端的特性(也就是说 useState、useEffect 那些都是用不了的,包括 window 对象这些),所以一般我们可以用于获取数据,或者对非客户端组件进行渲染...,useState ,onClick特性!!...onClick={() => setCount(count + 1)}>Click me ) } next.js 这两个指令相关介绍可以这两个文档 nextjs.org.../docs/app/bu… nextjs.org/docs/app/bu… 这两个指令虽然是 next.js 团队提出来并用在了框架里面, 但是很大概率会整到 React 19 里面去!

    27510

    5w字长文带你【从0使用NextJS+SSR开发博客系统】 | 技术创作特训营第五期

    NextJS介绍 Next.js 是一个用于构建 React 应用程序的 React 框架。它的目标是使 React 应用的开发变得更简单、更灵活。...github上创建一个项目仓库,比如:nextjs-blog 将nextjs-blog仓库使用git拉取到本地git clone xxx.nextjs-blog.git 然后进入项目目录cd nestjs-blog...提供 getServerSideProps 来获取数据,返回到props中,然后在react组件中通过props获取数据进行渲染,达到ssr效果。...通过props获取 文章和标签 const { articles = [], tags = [] } = props; 7.默认将 获取的 文章,存放到所有文章的state中 const [showAricles...通过props获取article数据 1.将 文章标题,文章内容通过state来控制,初始值是props获取的数据 const [title, setTitle] = useState(article?

    1.6K30

    Next.js - SSR SSG CSR ISR Dynamic Routing

    Next.js 提供了多种网页渲染方式,这取决于你的服务应用的场景,包括服务端渲染、客户端渲染、静态生成、增量静态生成等。...useEffect 中请求服务端数据再渲染组件,该动作在页面基本静态文件加载完毕后执行,示例代码如下:function Profile() { const [data, setData] = useState...(null) const [isLoading, setLoading] = useState(false) useEffect(() => { setLoading(true) fetch...SWR 的 React Hook 包,如果使用客户端渲染的话,强烈推荐使用 SWR,它可以处理缓存、重新验证、焦点跟踪、间隔重新获取等。...Dynamic Routing在 Next.js 中配合使用 getStaticPaths + getStaticProps 即可实现动态路由的预渲染,该动作在 next build 时执行,示例代码:

    1.2K20
    领券