রেন্ডার-ট্রি কনস্ট্রাকশন, লেআউট এবং পেইন্ট

প্রকাশিত: মার্চ 31, 2014

CSSOM এবং DOM ট্রিগুলিকে একটি রেন্ডার ট্রিতে একত্রিত করা হয়, যা পরে প্রতিটি দৃশ্যমান উপাদানের বিন্যাস গণনা করতে ব্যবহৃত হয় এবং পেইন্ট প্রক্রিয়ার একটি ইনপুট হিসাবে কাজ করে যা পিক্সেলগুলিকে স্ক্রিনে রেন্ডার করে। সর্বোত্তম রেন্ডারিং পারফরম্যান্স অর্জনের জন্য এই পদক্ষেপগুলির প্রতিটি অপ্টিমাইজ করা গুরুত্বপূর্ণ।

অবজেক্ট মডেল নির্মাণের পূর্ববর্তী বিভাগে, আমরা HTML এবং CSS ইনপুটের উপর ভিত্তি করে DOM এবং CSSOM ট্রি তৈরি করেছি। যাইহোক, এই দুটিই স্বতন্ত্র বস্তু যা নথির বিভিন্ন দিক ক্যাপচার করে: একটি বিষয়বস্তু বর্ণনা করে, এবং অন্যটি নথিতে প্রয়োগ করা প্রয়োজন এমন শৈলী নিয়ম বর্ণনা করে। কীভাবে আমরা দুটিকে একত্রিত করব এবং ব্রাউজারটিকে স্ক্রিনে পিক্সেল রেন্ডার করতে পারি?

সারাংশ

  • DOM এবং CSSOM গাছ একত্রিত হয়ে রেন্ডার ট্রি গঠন করে।
  • রেন্ডার ট্রিতে পৃষ্ঠাটি রেন্ডার করার জন্য প্রয়োজনীয় নোডগুলিই থাকে৷
  • লেআউট প্রতিটি বস্তুর সঠিক অবস্থান এবং আকার গণনা করে।
  • শেষ ধাপটি হল পেইন্ট, যা চূড়ান্ত রেন্ডার ট্রিতে নেয় এবং পিক্সেলগুলিকে স্ক্রিনে রেন্ডার করে।

প্রথমত, ব্রাউজারটি DOM এবং CSSOM কে একটি "রেন্ডার ট্রি"-তে একত্রিত করে, যা পৃষ্ঠার সমস্ত দৃশ্যমান DOM সামগ্রী এবং প্রতিটি নোডের জন্য সমস্ত CSSOM শৈলী তথ্য ক্যাপচার করে।

DOM এবং CSSOM কে একত্রিত করে রেন্ডার ট্রি তৈরি করা হয়

রেন্ডার ট্রি তৈরি করতে, ব্রাউজার মোটামুটি নিম্নলিখিতগুলি করে:

  1. DOM গাছের মূল থেকে শুরু করে, প্রতিটি দৃশ্যমান নোড অতিক্রম করুন।

    • কিছু নোড দৃশ্যমান নয় (উদাহরণস্বরূপ, স্ক্রিপ্ট ট্যাগ, মেটা ট্যাগ ইত্যাদি), এবং বাদ দেওয়া হয় কারণ সেগুলি রেন্ডার করা আউটপুটে প্রতিফলিত হয় না।
    • কিছু নোড সিএসএস ব্যবহার করে লুকানো থাকে এবং রেন্ডার ট্রি থেকেও বাদ দেওয়া হয়; উদাহরণস্বরূপ, স্প্যান নোড—উপরের উদাহরণে—রেন্ডার ট্রি থেকে অনুপস্থিত কারণ আমাদের একটি সুস্পষ্ট নিয়ম রয়েছে যা এটিতে "ডিসপ্লে: নেই" বৈশিষ্ট্য সেট করে।
  2. প্রতিটি দৃশ্যমান নোডের জন্য, উপযুক্ত মিলিত CSSOM নিয়মগুলি খুঁজুন এবং সেগুলি প্রয়োগ করুন৷

  3. বিষয়বস্তু এবং তাদের গণনা করা শৈলী সহ দৃশ্যমান নোড নির্গত করুন।

চূড়ান্ত আউটপুট হল একটি রেন্ডার ট্রি যা পর্দায় দৃশ্যমান সমস্ত বিষয়বস্তুর বিষয়বস্তু এবং শৈলীর তথ্য উভয়ই ধারণ করে। রেন্ডার গাছের জায়গায়, আমরা "লেআউট" পর্যায়ে যেতে পারি।

এই বিন্দু পর্যন্ত আমরা গণনা করেছি কোন নোডগুলি দৃশ্যমান হওয়া উচিত এবং তাদের গণনা করা শৈলীগুলি, কিন্তু আমরা ডিভাইসের ভিউপোর্টের মধ্যে তাদের সঠিক অবস্থান এবং আকার গণনা করিনি - এটি "লেআউট" পর্যায়, যা "রিফ্লো" নামেও পরিচিত।

পৃষ্ঠায় প্রতিটি বস্তুর সঠিক আকার এবং অবস্থান বের করার জন্য, ব্রাউজারটি রেন্ডার গাছের মূল থেকে শুরু হয় এবং এটিকে অতিক্রম করে। এই উদাহরণ বিবেচনা করুন:

<!DOCTYPE html>
<html>
 
<head>
   
<meta name="viewport" content="width=device-width,initial-scale=1" />
   
<title>Critial Path: Hello world!</title>
 
</head>
 
<body>
   
<div style="width: 50%">
     
<div style="width: 50%">Hello world!</div>
   
</div>
 
</body>
</html>

চেষ্টা করে দেখুন

পূর্ববর্তী উদাহরণের <body> দুটি নেস্টেড <div> s রয়েছে: প্রথমটি (অভিভাবক) <div> নোডের প্রদর্শনের আকারকে ভিউপোর্ট প্রস্থের 50% সেট করে এবং দ্বিতীয়টি <div> — অভিভাবক দ্বারা ধারণ করে - এটির width তার পিতামাতার 50% সেট করে; অর্থাৎ, ভিউপোর্ট প্রস্থের 25%।

লেআউট তথ্য গণনা করা হচ্ছে

লেআউট প্রক্রিয়ার আউটপুট হল একটি "বক্স মডেল", যা সঠিকভাবে ভিউপোর্টের মধ্যে প্রতিটি উপাদানের সঠিক অবস্থান এবং আকার ক্যাপচার করে: সমস্ত আপেক্ষিক পরিমাপ স্ক্রিনে পরম পিক্সেলে রূপান্তরিত হয়।

অবশেষে, এখন আমরা জানি যে কোন নোডগুলি দৃশ্যমান, এবং তাদের গণনা করা শৈলী এবং জ্যামিতি, আমরা এই তথ্যটি চূড়ান্ত পর্যায়ে প্রেরণ করতে পারি, যা রেন্ডার ট্রিতে প্রতিটি নোডকে স্ক্রিনের প্রকৃত পিক্সেলে রূপান্তরিত করে। এই ধাপটিকে প্রায়ই "পেইন্টিং" বা "রাস্টারাইজিং" হিসাবে উল্লেখ করা হয়।

এতে কিছু সময় লাগতে পারে কারণ ব্রাউজারটিকে বেশ কিছুটা কাজ করতে হবে। যাইহোক, Chrome DevTools পূর্বে বর্ণিত তিনটি ধাপে কিছু অন্তর্দৃষ্টি প্রদান করতে পারে। আমাদের আসল "হ্যালো ওয়ার্ল্ড" উদাহরণের জন্য লেআউট পর্যায়ে পরীক্ষা করুন:

DevTools-এ লেআউট পরিমাপ করা

  • "লেআউট" ইভেন্টটি টাইমলাইনে রেন্ডার ট্রি নির্মাণ, অবস্থান এবং আকারের গণনা ক্যাপচার করে।
  • লেআউট সম্পূর্ণ হলে, ব্রাউজার "পেইন্ট সেটআপ" এবং "পেইন্ট" ইভেন্টগুলি ইস্যু করে, যা রেন্ডার ট্রিকে স্ক্রিনে পিক্সেলে রূপান্তর করে।

রেন্ডার ট্রি নির্মাণ, লেআউট এবং পেইন্ট করার জন্য প্রয়োজনীয় সময় নথির আকার, প্রয়োগ করা শৈলী এবং এটি যে ডিভাইসে চলছে তার উপর ভিত্তি করে পরিবর্তিত হয়: নথি যত বড় হবে, ব্রাউজারে তত বেশি কাজ হবে; শৈলী যত জটিল হবে, পেইন্টিংয়ের জন্যও তত বেশি সময় লাগবে (উদাহরণস্বরূপ, একটি কঠিন রঙ আঁকার জন্য "সস্তা", যখন একটি ড্রপ শ্যাডো গণনা এবং রেন্ডার করার জন্য "ব্যয়"।

পৃষ্ঠাটি অবশেষে ভিউপোর্টে দৃশ্যমান:

রেন্ডারড হ্যালো ওয়ার্ল্ড পেজ

এখানে ব্রাউজারের পদক্ষেপগুলির একটি দ্রুত সংক্ষিপ্ত বিবরণ রয়েছে:

  1. HTML মার্কআপ প্রক্রিয়া করুন এবং DOM ট্রি তৈরি করুন।
  2. CSS মার্কআপ প্রক্রিয়া করুন এবং CSSOM ট্রি তৈরি করুন।
  3. একটি রেন্ডার ট্রিতে DOM এবং CSSOM একত্রিত করুন।
  4. প্রতিটি নোডের জ্যামিতি গণনা করতে রেন্ডার ট্রিতে লেআউট চালান।
  5. স্ক্রিনে পৃথক নোডগুলি পেইন্ট করুন।

ডেমো পৃষ্ঠাটি মৌলিক বলে মনে হতে পারে, তবে এটি ব্রাউজারের অংশে বেশ কিছুটা কাজ করতে হবে। যদি DOM বা CSSOM হয় পরিবর্তন করা হয়, তাহলে স্ক্রিনে কোন পিক্সেলগুলিকে পুনরায় রেন্ডার করতে হবে তা নির্ধারণ করার জন্য আপনাকে প্রক্রিয়াটি পুনরাবৃত্তি করতে হবে।

ক্রিটিক্যাল রেন্ডারিং পাথকে অপ্টিমাইজ করা হল উপরের সিকোয়েন্সে ধাপ 1 থেকে 5 পর্যন্ত পারফর্ম করার জন্য মোট সময় কমানোর প্রক্রিয়া। এটি করার ফলে যত তাড়াতাড়ি সম্ভব স্ক্রীনে বিষয়বস্তু রেন্ডার হয় এবং প্রাথমিক রেন্ডারের পরে স্ক্রীন আপডেটের মধ্যে সময়ের পরিমাণও কমে যায়; অর্থাৎ, ইন্টারেক্টিভ কন্টেন্টের জন্য উচ্চতর রিফ্রেশ হার অর্জন করুন।

প্রতিক্রিয়া