Bu challengeda bir WIDGET için bir uygulama geliştireceksiniz.
İşlevini inceleyin ve ayrıca Chrome Geliştirici Araçları'nda Konsolu, Ağ sekmesini ve Öğeler sekmesini inceleyin:
- Widget'ın aynı işlevselliğe sahip iki sürümü vardır: class-based ve fonksiyonel (biz fonksiyonel kısmıyla ilgileniyoruz).
- Sayfanın altındaki input kutusu, geçerli bir e-posta adresi girilmesini bekler.
- Ağ sekmesinde "Önizleme" altında görebileceğiniz gibi, e-posta doğrulama hataları sunucudan gelir.
- Form gönderiminde sunucuya gönderilen payload, Ağ sekmesinde "Payload" altında görülebilir
- Özellikle 1 geçerli email,
[email protected]
, "Forbiden" sunucu hatasıyla cevap verir❗ - Koordinatların orijini Gridin sol üst köşesindedir.
- Node 16.x
- NPM 8.x (
npm i -g npm
NPM güncellemek için) - Unix-benzeri bir shell (Gitbash/bash/zsh)
- Chrome >= 100.x
❗ Diğer versiyonlarda da çalışabilir fakat test edilmedi.
- Forklayın, klonlayın, ve
npm install
. (Başka bir kütüphaneye ihtiyaç yok.) - Projeyi çalıştırmak için
npm run dev
. http://localhost:3000
.- Testler için
npm test
. Test dosyalarıcodegrade_mvp.test.js
veApp.test.js
.
- Uygulama bir API uç noktasına sahip:
POST http://localhost:9000/api/result
. - Postman gibi bir HTTP istemcisi kullanarak bu uç noktayı deneyebilirsiniz.
- Uç nokta şu şekilde bir payloada gereksinim duyuyor:
{ "x": 1, "y": 2, "steps": 3, "email": "[email protected]" }
:x
1 ile 3 arasında bir integer olmalı.y
1 ile 3 arasında bir integer olmalı.steps
0 dan büyük bir integer olmalı.email
geçerli bir email adresi olmalı.
- Eğer payload hatalı gönderilirse bir "Unprocessable Entity"(İşlenemez Varlık) sunucu cevabı döner.
-
Bu README'nin üst kısmında bağlantısı verilen prototipte gösterilen işlevselliği ve DOM'u kopyalayın.
-
Kodlarınızı
frontend/components/AppFunctional.js
dosyasına yazın. -
"AppFunctional.js" tarafından sunulan bileşen, stateful olan işlevsel bir bileşen olmalıdır.
-
Bileşenleriniz tarafından üretilen DOM, prototipteki DOM ile tam olarak eşleşmelidir:
- HTML öğelerinin hiyerarşisi, idleri, class adları vb. aynı olmalıdır..
- Geçerli kare, büyük bir B ve "active" class adıyla işaretlenmiştir.
- Sayfada görüntülenen submit başarısı ve hata mesajları API'den gelir.(Network tabını inceleyin).
- Frontend form doğrulama eklemenize gerek yok.
-
Gridin her bir karesinin koordinatları aşağıdaki gibidir:
(1, 1) (2, 1) (3, 1) (1, 2) (2, 2) (3, 2) (1, 3) (2, 3) (3, 3)
❗ TÜM TESTLER GEÇMELİ
codegrade_mvp.test.js
den ilham alarakfrontend/components/App.test.js
içine 5 tane test kodu yazın:- Test dosyanızın içine seçtiğiniz bir bileşeni import edin,
AppFunctional.js
. - Başlıklardaki, butonlardaki, bağlantılardaki görünür metinlerin ekranda göründüğünü test edin.
- Inputa metin girildiğinde value değişimini test eden bir test yazın.
- Test dosyanızın içine seçtiğiniz bir bileşeni import edin,
-
AppFunctional
içinde bazı önerilen stateler ve yardımcı fonksiyonlar bulacaksınız. Bunları kullanmaktan çekinmeyin. -
Karelerin durumunu izlemek için karmaşık bir yapıya ihtiyacınız yok çünkü karelerde herhangi bir bilgi depolamıyoruz.
-
Gridin --yalnızca görsel olarak- üç sıraya bölünmüş tek boyutlu bir dizi olduğunu hayal edin..
-
Gridi sürmek için ihtiyaç duyduğunuz tek bileşen statei, 0 ile 8 arasında bir tamsayıdır: "B" nin indexi şu satırda.
-
Koordinatlar gibi diğer bilgi parçaları bu dizinden türetilebilir ve kendi statelerine ihtiyaç duymazlar.
-
Hayatı kendiniz için daha karmaşık (veya ilginç) hale getirmek istiyorsanız, gridin stateini saklamak için başka yapılar kullanılabilir:
// Bir gridi temsil etmek için düz bir dizi kullanılabilir. // Ancak Uygulama bileşenimizin tüm diziyi izlemesi gerekmez, yalnızca "B"nin olduğu dizini izlemesi gerekir. [null, null, null, null, "B", null, null, null, null] // Bir gridi temsil etmek için 2 boyutlu diziler veya matrisler kullanılabilir, ancak bu, bu projede önerilmez: [[null, null, null], [null, "B", null], [null, null, null]] // Bir string de işe yarayabilir, ancak JS'deki stringler değişmezdir ve bu yaklaşımı elverişsiz hale getirir: "xxxxBxxxx"