ஜாவாஸ்கிரிப்டைப் பயன்படுத்தி கீஃப்ரேம் மதிப்புகளைக் கணக்கிடுவது மற்றும் அனிமேட் செய்வது எப்படி
டைனமிக் இணையப் பயன்பாடுகளை உருவாக்கும்போது, ஜாவாஸ்கிரிப்டை 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-dashoffset
let labels = document.getElementById("labels");
const SubGoal = 50; // Total subscription goal
function updateProgress(data) {
const SubCount = parseInt(data.split('/')[0]); // Extract number
const SubPercent = SubCount / SubGoal; // Calculate percentage
const SubPercentStroke = 450 - 450 * SubPercent; // Set stroke offset
document.getElementById('circle').style.strokeDashoffset = SubPercentStroke;
}
// Example usage
fetch('subscribers.txt').then(response => response.text())
.then(data => updateProgress(data));
ஜாவாஸ்கிரிப்ட் மூலம் டைனமிக் லேபிள் சுழற்சி
இந்த தீர்வு JavaScript ஐப் பயன்படுத்தி வெவ்வேறு லேபிள்களை செட் இடைவெளியில் மாறும் வகையில் சுழற்றுகிறது. இது பயனர் அமைப்புகளின் அடிப்படையில் நிலையான மற்றும் சுழலும் காட்சிகளை ஆதரிக்கிறது.
// Label rotation logic
var 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 enabled
if (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 ஐப் பயன்படுத்துதல் .