Angular CDK দিয়ে বড় তালিকা ভার্চুয়ালাইজ করুন

ভার্চুয়াল স্ক্রোলিং প্রয়োগ করে বড় তালিকাগুলিকে আরও প্রতিক্রিয়াশীল করুন।

স্টিফেন ফ্লুইন
Stephen Fluin

স্ক্রোলিং তালিকাটি আজকের সবচেয়ে সাধারণ UI প্যাটার্নগুলির মধ্যে একটি, এটি আপনার প্রিয় সোশ্যাল মিডিয়া সাইটে একটি অসীম স্ক্রলিং ফিড ব্রাউজ করা, বা একটি এন্টারপ্রাইজ ড্যাশবোর্ড নেভিগেট করা। যখন স্ক্রলিং তালিকা খুব দীর্ঘ হয়ে যায় (শত, হাজার, বা কয়েক হাজার আইটেম), অ্যাপ্লিকেশন কার্যকারিতা ক্ষতিগ্রস্ত হতে পারে।

বড় তালিকাগুলি লোড হতে ধীর হতে পারে কারণ অ্যাপ্লিকেশনটিকে অবশ্যই লোড করতে হবে এবং সমস্ত ডেটা সামনে রেন্ডার করতে হবে৷ এগুলি রেন্ডার এবং নেভিগেট করতেও ধীর হতে পারে কারণ তালিকার প্রতিটি আইটেমে সমৃদ্ধ ডেটা, মিডিয়া এবং কার্যকারিতা থাকতে পারে৷

ব্যবহারকারীরা যখন পৃষ্ঠাটি লোড বা স্ক্রোল করে তখন সমস্যা অনুভব করতে পারে, যা হতাশা এবং পৃষ্ঠা পরিত্যাগের দিকে পরিচালিত করে।

কম্পোনেন্ট ডেভ কিটের সাথে কৌণিকভাবে ভার্চুয়াল স্ক্রোলিং

ভার্চুয়াল স্ক্রোলিং হল প্রাথমিক কৌশল যা এই স্কেল সমস্যাগুলি সমাধান করার জন্য ব্যবহৃত হয়। ভার্চুয়াল স্ক্রোলিং একটি খুব বড় তালিকার ছাপ দেয় - একটি উপযুক্ত আকারের স্ক্রোল বার প্রদান করে - এবং অ্যাপ্লিকেশনটিকে পুরো তালিকাটি মেমরিতে ধরে রাখার বা পৃষ্ঠায় রেন্ডার করার প্রয়োজন ছাড়াই তালিকাটি নেভিগেট করার ক্ষমতা দেয়৷

কৌণিক ভাষায়, কম্পোনেন্ট ডেভ কিট (CDK) দ্বারা ভার্চুয়াল স্ক্রোলিং প্রদান করা হয়। তালিকার মাধ্যমে আপনি যেভাবে পুনরাবৃত্তি করেন তা পরিবর্তন করে এবং কয়েকটি অতিরিক্ত কনফিগারেশন প্যারামিটার সরবরাহ করে, CDK-এর ভার্চুয়াল স্ক্রলিং স্বয়ংক্রিয়ভাবে আপনার তালিকাগুলির ভার্চুয়াল রেন্ডারিং পরিচালনা করবে, পৃষ্ঠার কর্মক্ষমতা এবং প্রতিক্রিয়াশীলতা উন্নত করবে।

একবারে সম্পূর্ণ তালিকা রেন্ডার করার পরিবর্তে, স্ক্রিনে ফিট করা আইটেমগুলির শুধুমাত্র একটি উপসেট (একটি ছোট বাফার) রেন্ডার করা হবে। ব্যবহারকারী নেভিগেট করার সাথে সাথে, আইটেমগুলির একটি নতুন উপসেট গণনা করা হয় এবং রেন্ডার করা হয়, যদি ইচ্ছা হয় তবে বিদ্যমান DOM পুনরায় ব্যবহার করা হয়।

এই পোস্টের বাকি অংশটি কীভাবে বেসিক ভার্চুয়াল স্ক্রোলিং সেট আপ করতে হয় তা নিয়ে চলে। আপনি এই নমুনা অ্যাপ্লিকেশনটিতে একটি সম্পূর্ণ কাজের উদাহরণ দেখতে পারেন:

ভার্চুয়াল স্ক্রোলিং সেট আপ করা হচ্ছে

প্রথমে নিশ্চিত করুন যে আপনি আপনার প্রিয় প্যাকেজ ম্যানেজার ব্যবহার করে @angular/cdk ইনস্টল করেছেন। npm ব্যবহার করে এটি ইনস্টল করতে টার্মিনালে এই কমান্ডটি চালান:

npm install --save @angular/cdk

আপনার অ্যাপে ScrollingModule যোগ করুন

CDK ইন্সটল করা হলে, @angular/cdk/scrolling প্যাকেজ থেকে ScrollingModule , যা ভার্চুয়াল স্ক্রোলিং পরিচালনা করে, আমদানি করুন। তারপরে এটি আপনার মডিউলের আমদানি অ্যারেতে যুক্ত করুন:

import {ScrollingModule} from '@angular/cdk/scrolling';

...
imports: [
  ScrollingModule
...
]
...

একটি ভিউপোর্ট তৈরি করুন

প্যাকেজ কিভাবে কাজ করে তা দেখতে, 0 থেকে 99,999 পর্যন্ত সংখ্যার একটি সাধারণ তালিকা সহ একটি উপাদান তৈরি করার চেষ্টা করুন:

@Component({
  template: `<div *ngFor="let item of list">{{item}}</div>`
})
export class ScrollComponent {
  list = Array.from({length: 100000}).map((_, i) => i);
}

যখন ব্রাউজার অ্যাপটি রেন্ডার করে, তখন এটিকে 100,000 পৃথক <div> উপাদান রেন্ডার করতে হবে। এটি সাধারণ টেক্সট নোডের জন্য ঠিক হতে পারে, কিন্তু পুনরাবৃত্তি করা টেমপ্লেটে যেকোন জটিলতা ভালভাবে পরিমাপ করবে না এবং যেকোন ইভেন্ট শ্রোতাদের উল্লেখযোগ্যভাবে গুণ করা হবে।

ভার্চুয়াল স্ক্রোলিং যোগ করতে এবং এই সমস্যাগুলি এড়াতে, আপনাকে একটি <cdk-virtual-scroll-viewport> উপাদানে তালিকাটি মোড়ানোর মাধ্যমে একটি ভিউপোর্ট তৈরি করতে হবে:

@Component({
  template: `<cdk-virtual-scroll-viewport>
    <div *ngFor="let item of list">{{item}}</div>
    </cdk-virtual-scroll-viewport>`
})
export class ScrollComponent {
  list = Array.from({length: 100000}).map((_, i) => i);
}

যেহেতু ScrollingModule গতিশীলভাবে তালিকার উপসেটগুলি রেন্ডার করে, আপনাকে স্ট্যান্ডার্ড CSS এর মাধ্যমে ভিউপোর্টের উচ্চতা নির্দিষ্ট করতে হবে। আপনাকে itemSize নির্দিষ্ট করে ভিউপোর্টকে এর বিষয়বস্তু সম্পর্কে একটি ইঙ্গিত দিতে হবে। একটি নির্দিষ্ট সময়ে কতগুলি আইটেম DOM-এ রাখতে হবে এবং কীভাবে একটি উপযুক্ত আকারের স্ক্রলবার রেন্ডার করতে হবে তা নির্ধারণ করতে মডিউলটি এই তথ্য ব্যবহার করে।

@Component({
  template: `<cdk-virtual-scroll-viewport itemSize="18" style="height:80vh">
    <div *ngFor="let item of list">{{item}}</div>
    </cdk-virtual-scroll-viewport>`
})
export class ScrollComponent {
  list = Array.from({length: 100000}).map((_, i) => i);
}

অবশেষে, *ngFor *cdkVirtualFor এ রূপান্তর করুন:

@Component({
  template: `<cdk-virtual-scroll-viewport itemSize="18" style="height:80vh">
    <div *cdkVirtualFor="let item of list">{{item}}</div>
    </cdk-virtual-scroll-viewport>`
})
export class ScrollComponent {
  list = Array.from({length: 100000}).map((_, i) => i);
}

পুরো তালিকার মাধ্যমে পুনরাবৃত্তি করার পরিবর্তে, ভিউপোর্ট ব্যবহারকারীর জন্য তালিকার সঠিক উপসেটের মাধ্যমে গতিশীলভাবে সনাক্ত করবে এবং পুনরাবৃত্তি করবে। এখন যখন ব্যবহারকারী পৃষ্ঠাটি লোড করে, তখন CDK-এর উচিত তালিকার উপসেটটি রেন্ডার করা যা স্ক্রিনে ফিট করে (একটু বাফারের সাথে), এবং ভিউপোর্টে যে কোনো স্ক্রলিং ইভেন্ট তালিকার উপযুক্ত উপসেট লোড এবং রেন্ডার করবে:

ব্যবহারকারী স্ক্রোল করার সময় একটি তালিকার CDK রেন্ডারিং উপসেট।

আরও এগিয়ে যাচ্ছে

CDK-এর ভার্চুয়াল স্ক্রোল ক্ষমতা এই মৌলিক উদাহরণের চেয়ে অনেক বেশি। নমুনা অ্যাপে , পুরো তালিকাটি মেমরিতে ছিল, তবে আরও জটিল অ্যাপ্লিকেশনের চাহিদা অনুযায়ী তালিকাটি আনা যেতে পারে। আপনি CDK ডকুমেন্টেশনে Scrolling সম্পর্কে পড়ে ScrollingModule এবং cdkVirtualOf নির্দেশের অন্যান্য ক্ষমতা সম্পর্কে আরও জানতে পারেন।

আনস্প্ল্যাশে মিস্টার কাপ / ফ্যাবিয়ান ব্যারালের হিরো ছবি।