ناوبری سریعتر وب با واکشی پیشگویانه

درباره واکشی پیش‌بینی‌کننده و نحوه اجرای آن توسط Guess.js بیاموزید.

در جلسه ناوبری سریعتر وب با واکشی پیش‌گویانه در Google I/O 2019، با صحبت در مورد بهینه‌سازی برنامه‌های وب با تقسیم کد و پیامدهای عملکرد بالقوه برای پیمایش صفحه بعدی شروع کردم. در بخش دوم بحث، من در مورد چگونگی بهبود سرعت ناوبری با استفاده از Guess.js برای تنظیم واکشی پیش‌بین بحث کردم:

تقسیم کد برای برنامه های وب سریعتر

برنامه های وب کند هستند و جاوا اسکریپت یکی از گران ترین منابعی است که شما ارسال می کنید. انتظار برای بارگیری یک برنامه وب کند می تواند کاربران شما را ناامید کند و تبدیل ها را کاهش دهد.

برنامه های وب آهسته استرس زا هستند.

بارگذاری تنبل یک تکنیک کارآمد برای کاهش بایت های جاوا اسکریپت است که از طریق سیم منتقل می کنید. شما می توانید از چندین تکنیک برای بارگذاری تنبل جاوا اسکریپت استفاده کنید، از جمله:

  • تقسیم کد در سطح مؤلفه
  • تقسیم کد در سطح مسیر

با تقسیم کد در سطح مؤلفه، می توانید اجزای جداگانه را به تکه های جاوا اسکریپت جداگانه منتقل کنید. در رویدادهای خاص، می‌توانید اسکریپت‌های مربوطه را بارگذاری کنید و مؤلفه‌ها را رندر کنید.

با این حال، با تقسیم کد در سطح مسیر، کل مسیرها را به تکه‌های مستقل منتقل می‌کنید. هنگامی که کاربران از مسیری به مسیر دیگر منتقل می شوند، باید جاوا اسکریپت مرتبط را دانلود کرده و صفحه درخواستی را بوت استرپ کنند. این عملیات می تواند منجر به تاخیرهای قابل توجهی به خصوص در شبکه های کند شود.

واکشی از قبل جاوا اسکریپت

واکشی اولیه به مرورگر اجازه می دهد تا منابعی را که کاربر احتمالاً به زودی به آنها نیاز دارد را بارگیری و ذخیره کند. روش معمول استفاده از <link rel="prefetch"> است، اما دو مشکل رایج وجود دارد:

  • واکشی بیش از حد منابع از قبل ( واکشی بیش از حد ) داده های زیادی را مصرف می کند.
  • برخی از منابع مورد نیاز کاربر ممکن است هرگز از قبل واکشی نشوند.

واکشی پیش‌بینی‌کننده این مشکلات را با استفاده از گزارشی از الگوهای ناوبری کاربران برای تعیین دارایی‌هایی که باید واکشی اولیه انجام شود، حل می‌کند.

نمونه در حال واکشی اولیه

واکشی پیش‌بینی‌کننده با Guess.js

Guess.js یک کتابخانه جاوا اسکریپت است که عملکرد واکشی پیش‌بینی‌کننده را ارائه می‌کند. Guess.js گزارشی را از Google Analytics یا ارائه‌دهنده تجزیه و تحلیل دیگری مصرف می‌کند تا یک مدل پیش‌بینی بسازد که می‌تواند برای واکشی هوشمندانه فقط آنچه کاربر احتمالاً به آن نیاز دارد استفاده کند.

Guess.js با Angular , Next.js , Nuxt.js و Gatsby ادغام می شود . برای استفاده از آن در برنامه خود، این خطوط را به پیکربندی بسته وب خود اضافه کنید تا شناسه نمای Google Analytics را مشخص کنید:

const { GuessPlugin } = require('guess-webpack');

// ...
plugins: [
   // ...
   new GuessPlugin({ GA: 'XXXXXX' })
]
// ...

اگر از Google Analytics استفاده نمی کنید، می توانید reportProvider را مشخص کنید و داده ها را از سرویس مورد علاقه خود دانلود کنید.

ادغام با فریم ورک ها

برای کسب اطلاعات بیشتر در مورد نحوه ادغام Guess.js با چارچوب مورد علاقه خود، این منابع را بررسی کنید:

برای آشنایی سریع با ادغام با Angular، این ویدیو را ببینید:

Guess.js چگونه کار می کند؟

در اینجا نحوه پیاده سازی Guess.js واکشی پیش بینی پیش بینی شده است:

  1. ابتدا داده های الگوهای ناوبری کاربر را از ارائه دهنده تجزیه و تحلیل مورد علاقه شما استخراج می کند.
  2. سپس URL ها را از گزارش به تکه های جاوا اسکریپت تولید شده توسط وب پک نگاشت می کند.
  3. بر اساس داده‌های استخراج‌شده، یک مدل پیش‌بینی ساده ایجاد می‌کند که کاربر احتمالاً از هر صفحه معینی به آن‌ها پیمایش می‌کند.
  4. مدل را برای هر تکه جاوا اسکریپت فراخوانی می‌کند و سایر تکه‌هایی را که احتمالاً بعداً مورد نیاز هستند، پیش‌بینی می‌کند.
  5. دستورالعمل‌های واکشی اولیه را به هر بخش اضافه می‌کند.

وقتی Guess.js تمام شد، هر بخش حاوی دستورالعمل‌های واکشی اولیه مشابه موارد زیر است:

__GUESS__.p(
  ['a.js', 0.2],
  ['b.js', 0.8]
)

این کد ایجاد شده توسط Guess.js به مرورگر می‌گوید که واکشی اولیه chunk a.js با احتمال 0.2 و chunk b.js با احتمال 0.8 را در نظر بگیرد.

هنگامی که مرورگر کد را اجرا کرد، Guess.js سرعت اتصال کاربر را بررسی می کند. اگر کافی باشد، Guess.js دو تگ <link rel="prefetch"> را در سرصفحه صفحه قرار می دهد، یکی برای هر تکه. اگر کاربر در یک شبکه پرسرعت باشد، Guess.js هر دو تکه را از قبل واکشی می کند. اگر کاربر اتصال شبکه ضعیفی داشته باشد، Guess.js فقط chunk b.js از قبل واکشی می کند زیرا احتمال نیاز به آن زیاد است.

بیشتر بدانید

برای کسب اطلاعات بیشتر در مورد Guess.js، این منابع را بررسی کنید: