ஜாவாஸ்கிரிப்டைப் பயன்படுத்தி கீஃப்ரேம் மதிப்புகளைக் கணக்கிடுவது மற்றும் அனிமேட் செய்வது எப்படி
டைனமிக் இணையப் பயன்பாடுகளை உருவாக்கும்போது, ஜாவாஸ்கிரிப்டை CSS அனிமேஷன்களுடன் இணைப்பது மென்மையான, பார்வைக்கு ஈர்க்கும் மாற்றங்களை உருவாக்கலாம். நிகழ்நேர தரவு மதிப்புகளின் அடிப்படையில் கூறுகளை அனிமேஷன் செய்வது ஒரு பொதுவான சவால். SVG மற்றும் ஸ்ட்ரோக்-டாஷ்ஆஃப்செட்டைப் பயன்படுத்தி முன்னேற்றப் பட்டியின் தற்போதைய சதவீதத்தை பிரதிபலிக்கும் கீஃப்ரேம் அனிமேஷன்களை உருவாக்குவது ஒரு சிறந்த எடுத்துக்காட்டு.
சந்தாதாரர் எண்ணிக்கை போன்ற டைனமிக் மதிப்புகளை நீங்கள் காண்பிக்கும் போது இந்த நுட்பம் மிகவும் பயனுள்ளதாக இருக்கும், இந்த எடுத்துக்காட்டில் சந்தாக்களின் எண்ணிக்கை நிகழ்நேரத்தில் புதுப்பிக்கப்படும். அனிமேஷன் தடையின்றி செயல்பட, இந்த எண்ணை சதவீதமாக மாற்றி, அதை நேரடியாக CSS அனிமேஷனுக்குப் பயன்படுத்தலாம்.
இருப்பினும், ஜாவாஸ்கிரிப்ட் CSS அனிமேஷன்களைக் கையாளும் போது குழப்பமாக இருக்கும், குறிப்பாக கீஃப்ரேம்களை திறம்பட கையாளுவதற்கு சதவீதங்கள் போன்ற மதிப்புகளைக் கணக்கிடும்போது. இந்த வழக்கில், ஜாவாஸ்கிரிப்ட் மூலம் டைனமிக் தரவை எவ்வாறு பிரித்தெடுப்பது மற்றும் கையாளுவது என்பதைப் புரிந்துகொள்வது, உங்கள் அனிமேஷன்கள் சரியான மதிப்பைப் பிரதிபலிக்கின்றன என்பதை உறுதிப்படுத்துவது முக்கியம்.
இந்தக் கட்டுரையானது ஜாவாஸ்கிரிப்டைப் பயன்படுத்தி எண் தரவுகளை அகற்றவும், சதவீதங்களைக் கணக்கிடவும், ஸ்ட்ரோக்-டாஷ்ஆஃப்செட் பண்புகளைப் பயன்படுத்தி கீஃப்ரேம்களில் அவற்றைப் பயன்படுத்தவும் உங்களுக்கு வழிகாட்டும். முடிவில், பதிலளிக்கக்கூடிய அனிமேஷன்களை உருவாக்க JavaScript மற்றும் CSS எவ்வாறு இணைந்து செயல்பட முடியும் என்பதை நீங்கள் தெளிவாகப் புரிந்துகொள்வீர்கள்.
| கட்டளை | பயன்பாட்டின் உதாரணம் |
|---|---|
| fetch() | பெறுதல்() முறையானது ஆதாரத்திலிருந்து தரவைக் கோர பயன்படுகிறது (எ.கா. உரை கோப்பு, API). இந்த ஸ்கிரிப்ட்டில், முன்னேற்றப் பட்டியில் செயலாக்க ஒரு உரை கோப்பிலிருந்து சந்தாதாரர் தரவைப் பெற இது பயன்படுகிறது. |
| parseInt() | parseInt() செயல்பாடு ஒரு சரத்தை முழு எண்ணாக மாற்றுகிறது. இங்கே, தற்போதைய சந்தாதாரர் எண்ணிக்கையைப் பெற, சாய்வுக்கு முந்தைய மதிப்பை (எ.கா., 42/50) நீக்குகிறது. |
| split() | ஸ்பிலிட்() முறையானது ஒரு சரத்தை ஒரு டிலிமிட்டரின் அடிப்படையில் ஒரு வரிசையாகப் பிரிக்கிறது. இந்த வழக்கில், தற்போதைய சந்தாதாரர் எண்ணிக்கையை இலக்கிலிருந்து பிரிக்க '/' ஐப் பயன்படுத்துகிறது (42 இலிருந்து 42/50). |
| strokeDashoffset | strokeDashoffset என்பது ஒரு SVG பண்புக்கூறு ஆகும், இது ஒரு பக்கவாதம் எவ்வாறு வரையப்படுகிறது என்பதைக் கட்டுப்படுத்துகிறது. சந்தா சதவீதத்தின் அடிப்படையில் SVG வட்டத்தின் நிரப்புதலை மாறும் வகையில் மாற்றுவதற்கு இது இங்கு கையாளப்படுகிறது. |
| setTimeout() | இந்த முறை ஒரு குறிப்பிட்ட தாமதத்திற்குப் பிறகு ஒரு செயல்பாட்டை அழைக்கிறது. லேபிள்களை சுழற்றுவதற்கான இடைவெளியை அமைக்க இது இங்கே பயன்படுத்தப்படுகிறது, சில வினாடிகளுக்குப் பிறகு புதிய லேபிள்கள் தோன்றும். |
| cloneNode() | cloneNode(true) ஆனது அதன் குழந்தைகள் உட்பட ஒரு முனையின் நகலை உருவாக்க பயன்படுகிறது. லேபிள் டெம்ப்ளேட்டை நகலெடுத்து, DOM இல் டைனமிக் முறையில் சேர்ப்பதற்கு இது அவசியம். |
| visibility | இந்த CSS சொத்து லேபிள்களை மறைக்க அல்லது காட்ட JavaScript மூலம் கட்டுப்படுத்தப்படுகிறது. சுழற்சியின் போது ஒரு நேரத்தில் ஒரு லேபிள் மட்டுமே தெரியும் என்பதை இது உறுதி செய்கிறது. |
| strokeDasharray | StrokeDasharray ஒரு SVG ஸ்ட்ரோக்கில் உள்ள கோடுகள் மற்றும் இடைவெளிகளின் வடிவத்தை வரையறுக்கிறது. ஸ்ட்ரோக் டாஷோஃப்செட் மூலம் அனிமேஷன் செய்யப்பட்ட வட்டத்தின் சுற்றளவுடன் பொருந்துவதற்கு இது ஒரு குறிப்பிட்ட மதிப்பிற்கு (450) அமைக்கப்பட்டுள்ளது. |
ஜாவாஸ்கிரிப்ட் மூலம் SVG வட்டங்களை அனிமேட் செய்தல்: ஒரு படி-படி-படி வழிகாட்டி
இந்த எடுத்துக்காட்டில், ஜாவாஸ்கிரிப்ட் மற்றும் CSS ஆகியவற்றின் கலவையைப் பயன்படுத்தி SVG வட்டத்திற்கான டைனமிக் அனிமேஷனை உருவாக்கினோம். நிகழ்நேரத்தில் சந்தா எண்ணிக்கையை பார்வைக்கு பிரதிநிதித்துவப்படுத்த ஒரு வட்டத்தின் முன்னேற்றத்தை உயிரூட்டுவதே முக்கிய குறிக்கோள். வட்டம் பயன்படுத்துகிறது CSS சொத்து, இது வட்டத்தின் பக்கவாதம் எவ்வளவு தெரியும் என்பதைக் கட்டுப்படுத்துகிறது. ஜாவாஸ்கிரிப்ட் முன்னேற்றத்தின் சதவீதத்தைப் பெறவும் கணக்கிடவும் பயன்படுத்தப்படுகிறது, பின்னர் அந்த மதிப்பை ஸ்ட்ரோக்கிற்குப் பயன்படுத்துகிறது, இது நிகழ்நேர தரவின் அடிப்படையில் மென்மையான அனிமேஷனை அனுமதிக்கிறது.
ஒரு முக்கிய கூறு ஆகும் செயல்பாடு, இது ஒரு கோப்பு அல்லது சேவையகத்திலிருந்து தரவை மீட்டெடுக்கிறது, இந்த விஷயத்தில், சந்தா எண்ணிக்கை. ஸ்கிரிப்ட் சரம் கையாளுதல் முறைகளைப் பயன்படுத்தி தரவின் எண்ணியல் பகுதியைப் பிரித்தெடுக்கிறது , மற்றும் முடிவைப் பயன்படுத்தக்கூடிய எண்ணாக மாற்றுகிறது . தற்போதைய சந்தா எண்ணிக்கையை இலக்கால் வகுப்பதன் மூலம், முன்னேற்றத்தை தசமமாக (சதவீதம்) கணக்கிடுகிறோம். இந்த சதவீதம் பின்னர் பயன்படுத்தப்படும் stroke-dashoffset காட்சி விளைவை உருவாக்க.
இரண்டாவது ஸ்கிரிப்ட் லேபிள் சுழற்சியைக் கையாளுகிறது, இது காட்சிக்கு டைனமிக் உள்ளடக்கத்தின் அடுக்கைச் சேர்க்கிறது. இதைப் பயன்படுத்தி DOM இல் லேபிள்கள் சேர்க்கப்படுகின்றன ஏற்கனவே உள்ள லேபிள் டெம்ப்ளேட்டை நகலெடுக்கும் முறை. ஒவ்வொரு லேபிளும் ஒரு செட் இடைவெளியில் சுழற்றப்படுகிறது, இது கட்டுப்படுத்தப்படுகிறது செயல்பாடு. இந்த முறை குறிப்பிட்ட தாமதத்திற்குப் பிறகு சுழற்சியைத் தூண்டுகிறது, பயனர் தொடர்பு தேவையில்லாமல் லேபிள்களுக்கு இடையில் ஒரு மென்மையான மாற்றத்தை உருவாக்குகிறது.
கலவை வட்டம் மற்றும் லேபிள் சுழற்சி ஸ்கிரிப்ட் ஒரு ஈர்க்கக்கூடிய பயனர் இடைமுகத்தை உருவாக்குகிறது. வட்டத்தின் முன்னேற்றம் மற்றும் காட்டப்படும் லேபிள்கள் இரண்டையும் மாறும் வகையில் மாற்றுவதன் மூலம், பயனர்களுக்கு நிகழ்நேரத்தில் முன்னேற்றத்தின் காட்சி குறிப்பை வழங்குகிறோம். குறியீட்டின் மாடுலாரிட்டி இந்த அம்சங்களை மற்ற தரவு-உந்துதல் பயன்பாடுகளுக்கு எளிதாக மாற்றியமைக்கப்படுவதை உறுதிசெய்கிறது, இது டைனமிக் UI கூறுகளை செயல்படுத்த விரும்பும் டெவலப்பர்களுக்கு இது ஒரு நெகிழ்வான தீர்வாக அமைகிறது.
ஜாவாஸ்கிரிப்ட் மற்றும் CSS கீஃப்ரேம்கள் மூலம் SVG ப்ரோக்ரஸ் பார்களை அனிமேட் செய்தல்
இந்த தீர்வு வெண்ணிலா ஜாவாஸ்கிரிப்ட் மற்றும் SVG ஐ முன்-இறுதி டைனமிக் புரோகிராம் பார் அனிமேஷனுக்காக பயன்படுத்துகிறது. ஸ்கிரிப்ட் மதிப்புகளைப் பிரித்தெடுக்கிறது, சதவீதங்களைக் கணக்கிடுகிறது மற்றும் மென்மையான அனிமேஷனுக்காக SVG உறுப்புகளின் ஸ்ட்ரோக்-டாஷ்ஆஃப்செட்டில் அவற்றைப் பயன்படுத்துகிறது.
// HTML and SVG structure<div id="labels"></div><svg width="200" height="200"><circle id="circle" cx="100" cy="100" r="90" /></svg>// JavaScript to animate stroke-dashoffsetlet labels = document.getElementById("labels");const SubGoal = 50; // Total subscription goalfunction updateProgress(data) {const SubCount = parseInt(data.split('/')[0]); // Extract numberconst SubPercent = SubCount / SubGoal; // Calculate percentageconst SubPercentStroke = 450 - 450 * SubPercent; // Set stroke offsetdocument.getElementById('circle').style.strokeDashoffset = SubPercentStroke;}// Example usagefetch('subscribers.txt').then(response => response.text()).then(data => updateProgress(data));
ஜாவாஸ்கிரிப்ட் மூலம் டைனமிக் லேபிள் சுழற்சி
இந்த தீர்வு JavaScript ஐப் பயன்படுத்தி வெவ்வேறு லேபிள்களை செட் இடைவெளியில் மாறும் வகையில் சுழற்றுகிறது. இது பயனர் அமைப்புகளின் அடிப்படையில் நிலையான மற்றும் சுழலும் காட்சிகளை ஆதரிக்கிறது.
// Label rotation logicvar displaySettings = "RotatingDisplays";var displayRotationSeconds = 2;var displayRotationIndex = 0;function rotateLabelDisplay() {if (displayRotationIndex >= labels.children.length) {displayRotationIndex = 0;}for (const label of labels.children) {label.style.visibility = 'hidden';}let label = labels.children[displayRotationIndex];label.style.visibility = 'visible';displayRotationIndex++;setTimeout(rotateLabelDisplay, displayRotationSeconds * 1000);}// Trigger rotation if display setting is enabledif (displaySettings === "RotatingDisplays") {rotateLabelDisplay();} else {labels.children[0].style.visibility = "visible";}
ஜாவாஸ்கிரிப்ட் மற்றும் CSS மாறிகள் மூலம் அனிமேஷன்களை மேம்படுத்துதல்
பயன்படுத்துவதில் ஒரு முக்கியமான அம்சம் அனிமேஷன்களைக் கட்டுப்படுத்துவது என்பது அதனுடன் தொடர்பு கொள்ளும் திறன் ஆகும் . இந்த மாறிகள் டெவலப்பர்களை மீண்டும் பயன்படுத்தக்கூடிய மற்றும் எளிதில் பராமரிக்கக்கூடிய குறியீட்டை உருவாக்க அனுமதிக்கின்றன. எடுத்துக்காட்டாக, ஸ்ட்ரோக்-டாஷ்ஆஃப்செட் போன்ற ஹார்ட்கோடிங் அனிமேஷன் மதிப்புகளுக்குப் பதிலாக ஜாவாஸ்கிரிப்ட்டில் நேரடியாக அவற்றை நீங்கள் CSS மாறிகள் என வரையறுத்து, ஜாவாஸ்கிரிப்டைப் பயன்படுத்தி கையாளலாம். இது உங்கள் அனிமேஷன் பண்புகளை நிர்வகிக்க ஒரு தூய்மையான வழியை வழங்குகிறது மற்றும் உங்கள் குறியீட்டை மேலும் மட்டு மற்றும் அளவிடக்கூடியதாக ஆக்குகிறது.
ஜாவாஸ்கிரிப்டை CSS உடன் இணைக்கும்போது மற்றொரு சக்திவாய்ந்த அம்சம் நிகழ்வு கேட்பவர்களின் பயன்பாடு ஆகும். ஒரு பொத்தானைக் கிளிக் செய்வது அல்லது பக்கத்தை கீழே ஸ்க்ரோல் செய்வது போன்ற பயனர் தொடர்புகளின் அடிப்படையில் நிகழ்வு சார்ந்த அனிமேஷன்கள் தூண்டப்படலாம். எங்கள் எடுத்துக்காட்டில், ஊடாடுதலைச் சேர்ப்பதன் மூலம் நீங்கள் அனிமேஷனை மேம்படுத்தலாம். உதாரணமாக, ஒரு பயனர் சந்தா அல்லது மற்றொரு செயலைச் செய்யும் போதெல்லாம் ஸ்ட்ரோக்-டாஷ்ஆஃப்செட்டை மீண்டும் கணக்கிடலாம் மற்றும் மாறும் வகையில் பயன்படுத்தலாம். இது நிகழ்நேர தரவுகளுக்கு பதிலளிக்கும் மிகவும் ஈடுபாடு மற்றும் ஊடாடும் அனுபவத்தை உருவாக்குகிறது.
கூடுதலாக, இணைத்தல் கீஃப்ரேம்களுடன் மென்மையான மற்றும் திறமையான அனிமேஷன்களை உருவாக்க மற்றொரு வழி. இந்த முறையானது உலாவியின் உகந்த ரீபெயின்ட் சுழற்சியின் போது அனிமேஷன்கள் செய்யப்படுவதை உறுதி செய்கிறது, இது பாரம்பரிய செட்இண்டர்வல் அல்லது செட் டைம்அவுட்டன் ஒப்பிடும்போது சிறந்த செயல்திறனை வழங்குகிறது. பயனர் இடைமுகத்தை மெதுவாக்கும் அடிக்கடி அனிமேஷன் அல்லது கனமான ஜாவாஸ்கிரிப்ட் செயல்முறைகளைக் கையாளும் போது இந்த நுட்பம் மிகவும் பயனுள்ளதாக இருக்கும்.
- எப்படி செய்கிறது SVG அனிமேஷன்களை பாதிக்குமா?
- தி SVG பாத் ஸ்ட்ரோக் எவ்வளவு தெரியும் என்பதைக் கட்டுப்படுத்துகிறது. அதன் மதிப்பை மாற்றுவது சீரான முன்னேற்றம் போன்ற அனிமேஷன்களை அனுமதிக்கிறது.
- பங்கு என்ன நிகழ் நேர அனிமேஷன்களில்?
- API அல்லது கோப்பிலிருந்து தரவை மீட்டெடுக்கப் பயன்படுகிறது. அனிமேஷன்களில், இது சந்தாதாரர் எண்ணிக்கை போன்ற மாறும் மதிப்புகளை ஏற்ற உதவுகிறது, பின்னர் அவை திரையில் அனிமேஷன் செய்யப்படலாம்.
- முடியும் அனிமேஷன் இடைவெளிகளைக் கட்டுப்படுத்தப் பயன்படுத்தப்படலாமா?
- ஆம், இடைவெளியில் லேபிள்களை சுழற்றுவது போன்ற அனிமேஷன்களில் தாமதங்களை அறிமுகப்படுத்த பயன்படுத்தலாம்.
- நோக்கம் என்ன ஜாவாஸ்கிரிப்ட் அனிமேஷன் ஸ்கிரிப்ட்களில்?
- ஒரு சரத்தை ("42/50" போன்றது) முழு எண்ணாக மாற்றுகிறது, இது டைனமிக் அனிமேஷன்களில் சதவீதங்களைக் கணக்கிடுவதற்கு அவசியமானது.
- நான் ஏன் பயன்படுத்த வேண்டும் பதிலாக ?
- அனிமேஷன்களுக்கு உகந்ததாக உள்ளது, உலாவியின் ரீபெயின்ட் சுழற்சியுடன் அவற்றை ஒத்திசைப்பதன் மூலம் மென்மையான மாற்றங்களை உறுதி செய்கிறது.
இணைத்தல் CSS உடன் நிகழ்நேர தரவுகளுக்கு பதிலளிக்கக்கூடிய சக்திவாய்ந்த மற்றும் மாறும் அனிமேஷன்களை அனுமதிக்கிறது. சதவீதங்கள் போன்ற மதிப்புகளைக் கணக்கிடுவது மற்றும் அவற்றை கீஃப்ரேம் அனிமேஷன்களுக்கு எவ்வாறு பயன்படுத்துவது என்பதைப் புரிந்துகொள்வதன் மூலம், நேரடி முன்னேற்றம் அல்லது தரவு புதுப்பிப்புகளைப் பிரதிபலிக்கும் ஈர்க்கக்கூடிய மற்றும் பதிலளிக்கக்கூடிய பயனர் இடைமுகங்களை நீங்கள் உருவாக்கலாம்.
இந்த வழிகாட்டியில் உள்ள நுட்பங்கள் மூலம், நீங்கள் போன்ற பண்புகளை எளிதாக கையாளலாம் SVG அனிமேஷன்கள் மற்றும் உறுப்புகளை மாறும் வகையில் சுழற்றும். நிகழ்நேர தரவு உள்ளீடுகளுடன் தங்கள் திட்டங்களில் டைனமிக் அனிமேஷன்களை ஒருங்கிணைக்க விரும்பும் டெவலப்பர்களுக்கு இந்த கலவையானது அளவிடக்கூடிய தீர்வை வழங்குகிறது.
- பயன்படுத்துவது பற்றிய விரிவான தகவல்கள் SVG அனிமேஷன்களை இங்கே காணலாம் MDN Web Docs: stroke-dashoffset .
- ஜாவாஸ்கிரிப்ட் மற்றும் CSS ஐப் பயன்படுத்தி டைனமிக் கீஃப்ரேம் அனிமேஷன்கள் பற்றிய கூடுதல் நுண்ணறிவுகளுக்கு, பார்க்கவும் ஸ்மாஷிங் இதழ்: CSS கீஃப்ரேம் அனிமேஷன்கள் .
- DOM ஐக் கையாள்வதற்கான கூடுதல் வழிகாட்டுதல் JavaScript இல் கிடைக்கிறது MDN Web Docs: cloneNode .
- பயன்படுத்துவது பற்றி மேலும் அறிக நிகழ்நேரத்தில் தரவை மீட்டெடுக்க MDN Web Docs: Fetch ஐப் பயன்படுத்துதல் .