در اینجا نحوه تنظیم قطعات RenderingNG و نحوه عبور خط لوله رندر از میان آنها را خواهید دید.
با شروع از بالاترین سطح، وظایف رندر عبارتند از:
- محتویات را به پیکسل بر روی صفحه نمایش دهید .
- جلوه های بصری را بر روی محتویات از حالتی به حالت دیگر متحرک کنید .
- در پاسخ به ورودی اسکرول کنید .
- ورودی را به طور موثر به مکان های مناسب هدایت کنید تا اسکریپت های توسعه دهنده و سایر سیستم های فرعی بتوانند پاسخ دهند.
محتویاتی که باید رندر شوند درختی از فریم ها برای هر برگه مرورگر، به علاوه رابط مرورگر هستند. و، جریانی از رویدادهای ورودی خام از صفحه نمایش لمسی، ماوس، صفحه کلید و سایر دستگاه های سخت افزاری.
هر فریم شامل:
- وضعیت DOM
- CSS
- بوم های نقاشی
- منابع خارجی مانند تصاویر، ویدئو، فونت و SVG
فریم یک سند HTML به اضافه URL آن است. یک صفحه وب بارگذاری شده در یک برگه مرورگر دارای یک قاب سطح بالا، فریم های فرزند برای هر iframe موجود در سند سطح بالا، و فرزندان iframe بازگشتی آنها است.
جلوه بصری یک عملیات گرافیکی است که بر روی یک بیت مپ اعمال می شود، مانند اسکرول، تبدیل، کلیپ، فیلتر، کدورت یا ترکیب.
اجزای معماری
در RenderingNG، این وظایف به طور منطقی در چندین مرحله و مؤلفه کد تقسیم می شوند. کامپوننتها در فرآیندهای مختلف CPU، رشتهها و اجزای فرعی درون آن رشتهها ختم میشوند. هر کدام نقش مهمی در دستیابی به قابلیت اطمینان ، عملکرد مقیاس پذیر و توسعه پذیری برای تمام محتوای وب دارند.
رندر کردن ساختار خط لوله
رندر در یک خط لوله با تعدادی از مراحل و مصنوعات ایجاد شده در طول مسیر انجام می شود. هر مرحله نشان دهنده کدی است که یک کار به خوبی تعریف شده در رندر انجام می دهد. آرتیفکت ها ساختارهای داده ای هستند که ورودی یا خروجی مراحل هستند.
مراحل عبارتند از:
- Animate: سبک های محاسبه شده را تغییر دهید و درختان ویژگی را در طول زمان بر اساس جدول زمانی اعلامی تغییر دهید.
- سبک: CSS را در DOM اعمال کنید و سبک های محاسبه شده را ایجاد کنید.
- Layout: اندازه و موقعیت عناصر DOM را روی صفحه تعیین کنید و درخت قطعه غیرقابل تغییر ایجاد کنید.
- Pre-paint: درختهای ویژگی را محاسبه کنید و لیستهای نمایشی موجود و کاشیهای بافت GPU را در صورت لزوم باطل کنید .
- اسکرول: افست اسکرول اسناد و عناصر DOM قابل پیمایش را با جهش درخت های ویژگی به روز کنید.
- Paint: یک لیست نمایشی را محاسبه کنید که نحوه رستر کردن کاشی های بافت گرافیکی GPU از DOM را توضیح می دهد.
- Commit: درختان ویژگی و لیست نمایشگر را در رشته کامپوزیتور کپی کنید.
- لایه بندی: لیست نمایش را به یک لیست لایه ترکیبی برای شطرنجی سازی و انیمیشن مستقل تقسیم کنید.
- رستر، کدگشایی و رنگآمیزی: فهرستهای نمایش، تصاویر رمزگذاریشده و کدهای ورکلت را به ترتیب به کاشیهای بافت GPU تبدیل کنید.
- فعال کردن: یک قاب ترکیبی ایجاد کنید که نشان دهنده نحوه ترسیم و قرار دادن کاشی های GPU روی صفحه نمایش است، همراه با جلوه های بصری.
- مجموع: ترکیب فریمهای ترکیبکننده از همه فریمهای ترکیبکننده قابل مشاهده در یک فریم ترکیبکننده واحد و جهانی.
- Draw: فریم ترکیبی را روی GPU اجرا کنید تا پیکسلهایی روی صفحه ایجاد کنید.
مراحل خط لوله رندر را می توان در صورت عدم نیاز رد کرد. برای مثال، انیمیشنهای جلوههای بصری، و اسکرول، میتوانند از طرحبندی، پیشرنگآمیزی و نقاشی صرفنظر کنند. به همین دلیل است که انیمیشن و اسکرول با نقاط زرد و سبز در نمودار مشخص شده اند. اگر بتوان از چیدمان، پیشرنگ و رنگ برای جلوههای بصری صرفنظر کرد، میتوان آنها را بهطور کامل بر روی نخ کامپوزیتور اجرا کرد و از نخ اصلی عبور کرد.
رندر رابط کاربری مرورگر مستقیماً در اینجا نشان داده نمیشود، اما میتوان آن را بهعنوان یک نسخه سادهشده از همین خط لوله در نظر گرفت (و در واقع اجرای آن بیشتر کد را به اشتراک میگذارد). ویدئو (همچنین مستقیماً به تصویر نمیآید) عموماً با کد مستقلی رندر میشود که فریمها را به کاشیهای بافت GPU رمزگشایی میکند که سپس به فریمهای ترکیبکننده و مرحله ترسیم متصل میشوند.
فرآیند و ساختار نخ
پردازش های CPU
استفاده از چندین فرآیند CPU باعث می شود عملکرد و امنیت ایزوله بین سایت ها و از وضعیت مرورگر، و پایداری و جداسازی امنیت از سخت افزار GPU ایجاد شود.
- فرآیند رندر رندر، متحرک سازی، اسکرول و مسیرهای ورودی را برای یک سایت و ترکیب برگه واحد می کند. چندین فرآیند رندر وجود دارد.
- فرآیند مرورگر ، ورودی را برای رابط کاربری مرورگر (شامل نوار آدرس، عناوین برگهها و نمادها) رندر میکند، متحرک میکند و مسیرهای ورودی را به سمت فرآیند رندر مناسب هدایت میکند. یک فرآیند مرورگر وجود دارد.
- فرآیند Viz ترکیبی از فرآیندهای رندر متعدد به اضافه فرآیند مرورگر است. با استفاده از GPU رسم و رسم می کند. یک فرآیند Viz وجود دارد.
سایت های مختلف همیشه به فرآیندهای رندر متفاوت ختم می شوند.
چندین برگه مرورگر یا پنجره های یک سایت معمولاً در فرآیندهای رندر متفاوتی قرار می گیرند، مگر اینکه تب ها به هم مرتبط باشند، مثلاً یکی دیگری را باز کند . تحت فشار شدید حافظه روی دسکتاپ، Chromium ممکن است چندین برگه از یک سایت را در یک فرآیند رندر قرار دهد، حتی اگر مرتبط نباشد.
در یک برگه مرورگر، فریمهای سایتهای مختلف همیشه در فرآیندهای رندر متفاوت از یکدیگر قرار دارند، اما فریمهای یک سایت همیشه در یک فرآیند رندر هستند. از منظر رندر، مزیت مهم فرآیندهای رندر چندگانه این است که iframe ها و تب های متقاطع سایت به جداسازی عملکرد از یکدیگر می رسند. علاوه بر این، ریشه ها می توانند حتی بیشتر در انزوا انتخاب شوند.
دقیقاً یک فرآیند Viz برای همه Chromium وجود دارد، زیرا معمولاً فقط یک GPU و صفحه نمایش برای کشیدن وجود دارد.
جداسازی Viz به فرآیند خودش برای پایداری در مواجهه با اشکالات درایورهای GPU یا سخت افزار خوب است. همچنین برای ایزوله سازی امنیتی خوب است، که برای API های GPU مانند Vulkan و به طور کلی امنیت مهم است.
از آنجایی که مرورگر میتواند تبها و پنجرههای زیادی داشته باشد و همه آنها دارای پیکسلهای رابط کاربری مرورگر برای ترسیم هستند، ممکن است تعجب کنید: چرا دقیقاً یک فرآیند مرورگر وجود دارد؟ دلیل آن این است که تنها یکی از آنها در یک زمان متمرکز است. در واقع، تب های غیر قابل مشاهده مرورگر عمدتا غیرفعال می شوند و تمام حافظه GPU خود را حذف می کنند. با این حال، ویژگی های پیچیده رندر رابط کاربری مرورگر به طور فزاینده ای در فرآیندهای رندر نیز اجرا می شوند (معروف به WebUI ). این به دلایل جداسازی عملکرد نیست، بلکه به منظور استفاده از سهولت استفاده از موتور رندر وب Chromium است.
در دستگاههای Android قدیمیتر ، فرآیند رندر و مرورگر زمانی که در WebView استفاده میشود به اشتراک گذاشته میشود (این به طور کلی برای Chromium در Android اعمال نمیشود، فقط WebView). در WebView، فرآیند مرورگر نیز با برنامه جاسازی به اشتراک گذاشته میشود و WebView تنها یک فرآیند رندر دارد.
همچنین گاهی اوقات یک فرآیند کاربردی برای رمزگشایی محتوای ویدیویی محافظت شده وجود دارد. این فرآیند در نمودارهای قبلی نشان داده نشده است.
موضوعات
موضوعات به دستیابی به انزوای عملکرد و پاسخگویی با وجود انجام وظایف کند، موازی سازی خط لوله و بافر چندگانه کمک می کنند.
- رشته اصلی اسکریپت ها، حلقه رویداد رندر، چرخه عمر سند، تست ضربه، ارسال رویداد اسکریپت، و تجزیه HTML، CSS و سایر فرمت های داده را اجرا می کند.
- کمک کننده های رشته اصلی کارهایی مانند ایجاد بیت مپ های تصویر و حباب هایی که نیاز به رمزگذاری یا رمزگشایی دارند را انجام می دهند.
- Web Workers اسکریپت و یک حلقه رویداد رندر برای OffscreenCanvas را اجرا می کنند.
- رشته Compositor رویدادهای ورودی را پردازش میکند، پیمایش و انیمیشنهای محتوای وب را انجام میدهد، لایهبندی بهینه محتوای وب را محاسبه میکند و رمزگشاییهای تصویر، Workletهای نقاشی و وظایف شطرنجی را هماهنگ میکند.
- کمککنندههای رشته Compositor وظایف شطرنجی Viz را هماهنگ میکنند، و وظایف رمزگشایی تصویر، worklets رنگ و رستر بازگشتی را اجرا میکنند.
- رسانه ها، دموکسر یا رشته های خروجی صدا جریان های ویدئویی و صوتی را رمزگشایی، پردازش و همگام سازی می کنند. (به یاد داشته باشید که ویدئو به موازات خط لوله رندر اصلی اجرا می شود.)
جداسازی رشتههای اصلی و ترکیبکننده برای جداسازی عملکرد انیمیشن و اسکرول از کار رشته اصلی بسیار مهم است.
در هر فرآیند رندر فقط یک رشته اصلی وجود دارد، حتی اگر چندین برگه یا فریم از یک سایت ممکن است به یک فرآیند ختم شوند. با این حال، جداسازی عملکرد از کارهای انجام شده در API های مختلف مرورگر وجود دارد. به عنوان مثال، تولید بیت مپ ها و حباب های تصویر در Canvas API در یک رشته کمکی رشته اصلی اجرا می شود.
به همین ترتیب، در هر فرآیند رندر تنها یک رشته ترکیبی وجود دارد. به طور کلی مشکلی نیست که فقط یک مورد وجود داشته باشد، زیرا تمام عملیات واقعاً گران روی رشته کامپوزیتور به رشتههای کارگر کامپوزیتور یا فرآیند Viz واگذار میشود و این کار را میتوان به موازات مسیریابی ورودی، اسکرول یا انیمیشن انجام داد. . وظایف هماهنگی threads کارگر Compositor در فرآیند Viz اجرا میشود، اما شتاب GPU در همه جا ممکن است به دلایلی خارج از کنترل Chromium، مانند اشکالات درایور، با شکست مواجه شود. در این مواقع، Worker Thread کار را در حالت بازگشتی روی CPU انجام می دهد.
تعداد نخ های کامپوزیتور کارگر بستگی به قابلیت های دستگاه دارد. برای مثال، دسکتاپها معمولاً از Threadهای بیشتری استفاده میکنند، زیرا هستههای CPU بیشتری دارند و نسبت به دستگاههای تلفن همراه باتری کمتری دارند. این نمونه ای از افزایش و کاهش مقیاس است.
معماری رشتهبندی فرآیند رندر، کاربرد سه الگوی بهینهسازی مختلف است:
- رشتههای کمکی : وظایف فرعی طولانیمدت را به رشتههای اضافی ارسال کنید تا رشته اصلی به درخواستهای همزمان پاسخ دهد. نخ های کمکی اصلی و رزوه های کمکی ترکیب کننده نمونه های خوبی از این تکنیک هستند.
- بافر چندگانه : محتوای رندر شده قبلی را در حین ارائه محتوای جدید نشان دهید تا تأخیر رندر پنهان شود. رشته کامپوزیتور از این تکنیک استفاده می کند.
- موازی سازی خط لوله: خط لوله رندر را در چندین مکان به طور همزمان اجرا کنید. این است که چگونه اسکرول و انیمیشن می تواند سریع باشد. حتی اگر یک بهروزرسانی رندر رشته اصلی اتفاق بیفتد، اسکرول و انیمیشن میتوانند به صورت موازی اجرا شوند.
فرآیند مرورگر
- رشته رندر و ترکیب به ورودی در UI مرورگر پاسخ می دهد، ورودی های دیگر را به فرآیند رندر صحیح هدایت می کند. رابط کاربری مرورگر را طراحی و نقاشی می کند.
- کمککنندههای رشتههای رندر و ترکیب، وظایف رمزگشایی تصویر و رستر یا رمزگشایی مجدد را اجرا میکنند.
رندر فرآیند مرورگر و رشته ترکیبی شبیه به کد و عملکرد یک فرآیند رندر هستند، با این تفاوت که رشته اصلی و رشته کامپوزیتور در یکی ترکیب می شوند. در این مورد فقط یک رشته مورد نیاز است زیرا نیازی به جداسازی عملکرد از وظایف نخ اصلی طولانی نیست، زیرا هیچ کدام از نظر طراحی وجود ندارد.
یعنی فرآیند
- شطرنجهای رشته اصلی GPU فهرستها و فریمهای ویدیویی را در کاشیهای بافت GPU نمایش میدهند و فریمهای ترکیبکننده را به صفحه میکشند.
- رشته کامپوزیتور نمایشگر، ترکیب را از هر فرآیند رندر، بهعلاوه فرآیند مرورگر، در یک فریم ترکیبکننده واحد برای ارائه به صفحه جمعبندی و بهینهسازی میکند.
رستر و ترسیم عموماً روی یک رشته اتفاق میافتند، زیرا هر دوی آنها به منابع GPU متکی هستند و استفاده قابل اعتماد چند رشتهای از GPU دشوار است (دسترسی آسانتر چند رشتهای به GPU یکی از انگیزههای توسعه استاندارد جدید Vulkan است. ). در Android WebView، به دلیل نحوه تعبیه WebViewها در یک برنامه بومی، یک رشته رندر در سطح سیستم عامل جداگانه برای طراحی وجود دارد. سایر پلتفرم ها احتمالاً در آینده چنین موضوعی خواهند داشت.
سازنده نمایشگر در رشته دیگری قرار دارد زیرا باید همیشه پاسخگو باشد و هیچ منبع احتمالی کاهش سرعت در رشته اصلی GPU را مسدود نکند. یکی از دلایل کاهش سرعت در رشته اصلی GPU، فراخوانی به کدهای غیر Chromium، مانند درایورهای GPU خاص فروشنده است، که ممکن است به روشهای غیرقابل پیشبینی کند باشند.
ساختار جزء
در هر رشته اصلی یا کامپوزیتور فرآیند رندر، اجزای نرمافزار منطقی وجود دارد که به روشهای ساختاریافته با یکدیگر تعامل دارند.
رندر اجزای رشته اصلی فرآیند
در Blink Renderer:
- قطعه درخت قاب محلی نشان دهنده درخت فریم های محلی و DOM درون فریم ها است.
- مؤلفه DOM و Canvas APIها شامل پیاده سازی همه این APIها است.
- اجرا کننده چرخه حیات سند، مراحل رندر خط لوله را تا مرحله commit و از جمله آن اجرا می کند.
- مؤلفه آزمایش و ارسال ضربه رویداد ورودی، آزمایشهای ضربه را اجرا میکند تا بفهمد کدام عنصر DOM توسط یک رویداد هدف قرار گرفته است، و الگوریتمهای ارسال رویداد ورودی و رفتارهای پیشفرض را اجرا میکند.
زمانبندی و اجراکننده حلقه رویداد رندر تصمیم میگیرد چه چیزی و چه زمانی در حلقه رویداد اجرا شود. برنامه ریزی می کند که رندر در آهنگی مطابق با نمایشگر دستگاه اتفاق بیفتد.
قطعات درخت قاب محلی کمی پیچیده هستند. به یاد بیاورید که درخت فریم صفحه اصلی و فریم های فرزند آن به صورت بازگشتی است. یک فریم در صورتی که در آن فرآیند رندر شود برای یک فرآیند رندر محلی است و در غیر این صورت راه دور است.
می توانید رنگ آمیزی فریم ها را با توجه به فرآیند رندر آنها تصور کنید. در تصویر قبل، دایرههای سبز رنگ همگی فریمهایی در یک فرآیند رندر هستند. رنگ های نارنجی در یک ثانیه و آبی در یک سوم قرار دارند.
قطعه درخت قاب محلی یک جزء متصل از همان رنگ در یک درخت قاب است. چهار درخت فریم محلی در تصویر وجود دارد: دو درخت برای سایت A، یکی برای سایت B، و یکی برای سایت C. هر درخت فریم محلی جزء رندر Blink خود را دریافت می کند. رندر Blink یک درخت فریم محلی ممکن است در فرآیند رندر مشابه سایر درختان فریم محلی باشد یا نباشد. با نحوه انتخاب فرآیندهای رندر، همانطور که قبلا توضیح داده شد، تعیین می شود.
رندر ساختار نخ کامپوزیتور فرآیند
اجزای سازنده فرآیند رندر عبارتند از:
- یک کنترل کننده داده که یک لیست لایه های ترکیبی، لیست های نمایشی و درختان ویژگی را نگهداری می کند.
- یک دونده چرخه حیات که مراحل متحرک سازی، اسکرول، ترکیبی، شطرنجی و رمزگشایی و فعال سازی مراحل خط لوله رندر را اجرا می کند. (به یاد داشته باشید که متحرک سازی و اسکرول می توانند هم در رشته اصلی و هم در آهنگساز رخ دهند.)
- یک کنترلکننده تست ورودی و ضربه، پردازش ورودی و تست ضربه را با وضوح لایههای ترکیبی انجام میدهد تا تعیین کند آیا حرکات اسکرول را میتوان روی رشته ترکیبکننده اجرا کرد، و کدام آزمونهای ضربه فرآیند رندر را باید هدف قرار دهند.
نمونه معماری در عمل
در این مثال سه تب وجود دارد:
برگه 1: foo.com
<html>
<iframe id=one src="foo.com/other-url"></iframe>
<iframe id=two src="bar.com"></iframe>
</html>
برگه 2: bar.com
<html>
…
</html>
برگه 3: baz.com html <html> … </html>
فرآیند، رشته و ساختار اجزای این تب ها به صورت زیر است:
بیایید هر یک از چهار کار اصلی رندر را با یک مثال مرور کنیم. یک یادآوری:
- محتویات را به پیکسل بر روی صفحه نمایش دهید .
- جلوه های بصری را بر روی محتویات از حالتی به حالت دیگر متحرک کنید .
- در پاسخ به ورودی اسکرول کنید .
- ورودی را به طور موثر به مکان های مناسب هدایت کنید تا اسکریپت های توسعه دهنده و سایر سیستم های فرعی بتوانند پاسخ دهند.
برای ارائه DOM تغییر یافته برای تب یک:
- یک اسکریپت توسعه دهنده DOM را در فرآیند رندر برای foo.com تغییر می دهد.
- رندر Blink به کامپوزیتور می گوید که برای رخ دادن نیاز به رندر دارد.
- کامپوزیتور به Viz می گوید که برای رخ دادن به یک رندر نیاز دارد.
- Viz شروع رندر را به کامپوزیتور سیگنال می دهد.
- کامپوزیتور سیگنال شروع را به رندر Blink ارسال می کند.
- اجراکننده حلقه رویداد رشته اصلی چرخه عمر سند را اجرا می کند.
- نخ اصلی نتیجه را به رشته کامپوزیتور ارسال می کند.
- اجراکننده حلقه رویداد کامپوزیتور چرخه حیات ترکیب را اجرا می کند.
- هر کار شطرنجی برای رستر به Viz ارسال می شود (اغلب بیش از یکی از این وظایف وجود دارد).
- یعنی محتوای رسترها در GPU.
- Viz تکمیل کار شطرنجی را تأیید می کند. توجه: Chromium اغلب منتظر نمی ماند تا رستر کامل شود، و در عوض از چیزی به نام نشانه همگام سازی استفاده می کند که باید قبل از اجرای مرحله 15 توسط وظایف شطرنجی حل شود.
- یک فریم کامپوزیتور به Viz ارسال می شود.
- Viz فریم های کامپوزیتور را برای فرآیند رندر foo.com، فرآیند رندر iframe bar.com و رابط کاربری مرورگر را جمع می کند.
- ویز قرعه کشی را برنامه ریزی می کند.
- Viz قاب ترکیبکننده جمعشده را روی صفحه میکشد.
برای متحرک سازی یک انتقال تبدیل CSS در برگه دو:
- رشته کامپوزیتور برای فرآیند رندر bar.com یک انیمیشن را در حلقه رویداد کامپوزیتور آن با جهش درخت های ویژگی موجود علامت می دهد. سپس چرخه عمر کامپوزیتور را دوباره اجرا می کند. (کارهای رستر و رمزگشایی ممکن است رخ دهند، اما در اینجا به تصویر کشیده نمی شوند.)
- یک فریم کامپوزیتور به Viz ارسال می شود.
- Viz فریم های کامپوزیتور را برای فرآیند رندر foo.com، فرآیند رندر bar.com و رابط کاربری مرورگر جمع می کند.
- ویز قرعه کشی را برنامه ریزی می کند.
- به عنوان مثال، قاب ترکیبکننده جمعآوری شده را روی صفحه میکشد.
برای پیمایش صفحه وب در برگه سه:
- دنباله ای از رویدادهای
input
(ماوس، لمس یا صفحه کلید) به فرآیند مرورگر می آیند. - هر رویداد به رشته ترکیبکننده فرآیند رندر baz.com هدایت میشود.
- ترکیب کننده تعیین می کند که آیا موضوع اصلی باید درباره رویداد بداند یا خیر.
- رویداد در صورت لزوم به موضوع اصلی ارسال می شود.
- رشته اصلی شنوندگان رویداد
input
(pointerdown
،touchstar
،pointermove
،touchmove
یاwheel
) را فعال می کند تا ببیند آیا شنوندگان در رویداد،preventDefault
فرا خواهند خواند. - رشته اصلی نشان می دهد که آیا
preventDefault
به کامپوزیتور فراخوانی شده است یا خیر. - در غیر این صورت، رویداد ورودی به فرآیند مرورگر بازگردانده می شود.
- فرآیند مرورگر با ترکیب آن با سایر رویدادهای اخیر، آن را به یک حرکت حرکتی تبدیل میکند.
- ژست اسکرول یک بار دیگر به رشته ترکیب کننده فرآیند رندر baz.com ارسال می شود.
- اسکرول در آنجا اعمال میشود، و رشته ترکیبکننده برای فرآیند رندر bar.com یک انیمیشن را در حلقه رویداد ترکیبکننده آن علامتگذاری میکند. سپس این اسکرول افست را در درخت های ویژگی تغییر می دهد و چرخه حیات کامپوزیتور را دوباره اجرا می کند. همچنین به رشته اصلی میگوید که یک رویداد
scroll
اجرا کند (در اینجا نشان داده نشده است). - یک فریم کامپوزیتور به Viz ارسال می شود.
- Viz فریم های کامپوزیتور را برای فرآیند رندر foo.com، فرآیند رندر bar.com و رابط کاربری مرورگر جمع می کند.
- ویز قرعه کشی را برنامه ریزی می کند.
- Viz قاب ترکیبکننده جمعشده را روی صفحه میکشد.
برای مسیریابی یک رویداد click
روی یک پیوند در iframe #two در تب یک:
- یک رویداد
input
(موس، لمسی یا صفحه کلید) به فرآیند مرورگر می آید. یک تست ضربه تقریبی انجام می دهد تا مشخص کند که فرآیند رندر iframe bar.com باید کلیک را دریافت کند و آن را به آنجا ارسال می کند. - رشته compositor برای bar.com رویداد
click
را به رشته اصلی bar.com هدایت می کند و یک کار حلقه رویداد رندر را برای پردازش آن زمان بندی می کند. - پردازشگر رویداد ورودی برای رشته اصلی bar.com تست می کند تا مشخص کند کدام عنصر DOM در iframe کلیک شده است و یک رویداد
click
را برای مشاهده اسکریپت ها فعال می کند. با شنیدن هیچpreventDefault
، به لینک هدایت می شود. - پس از بارگذاری صفحه مقصد از هایپرلینک، وضعیت جدید با مراحلی شبیه به مثال قبلی "رندر تغییر DOM" ارائه می شود. (این تغییرات بعدی در اینجا نشان داده نشده است.)
غذای آماده
یادآوری و درونی کردن نحوه عملکرد رندر زمان زیادی می برد.
مهمترین نکته این است که خط لوله رندر، از طریق مدولارسازی دقیق و توجه به جزئیات، به تعدادی از اجزای مستقل تقسیم شده است. سپس این مؤلفهها در بین فرآیندها و رشتههای موازی تقسیم شدهاند تا عملکرد مقیاسپذیر و فرصتهای توسعهپذیری را به حداکثر برسانند.
هر جزء نقش مهمی در فعال کردن عملکرد و ویژگیهای برنامههای وب مدرن دارد.
به خواندن در مورد ساختارهای داده کلیدی ادامه دهید، که به اندازه اجزای کد برای RenderingNG مهم هستند.
تصاویر توسط Una Kravets.