{"id":24707561,"url":"https://github.com/madhusudhan1234/javascript30challenge","last_synced_at":"2026-05-17T17:07:36.116Z","repository":{"id":83232184,"uuid":"151758645","full_name":"madhusudhan1234/Javascript30challenge","owner":"madhusudhan1234","description":":fire: JavaScript 30 Day Challenge.  :seedling: C'mon it's free. Grab the course at https://JavaScript30.com ","archived":false,"fork":false,"pushed_at":"2019-10-31T16:25:34.000Z","size":45376,"stargazers_count":1,"open_issues_count":0,"forks_count":0,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-09-21T21:45:53.992Z","etag":null,"topics":["css","css3","css3-flexbox","es6","html","html5","javascript"],"latest_commit_sha":null,"homepage":"","language":"HTML","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/madhusudhan1234.png","metadata":{"files":{"readme":"readme.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2018-10-05T17:54:13.000Z","updated_at":"2019-10-31T16:25:36.000Z","dependencies_parsed_at":"2023-03-02T19:15:44.746Z","dependency_job_id":null,"html_url":"https://github.com/madhusudhan1234/Javascript30challenge","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/madhusudhan1234/Javascript30challenge","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/madhusudhan1234%2FJavascript30challenge","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/madhusudhan1234%2FJavascript30challenge/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/madhusudhan1234%2FJavascript30challenge/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/madhusudhan1234%2FJavascript30challenge/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/madhusudhan1234","download_url":"https://codeload.github.com/madhusudhan1234/Javascript30challenge/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/madhusudhan1234%2FJavascript30challenge/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":33147340,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-17T09:28:26.183Z","status":"ssl_error","status_checked_at":"2026-05-17T09:27:52.702Z","response_time":107,"last_error":"SSL_connect returned=1 errno=0 peeraddr=140.82.121.6:443 state=error: unexpected eof while reading","robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":false,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["css","css3","css3-flexbox","es6","html","html5","javascript"],"created_at":"2025-01-27T06:17:27.323Z","updated_at":"2026-05-17T17:07:36.110Z","avatar_url":"https://github.com/madhusudhan1234.png","language":"HTML","funding_links":[],"categories":[],"sub_categories":[],"readme":"![](https://javascript30.com/images/JS3-social-share.png)\n\n# JavaScript30\n\nStarter Files + Completed solutions for the JavaScript 30 Day Challenge.\n\nGrab the course at [https://JavaScript30.com](https://JavaScript30.com)\n\n## What I learned in Day 1\n\n- I learned about pull request template ```PULL_REQUEST_TEMPLATE.md``` is right here\n- audio ```play()``` method, how audio play works\n- transitionend event and it's types\n- audio tags and it's properties\n\n\n## What I learned in Day 2\n\n- transform from origin used css ```transform-origin: 100%;```\n- transition-timing-function property of css\n- And css transitions\n- Digital watch making by using css and js\n\n\n## What I learned in Day 3\n\n- I got the idea about ```this.dataset``` which is the pretty object of html data property\n- Css variable value can be changed from Javascript\n- Get idea about the control inputs and color switcher input\n- Got some Insights about nodeList and array's properties in js\n\n## What I learned in Day 4\n\n- Learned about sort function and reduce function properly\n- Learned about reduce function which can reduce object too.\n\n## What I learned in Day 5\n\n- Learned about the flex \n- Also start to implement the same design in my website, PR is here ```https://github.com/madhusudhan1234/madhusudhan1234.github.io/pull/5```\n\n## What I learned in Day 6\n\n- Learned about the innerHTML property\n- Learned about regular expression match and replace \n\n## What I learned in Day 7\n\n- Learned about the some, every function\n- And more clear about the splice and slice function\n\n## What I learned in Day 8\n\n- Learned about the Html Canvas, and drawing in 2d\n- Learned about how to draw line and several property and methods of the canvas context\n\n## What I learned in Day 9\n\n- Learned about the console tricks and tips\n- Grouping of the console\n- Timing of the data fetch is also learned\n\n## What I learned in Day 10\n\n- This one is tricky one challenge, and checked start to finish checkbox found\n- Multiple checkbox checked by pressing shiftkey very useful \n\n## What I learned in Day 11\n\n- Learned to play the video using Javscript\n- Play pause and progress bar is learned\n- play and pause method is nice \n\n## What I learned in Day 12\n\n- Learned about cornify library and it is very awesome\n- Splice from start is also learned\n\n## What I learned in Day 13\n\n- Learned about sliding image on scroll, Nice effect of sliding image\n- Learned actual implementation of the debounce function \n- To get height of current position dom element window.scrollY + window.innerHeight\n\n## What I learned in Day 14\n\n- Learned about the copy vs reference\n- Learned about how copy can be done by using spread operator, spread operator is yet to coe for object in js.\n- Object.assign can not work in nested child elements\n\n## What I learned in Day 15\n\n- Learned about the localStorage\n- setValue in localStorage and get value from localStorage is learned\n\n## What I learned in Day 16\n\n- Learned about the offsetX and offsetY to get the mouse cursor position of the screen.\n\n## What I learned in Day 17\n\n- Learned about the How we can use the regular expression inside the sort function\n- Sorted list without caring a, an and the is can be done such a nice way","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmadhusudhan1234%2Fjavascript30challenge","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fmadhusudhan1234%2Fjavascript30challenge","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fmadhusudhan1234%2Fjavascript30challenge/lists"}