使用 Next.js 和 Tailwind CSS 搭建静态图片展示站点并部署到 Vercel

J.sky
vercel
next.js
tailwind.css
2024/11/2

在本文中,我们将介绍如何使用 Next.js(纯.js 文件,不使用.jsx)和 Tailwind CSS 搭建一个静态图片展示站点。该站点将具有首页以瀑布流模式展示图片,点击图片可跳转到图片展示页面,所有图片信息存储在一个 JSON 文件中,并且为每个图片生成单独的静态页面。最后,我们将把这个站点部署到 Vercel。

效果展示:

演示

一、建站构思

(一)功能需求

首页以瀑布流布局展示图片,让用户可以快速浏览多个图片。 点击图片能够跳转到对应的图片展示页面,显示图片的详细信息,包括标签和简介。 所有图片存储在特定目录下,方便管理和维护。 使用 JSON 文件存储图片的相关信息,便于动态读取和生成页面。

(二)技术选择

Next.js:Next.js 是一个用于构建服务器端渲染和静态生成的 React 框架。它提供了很多强大的功能,如路由、代码分割、静态导出等,非常适合构建高性能的 Web 应用。 Tailwind CSS:Tailwind CSS 是一个实用工具类优先的 CSS 框架,可以快速构建美观的用户界面。它提供了丰富的预定义样式类,使得开发过程更加高效。 JSON 文件:用于存储图片的相关信息,方便读取和管理。 Vercel:一个优秀的云平台,用于部署 Next.js 应用,提供快速的部署、全球 CDN 加速和自动扩展等功能。

二、代码编写步骤

(一)项目初始化

创建一个 Next.js 项目: 确保已经安装了npx(如果使用npm版本大于 5.2.0),然后运行以下命令创建项目:

npx create-next-app picture-gallery-app

进入项目目录:

cd picture-gallery-app

安装 Tailwind CSS:

按照官方文档安装依赖:

npm install -D tailwindcss postcss autoprefixer
npx tailwindcss init -p

在tailwind.config.js文件中,配置内容路径:

module.exports = {
content: [
    "./pages/**/*.{js,ts,jsx,tsx}",
    "./components/**/*.{js,ts,jsx,tsx}",
],
theme: {
    extend: {},
},
plugins: [],
};

在styles/globals.css中导入 Tailwind 的基础样式:

@tailwind base;
@tailwind components;
@tailwind utilities;

(二)创建图片数据 JSON 文件

在项目根目录下创建一个images.json文件,示例结构如下:

[
{
    "imagePath": "/images/image1.jpg",
    "tags": ["nature", "landscape"],
    "description": "A beautiful landscape photo."
},
{
    "imagePath": "/images/image2.jpg",
    "tags": ["city", "architecture"],
    "description": "An amazing architecture in the city."
}
]

(三)创建首页组件(pages/index.js)

import Link from 'next/link';
import data from '../images.json';
import Image from 'next/image';

const HomePage = () => {
return (
    <div className="container mx-auto px-4 py-8">
    <h1 className="text-3xl font-bold mb-8">Picture Gallery</h1>
    <div className="grid grid-cols-1 sm:grid-cols-2 md:grid-cols-3 lg:grid-cols-4 gap-4">
        {data.map((image, index) => (
        <Link key={index} href={`/image/${index}`}>
            <a className="block relative">
            <Image
                src={image.imagePath}
                alt={image.description}
                width={300}
                height={200}
                layout="responsive"
                className="object-cover w-full h-full rounded-lg"
            />
            </a>
        </Link>
        ))}
    </div>
    </div>
);
};

export default HomePage;

(四)创建单个图片展示页面组件(pages/image/[id].js)

import data from '../../images.json';
import Image from 'next/image';

const ImagePage = ({ params }) => {
const { id } = params;
const image = data[id];
return (
    <div className="container mx-auto px-4 py-8">
    <Link href="/">
        <a className="text-blue-500 mb-4">Back to Home</a>
    </Link>
    <Image
        src={image.imagePath}
        alt={image.description}
        width={600}
        height={400}
        layout="responsive"
        className="object-cover w-full h-full rounded-lg mb-4"
    />
    <h2 className="text-2xl font-bold mb-2">{image.description}</h2>
    <p className="text-gray-700">Tags: {image.tags.join(', ')}</p>
    </div>
);
};

export default ImagePage;

三、部署到 Vercel

(一)前期准备

确保你的 Next.js 项目已经开发完成并且在本地能够正常运行。项目结构应该包括 package.json 文件、页面组件、样式文件等。 如果你的项目使用了环境变量,确保将敏感的环境变量设置为在 Vercel 上可配置的变量,或者使用 .env.local 文件来存储本地开发环境变量,而在生产环境中使用 Vercel 的环境变量配置功能。

(二)连接 Vercel

注册并登录 Vercel。 在 Vercel 控制台,点击 “New Project”(新建项目)按钮。 选择 “Import Git Repository”(导入 Git 仓库)选项。如果你的项目已经托管在 Git 平台(如 GitHub、GitLab、Bitbucket 等),Vercel 会自动检测到你的仓库并列出。选择你的 Next.js 项目仓库。

(三)配置项目

Vercel 会自动检测项目的框架为 Next.js,并显示一些默认的配置选项。 在 “Project Settings”(项目设置)中,可以设置项目名称、环境变量、构建和输出目录等。 如果你的项目有特定的构建命令或环境变量需求,可以在 “Build & Development Settings”(构建和开发设置)中进行配置。例如,默认情况下,Vercel 会使用 npm install 和 npm run build 作为构建命令,但如果你的项目有不同的构建流程,可以在这里进行修改。

(四)部署项目

完成配置后,点击 “Deploy”(部署)按钮。Vercel 会开始克隆你的 Git 仓库、安装依赖、构建项目,并将构建后的项目部署到 Vercel 的全球 CDN 网络上。 部署过程中,你可以在控制台查看构建日志和部署进度。一旦部署完成,Vercel 会提供一个项目的访问 URL,你可以通过这个 URL 访问你的 Next.js 项目。 通过以上步骤,我们成功地使用 Next.js 和 Tailwind CSS 搭建了一个静态图片展示站点,并将其部署到了 Vercel。这个站点具有良好的用户体验和性能,可以让用户轻松浏览和查看图片。以上就是一个简单的 Next.js 静态图片展示站点的搭建和部署过程,但着只是一个简单的示例,你可以根据自己的需求和项目特点进行更复杂的定制和扩展。

项目演示地址:https://suipian.suiyan.cc

项目源码地址:https://github.com/bosichong/suipian