cari
Rumahhujung hadapan webtutorial jsNext.js dan SSR: Membina aplikasi yang diberikan pelayan berprestasi tinggi

Next.js and SSR: Building high-performance server-rendered applications

1. Buat projek

Buat projek Next.js baharu dengan perancah create-next-app:

npx create-next-app my-app
cd my-app

2. SSR automatik

Dalam Next.js, setiap komponen fail .js atau .jsx akan diproses secara automatik sebagai halaman SSR. Contohnya, buat fail pages/index.js:

// pages/index.js
import React from 'react';

function Home() {
  return (
    <div>
      <h1 id="Welcome-to-Next-js-with-SSR">Welcome to Next.js with SSR!</h1>
      <p>This is rendered on the server.</p>
    </div>
  );
}

export default Home;

Jalankan npm run dev untuk memulakan pelayan pembangunan, lawati http://localhost:3000, dan anda akan mendapati bahawa HTML sudah mengandungi kandungan yang diberikan pelayan.

3. Penghalaan dinamik dan pemerolehan data

Next.js menyokong penghalaan dinamik, seperti halaman/siaran/[id].js. Dapatkan data dalam getStaticPaths dan getStaticProps atau getServerSideProps:

// pages/posts/[id].js
import { useRouter } from 'next/router';
import { getPostById } from '../lib/api'; // Custom API to obtain data

export async function getServerSideProps(context) {
  const id = context.params.id;
  const post = await getPostById(id);

  return {
    props: {
      post,
    },
  };
}

function Post({ post }) {
  const router = useRouter();
  if (!router.isFallback && !post) {
    router.push('/404');
    return null;
  }

  return (
    <div>
      <h1 id="post-title">{post.title}</h1>
      <p>{post.content}</p>
    </div>
  );
}

export default Post;

4. Pengoptimuman statik dan pra-penyampaian

Next.js juga menyokong pengoptimuman statik dan prapemarahan (Penjanaan Tapak Statik, SSG). Konfigurasikan dalam getStaticPaths dan getStaticProps:

// pages/posts/[id].js
export async function getStaticPaths() {
  // Get all possible dynamic paths
  const paths = await getPostIds();

  return {
    paths: paths.map((id) => `/posts/${id}`),
    fallback: false, // Or 'true' to return 404 for non-prerendered paths
  };
}

export async function getStaticProps(context) {
  const id = context.params.id;
  const post = await getPostById(id);

  return {
    props: {
      post,
    },
  };
}

6. Import dinamik dan pemisahan kod

Next.js menyokong import dinamik, yang membantu memuatkan kod atas permintaan dan mengurangkan masa pemuatan awal:

// pages/index.js
import dynamic from 'next/dynamic';

const DynamicComponent = dynamic(() => import('../components/Dynamic'), {
  ssr: false, // Avoid rendering on the server
});

function Home() {
  return (
    <div>
      <h1 id="Welcome-to-Next-js-with-SSR">Welcome to Next.js with SSR!</h1>
      <dynamiccomponent></dynamiccomponent>
    </div>
  );
}

export default Home;

7. Optimumkan imej dan sumber

Gunakan komponen seterusnya/imej untuk mengoptimumkan pemuatan imej, pemampatan automatik dan saiz semula:

// pages/index.js
import Image from 'next/image';

function Home() {
  return (
    <div>
      <h1 id="Welcome-to-Next-js-with-SSR">Welcome to Next.js with SSR!</h1>
      <image src="/example.jpg" alt="Example Image" width="{500}" height="{300}"></image>
    </div>
  );
}

export default Home;

8. Pelayan Tersuai

Jika anda memerlukan kawalan yang lebih terperinci, anda boleh membuat pelayan tersuai:

// server.js
const { createServer } = require('http');
const { parse } = require('url');
const next = require('next');

const dev = process.env.NODE_ENV !== 'production';
const app = next({ dev });
const handle = app.getRequestHandler();

app.prepare().then(() => {
  createServer((req, res) => {
    // Be sure to pass `true` as the second argument to `url.parse`.
    // This tells it to parse the query portion of the URL.
    const parsedUrl = parse(req.url, true);
    const { pathname } = parsedUrl;

    if (pathname === '/api') {
      // Custom API route handling
      // ...
    } else {
      handle(req, res, parsedUrl);
    }
  }).listen(3000, (err) => {
    if (err) throw err;
    console.log('> Ready on http://localhost:3000');
  });
});

9. Mengintegrasikan perpustakaan dan rangka kerja pihak ketiga

Next.js membolehkan anda menyepadukan perpustakaan dan rangka kerja pihak ketiga dengan mudah, seperti Redux, MobX, Apollo, dsb.:

// pages/_app.js
import React from 'react';
import App from 'next/app';
import { Provider } from 'react-redux';
import store from '../store';

function MyApp({ Component, pageProps }) {
  return (
    <provider store="{store}">
      <component></component>
    </provider>
  );
}

export default MyApp;

10. Optimumkan SEO

Ciri SSR Next.js mesra SEO, tetapi anda juga boleh mengoptimumkannya melalui tag meta:

// pages/index.js
import Head from 'next/head';

function Home() {
  return (
    
      
        <title>My Next.js App</title>
        <meta name="description" content="This is an example of using Next.js with SEO.">
      
      <h1 id="Welcome-to-Next-js-with-SEO">Welcome to Next.js with SEO!</h1>
    >
  );
}

export default Home;

11. Pengantarabangsaan (i18n)

Next.js 10 memperkenalkan sokongan i18n terbina dalam, menjadikannya mudah untuk melaksanakan tapak web berbilang bahasa:

// next.config.js
module.exports = {
  i18n: {
    locales: ['en', 'fr'],
    defaultLocale: 'en',
  },
};

12. Mod tanpa pelayan

Next.js menyokong mod Tanpa Pelayan, yang didayakan secara lalai pada Vercel. Dalam mod ini, aplikasi anda akan dijalankan atas permintaan, menjimatkan kos sumber.

13. Pekerja Web

Gunakan Pekerja Web dalam Next.js untuk mengendalikan tugas pengkomputeran intensif untuk mengelak daripada menyekat urutan utama:

// components/Worker.js
import { useEffect } from 'react';
import { createWorker } from 'workerize-loader!./my-worker.js'; // Use workerize-loader to load worker files

function MyComponent() {
  const worker = createWorker();

  useEffect(() => {
    const result = worker.calculate(100000); // Calling worker methods
    result.then(console.log);
    return () => worker.terminate(); // Cleaning up workers
  }, []);

  return <div>Loading...</div>;
}

export default MyComponent;

14. Penyepaduan TypeScript

Next.js menyokong TypeScript, menambahkan keselamatan jenis pada projek anda:

Pasang skrip taip dan @types/react.

Buat fail konfigurasi tsconfig.json.

Ubah suai next.config.js untuk mendayakan sokongan TypeScript.

15. Halaman Ralat Tersuai

Buat halaman/_error.js halaman ralat tersuai:

npx create-next-app my-app
cd my-app

16. Sebarkan ke Vercel

Next.js disepadukan dengan sempurna dengan Vercel. Anda boleh menggunakan ia hanya dalam beberapa langkah mudah:

Buat akaun atau log masuk di tapak web Vercel.

Izinkan Vercel untuk mengakses repositori GitHub atau GitLab anda.

Pilih projek untuk digunakan dan Vercel akan mengesan konfigurasi Next.js secara automatik.

Tetapkan nama domain projek dan pembolehubah persekitaran (jika perlu).

Klik butang "Kerahkan" dan Vercel akan membina dan menggunakan aplikasi secara automatik.

17. Pemantauan dan pengoptimuman prestasi

Gunakan pemalam Lighthouse terbina dalam Next.js atau alat pihak ketiga seperti Google PageSpeed ​​​​Insights untuk penilaian prestasi. Optimumkan kod, imej dan sumber lain berdasarkan laporan untuk meningkatkan kelajuan pemuatan dan pengalaman pengguna.

Atas ialah kandungan terperinci Next.js dan SSR: Membina aplikasi yang diberikan pelayan berprestasi tinggi. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Ganti aksara rentetan dalam javascriptGanti aksara rentetan dalam javascriptMar 11, 2025 am 12:07 AM

Penjelasan terperinci mengenai kaedah penggantian rentetan javascript dan Soalan Lazim Artikel ini akan meneroka dua cara untuk menggantikan watak rentetan dalam JavaScript: Kod JavaScript dalaman dan HTML dalaman untuk laman web. Ganti rentetan di dalam kod JavaScript Cara yang paling langsung ialah menggunakan kaedah pengganti (): str = str.replace ("cari", "ganti"); Kaedah ini hanya menggantikan perlawanan pertama. Untuk menggantikan semua perlawanan, gunakan ungkapan biasa dan tambahkan bendera global g: str = str.replace (/fi

Tutorial Persediaan API Carian Google CustomTutorial Persediaan API Carian Google CustomMar 04, 2025 am 01:06 AM

Tutorial ini menunjukkan kepada anda bagaimana untuk mengintegrasikan API carian Google tersuai ke dalam blog atau laman web anda, menawarkan pengalaman carian yang lebih halus daripada fungsi carian tema WordPress standard. Ia menghairankan mudah! Anda akan dapat menyekat carian ke y

Bina Aplikasi Web Ajax anda sendiriBina Aplikasi Web Ajax anda sendiriMar 09, 2025 am 12:11 AM

Jadi di sini anda, bersedia untuk mempelajari semua perkara ini yang dipanggil Ajax. Tetapi, apa sebenarnya? Istilah Ajax merujuk kepada kumpulan teknologi longgar yang digunakan untuk membuat kandungan web yang dinamik dan interaktif. Istilah Ajax, yang asalnya dicipta oleh Jesse J

Contoh warna json failContoh warna json failMar 03, 2025 am 12:35 AM

Siri artikel ini ditulis semula pada pertengahan 2017 dengan maklumat terkini dan contoh segar. Dalam contoh JSON ini, kita akan melihat bagaimana kita dapat menyimpan nilai mudah dalam fail menggunakan format JSON. Menggunakan notasi pasangan nilai utama, kami boleh menyimpan apa-apa jenis

10 JQuery Syntax Highlighters10 JQuery Syntax HighlightersMar 02, 2025 am 12:32 AM

Tingkatkan Penyampaian Kod Anda: 10 Penyeret Sintaks untuk Pemaju Coretan kod perkongsian di laman web atau blog anda adalah amalan biasa bagi pemaju. Memilih penyapu sintaks yang betul dapat meningkatkan daya tarikan dan daya tarikan visual dengan ketara. T

8 plugin susun atur halaman jquery yang menakjubkan8 plugin susun atur halaman jquery yang menakjubkanMar 06, 2025 am 12:48 AM

Leverage JQuery untuk Layouts Laman Web yang mudah: 8 Plugin Essential JQuery memudahkan susun atur laman web dengan ketara. Artikel ini menyoroti lapan plugin jQuery yang kuat yang menyelaraskan proses, terutamanya berguna untuk penciptaan laman web manual

10 JavaScript & JQuery MVC Tutorial10 JavaScript & JQuery MVC TutorialMar 02, 2025 am 01:16 AM

Artikel ini membentangkan pemilihan lebih daripada 10 tutorial mengenai rangka kerja javascript dan jquery model-view-controller (MVC), sesuai untuk meningkatkan kemahiran pembangunan web anda pada tahun baru. Tutorial ini merangkumi pelbagai topik, dari Foundatio

Apa itu ' ini ' Dalam JavaScript?Apa itu ' ini ' Dalam JavaScript?Mar 04, 2025 am 01:15 AM

Mata teras Ini dalam JavaScript biasanya merujuk kepada objek yang "memiliki" kaedah, tetapi ia bergantung kepada bagaimana fungsi dipanggil. Apabila tidak ada objek semasa, ini merujuk kepada objek global. Dalam penyemak imbas web, ia diwakili oleh tetingkap. Apabila memanggil fungsi, ini mengekalkan objek global; tetapi apabila memanggil pembina objek atau mana -mana kaedahnya, ini merujuk kepada contoh objek. Anda boleh mengubah konteks ini menggunakan kaedah seperti panggilan (), memohon (), dan mengikat (). Kaedah ini memanggil fungsi menggunakan nilai dan parameter yang diberikan. JavaScript adalah bahasa pengaturcaraan yang sangat baik. Beberapa tahun yang lalu, ayat ini

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

Muat turun versi mac editor Atom

Muat turun versi mac editor Atom

Editor sumber terbuka yang paling popular

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa