Kā novērst kļūdas JavaScript ātruma iegūšanas funkcijās
JavaScript ir efektīvs tīmekļa izstrādes rīks, īpaši strādājot ar ārējām API. Tomēr pat pieredzējuši izstrādātāji pieļauj tipiskas kļūdas, rakstot funkcijas datu izgūšanai no API. Viena no šādām problēmām rodas, mēģinot nosūtīt argumentus funkcijai un kā atbildi iegūt nedefinētas vērtības.
Šajā rakstā ir apskatītas grūtības, kas rodas, rakstot JavaScript funkciju, kas izgūst bitcoin likmes starp divām valūtām. Problēmu "ReferenceError: btc nav definēta" bieži izraisa nepareizi norādīti parametri un mainīgie. No šīm bažām var izvairīties, ja kods ir pareizi strukturēts.
Mēs parādīsim, kā izveidot funkciju ar nosaukumu rīvēt (no, līdz), kas pieņem divus parametrus un atgriež maiņas kursu starp abām valūtām. Līdz šīs grāmatas beigām jūs uzzināsit, kā pareizi nodot argumentus un pārvaldīt kļūdas datu iegūšanas procesos.
Ja rodas līdzīgas problēmas vai esat saņēmis kļūdu “Nevar nolasīt nedefinētas īpašības (lasīšanas ātrums”), šis raksts palīdzēs novērst un efektīvi tās novērst. Apskatīsim soli pa solim, kā šīs problēmas novērst.
Komanda | Lietošanas piemērs |
---|---|
XMLHttpRequest() | Šis konstruktors ģenerē XMLHttpRequest gadījumu tīkla pieprasījumu veikšanai. To plaši izmanto asinhroniem HTTP vaicājumiem, īpaši vecākos tīmekļa projektos, kuros netiek izmantota funkcija Fetch. |
atvērt ('GET', url, true) | The atvērt () metode definē pieprasījuma veidu (šajā gadījumā GET), mērķa URL un to, vai pieprasījums ir asinhrons (true). |
ielāde | Šis ir XMLHttpRequest notikumu apdarinātājs, kas tiek aktivizēts, kad pieprasījums ir veiksmīgi pabeigts. Tas ļauj apstrādāt atbildi, tiklīdz ir saņemti visi dati. |
atnest() | The atnest() funkcija ir modernāka un daudzpusīgāka metode tīkla pieprasījumu veikšanai. Tas dod solījumu un parasti tiek izmantots mūsdienu JavaScript, lai veiktu asinhronus API zvanus. |
response.json() | Šī metode pārvērš atgriezto atbildi no API par JavaScript objektu. Tas galvenokārt ir paredzēts darbam ar JSON datiem, kas ir populārs API formāts. |
async/wait | The asinhronā atslēgvārds liek funkcijai atgriezt solījumu, savukārt gaidīt pārtrauc izpildi, līdz solījums ir izpildīts. Tas atvieglo asinhronā koda apstrādi. |
mēģināt/noķert | Try/catch bloks graciozi apstrādā kļūdas. Strādājot ar API izsaukumiem, ir lietderīgi fiksēt visus izņēmumus, kas radušies tīkla problēmu vai nepareizu datu dēļ. |
http.get() | Node.js funkcija http.get() nosūta GET pieprasījumu serverim un apstrādā atbildi. Tas ir būtiski, lai veiktu HTTP pieprasījumus aizmugursistēmas Node.js lietojumprogrammās. |
izjokot-atnest-izsmiet | Īpaša Jest testēšanas utilīta, lai izsmietu ieneses vaicājumus vienību testos. Tas ļauj pārbaudīt metodes, kas balstās uz ārējiem API izsaukumiem, atdarinot to atbildes. |
Izpratne par to, kā JavaScript funkcijas apstrādā API pieprasījumus par kriptovalūtas kursiem
Šeit sniegtie skripti demonstrē alternatīvas metodes, lai iegūtu kriptovalūtas maiņas kursus starp divām valūtām, izmantojot JavaScript. Pirmajā skriptā tiek izmantots objekts XMLHttpRequest, kas ir viena no vecākajām metodēm asinhrono HTTP pieprasījumu apstrādei JavaScript. Funkcija rīvēt (no, līdz) pieņem divus parametrus: konvertējamās valūtas. URL tiek ģenerēts dinamiski, pamatojoties uz sniegtajiem parametriem, un pieprasījums tiek nosūtīts uz Bitpay API galapunktu. Pēc atbildes saņemšanas dati tiek parsēti, izmantojot JSON.parse() parāda maiņas kursu dokumenta pamattekstā. Šis risinājums saglabā saderību ar vecākām pārlūkprogrammām, taču tam trūkst dažu jaunāku iespēju, piemēram, solījumu, kas ir apskatīti otrajā piemērā.
Otrajā piemērā, lai veiktu to pašu darbību, XMLHttpRequest vietā tiek izmantota Fetch API. Programma Fetch API ir jaunāka un piedāvā vienkāršāku veidu, kā veikt tīkla pieprasījumus. Tas izmanto solījumus padarīt asinhrono plūsmu lasāmāku un pārvaldāmāku. Kad funkcija tiek izsaukta, tā veic HTTP pieprasījumu uz to pašu URL un gaida atbildi. Pēc atbildes saņemšanas tas pārvērš datus par JSON objektu un iegūst ātrumu. Programma Fetch API uzlabo kļūdu pārvaldību, izmantojot try/catch blokus, lai apkopotu un pārvaldītu visas problēmas, kas rodas pieprasījuma vai datu apstrādes laikā.
Trešā skripta mērķis ir a aizmugures vide un veic API vaicājumus, izmantojot Node.js HTTP moduli. Tas ir īpaši noderīgi, izstrādājot servera puses lietotnes, kurām nepieciešams izgūt valūtas maiņas kursus. HTTP modulis ir iebūvēts Node.js un ļauj izstrādātājiem veikt HTTP darbības. Šī funkcija izveido URL tādā pašā veidā kā iepriekšējie skripti, nosūta GET izsaukumu API un pēc tam parsē saņemtos datus. Rezultāts tiek reģistrēts konsolē, nevis parādīts pārlūkprogrammā, padarot to labāk piemērotu aizmugursistēmas scenārijiem, kuriem nav nepieciešamas tīmekļa pārlūkprogrammas.
Visbeidzot, ir iekļauts Jest testa komplekts, lai pārbaudītu, vai Fetch API risinājums darbojas pareizi. Jest ir populāra testēšanas sistēma, un ar izjokot-atnest-izsmiet, mēs savos testos varam atdarināt API atbildes. Tas ļauj izstrādātājiem pārbaudīt savu kodu, faktiski neģenerējot tīkla vaicājumus, kas paātrina testēšanas procesu un izolē iespējamās kļūdas. Pārbaudes pārbauda, vai likmes dati ir veiksmīgi iegūti un parādīti dokumenta pamattekstā, apstiprinot, ka funkcija dažādos kontekstos darbojas kā paredzēts. Testēšana ir svarīgs izstrādes elements, īpaši strādājot ar ārējām API, jo tas palīdz agrīni atklāt kļūdas un uzlabo produkta kopējo stabilitāti.
JavaScript: tiek novērsta problēma "ReferenceError: btc nav definēts".
Priekšgala vidē šī metode izmanto JavaScript un XMLHTTPRequest, lai izgūtu dinamiskus datus.
// Solution 1: Using XMLHTTPRequest to fetch cryptocurrency rates
function grate(from, to) {
var burl = 'https://bitpay.com/rates/';
var url = burl + from + '/' + to;
var ourRequest = new XMLHttpRequest();
ourRequest.open('GET', url, true);
ourRequest.onload = function() {
if (ourRequest.status >= 200 && ourRequest.status < 400) {
var response = JSON.parse(ourRequest.responseText);
document.body.innerHTML = 'Rate: ' + response.data.rate;
} else {
console.error('Error fetching the data');
}
};
ourRequest.onerror = function() {
console.error('Connection error');
};
ourRequest.send();
}
// Test the function with actual currency codes
grate('btc', 'usd');
JavaScript: Fetch API ir modernāka pieeja API pieprasījumu apstrādei.
Šis risinājums uzlabo moderno priekšgala lietotņu veiktspēju un kļūdu apstrādi, izmantojot JavaScript un Fetch API.
// Solution 2: Using Fetch API for cleaner asynchronous requests
async function grate(from, to) {
var burl = 'https://bitpay.com/rates/';
var url = burl + from + '/' + to;
try {
let response = await fetch(url);
if (!response.ok) throw new Error('Network response was not ok');
let data = await response.json();
document.body.innerHTML = 'Rate: ' + data.data.rate;
} catch (error) {
console.error('Fetch error: ', error);
}
}
// Test the function with Fetch API
grate('btc', 'usd');
Node.js aizmugursistēma: API pieprasījumu veikšana, izmantojot Node HTTP moduli
Šī metode ienes valūtas kursus, izmantojot Node.js un HTTP moduli aizmugursistēmas lietojumprogrammās.
// Solution 3: Using Node.js HTTP module to fetch data from API
const http = require('http');
function grate(from, to) {
const url = 'http://bitpay.com/rates/' + from + '/' + to;
http.get(url, (resp) => {
let data = '';
resp.on('data', (chunk) => { data += chunk; });
resp.on('end', () => {
let rateData = JSON.parse(data);
console.log('Rate: ' + rateData.data.rate);
});
}).on('error', (err) => {
console.log('Error: ' + err.message);
});
}
// Test the Node.js function
grate('btc', 'usd');
Priekšgala risinājumu vienību testi, izmantojot Jest
JavaScript Fetch API risinājuma funkcionalitāte tiek pārbaudīta, izmantojot vienību testus, kas rakstīti Jest.
// Solution 4: Unit testing Fetch API using Jest
const fetchMock = require('jest-fetch-mock');
fetchMock.enableMocks();
test('grate() fetches correct rate data', async () => {
fetch.mockResponseOnce(JSON.stringify({ data: { rate: 50000 }}));
const rate = await grate('btc', 'usd');
expect(document.body.innerHTML).toBe('Rate: 50000');
});
Asinhrono JavaScript funkciju izpēte API pieprasījumiem
Asinhrono pieprasījumu apstrāde ir ļoti svarīga, strādājot ar API JavaScript. Fetch API un XMLHttpRequest ir divi galvenie veidi, kā veikt šos pieprasījumus. Asinhrono funkciju mērķis ir novērst pārlūkprogrammas vai servera sastingšanu, gaidot atbildi, tādējādi uzlabojot lietotāja pieredzi un veiktspēju. Izpratne par asinhrono darbību ļauj izstrādātājiem izveidot atsaucīgākas lietojumprogrammas, kas reāllaikā var izgūt datus no API, neietekmējot galveno pavedienu.
Lai apstrādātu asinhronos pieprasījumus, ir jāpārvalda atbildes un dažādas kļūdas, kas var rasties procesa laikā. Piemēram, viena izplatīta problēma, izgūstot datus no ārējām API, ir nenoteiktas vērtības atgriešana, kā to parāda kļūda sākotnējā gadījumā. Ja izstrādātājiem neizdodas efektīvi pārvaldīt izņēmumus, viņu lietojumprogramma var avarēt vai radīt neprecīzus rezultātus. Ļoti svarīga ir efektīva kļūdu apstrāde, piemēram, mēģinājuma/tveršanas bloki vai atbildes statusa pārbaudes.
Papildus kļūdu apstrādei drošība ir svarīgs apsvērums, mijiedarbojoties ar ārējām API. Sensitīvu datu atklāšana vai tiešas piekļuves piešķiršana API bez validācijas var radīt ievainojamības. Viens no risinājumiem ir ieviest servera puses pieprasījumus, kuros API izsaukumi tiek veikti no aizmugures servera, nodrošinot papildu drošības pakāpi. Tas aizliedz ļaunprātīgiem dalībniekiem iejaukties priekšgala pieprasījumos vai tieši iegūt sensitīvus datus, izmantojot pārlūkprogrammu. Šo API savienojumu nodrošināšana ir ļoti svarīga, jo īpaši, ja tiek risināta finanšu informācija, piemēram, bitcoin likmes.
Bieži uzdotie jautājumi par API datu ienešanu, izmantojot JavaScript
- Kāda ir atšķirība starp XMLHttpRequest un Fetch API?
- Lai gan abus var izmantot, lai nosūtītu HTTP vaicājumus, Fetch API ir jaunāka un tai ir vienkāršāka saskarne. Tas izmanto solījumus, kas atvieglo asinhrono procesu darbību.
- Kā rīkoties ar kļūdām, lietojot Fetch API?
- Lai apstrādātu kļūdas, iekapsulējiet ieneses pieprasījumu sadaļā a try/catch bloķēt un pārbaudīt atbildes statusu. Tas padara jūsu kodu izturīgāku pret kļūmēm.
- Kāpēc, mēģinot izgūt datus no API, saņemu nenoteiktu vērtību?
- Tas parasti notiek, ja API galapunkts vai argumenti ir nepareizi vai atbilde nav pareizi apstrādāta, izmantojot JSON.parse().
- Vai varu pārbaudīt API pieprasījumus bez faktiska tīkla zvana?
- Jā, jūs varat izmantot tādas bibliotēkas kā jest-fetch-mock Jest, lai imitētu API vaicājumus un atbildes testēšanai.
- Kā es varu uzlabot savu API pieprasījumu drošību?
- Viena no iespējām, kā uzlabot drošību, ir veikt pieprasījumus no aizmugursistēmas servera, nevis priekšgala. Tas paslēpj svarīgas API atslēgas un aizsargā jūsu lietojumprogrammu pret ļaunprātīgiem dalībniekiem.
Pēdējās domas par API kļūdu un pieprasījumu apstrādi
Izpratne par API izsaukumu apstrādi JavaScript ir ļoti svarīga dinamisku lietojumprogrammu izstrādei. Izmantojot tādas tehnoloģijas kā XMLHttpRequest un Fetch API, izstrādātāji var efektīvi izgūt reāllaika datus, piemēram, kriptovalūtu cenas. Tomēr ir pareizi jārisina tipiskas problēmas, piemēram, nedefinēti rekvizīti.
Ieviešot adekvātas kļūdu apstrādes un testēšanas procedūras, jūsu kods kļūst uzticamāks. Neatkarīgi no tā, vai izstrādājat priekšgala vai aizmugures lietojumprogrammas, API zvanu aizsardzība un mūsdienīgu pieeju ieviešana nodrošinās drošākus un efektīvākus tiešsaistes risinājumus.
JavaScript API pieprasījumu apstrādes avoti un atsauces
- Izstrādāts, kā apstrādāt API pieprasījumus JavaScript, izmantojot XMLHttpRequest un Ienest API, atsaucoties uz ārējiem ceļvežiem un dokumentāciju par JavaScript asinhrono programmēšanu. Apmeklējiet MDN tīmekļa dokumenti — XMLHttpRequest .
- Ietver labāko praksi kļūdu apstrādē un API pieprasījumu nodrošināšanā gan priekšgala, gan aizmugures izstrādē. Atsauce: Node.js oficiālā dokumentācija — HTTP pieprasījumi .
- Sniedz ieskatu API funkcionalitātes testēšanā, izmantojot Jest un izspēles rīkus, piemēram izjokot-atnest-izsmiet. Lai iegūtu sīkāku informāciju, pārbaudiet Jest oficiālā dokumentācija .