Difference between revisions of "Javascript Resources"
m |
|||
(6 intermediate revisions by the same user not shown) | |||
Line 1: | Line 1: | ||
==Why JavaScript? | ==Why JavaScript?== | ||
JavaScript is my recommended first language for aspiring programmers---not Python. The reason is that JavaScript is built into every browser, so no matter where you are or what kind of computer you have, you can start playing with JavaScript. And as soon as you have learned a little, you can do neat things like interactive graphics, extend Google's Chrome Browser, and so on. | JavaScript is my recommended first language for aspiring programmers---not Python. The reason is that JavaScript is built into every browser, so no matter where you are or what kind of computer you have, you can start playing with JavaScript. And as soon as you have learned a little, you can do neat things like interactive graphics, extend Google's Chrome Browser, and so on. | ||
Line 10: | Line 10: | ||
If you are solely interested in graphics, you might also look at [https://processing.org/tutorials/ Processing]. There are some really good [https://processing.org/books/ processing books] as well. | If you are solely interested in graphics, you might also look at [https://processing.org/tutorials/ Processing]. There are some really good [https://processing.org/books/ processing books] as well. | ||
And if you are looking for playing around with hardware, you might check out [[CircuitPython]]. | |||
==Recommended JavaScript Tutorials== | ==Recommended JavaScript Tutorials== | ||
The most orderly way to learn JavaScript is to simply read the manual on the Mozilla website. There are also tutorials: | |||
* https://developer.mozilla.org/en-US/docs/Web/JavaScript | |||
If you've seen JavaScript but you've never formally learned it, I recommend: | |||
* https://developer.mozilla.org/en-US/docs/Web/JavaScript/A_re-introduction_to_JavaScript | |||
There are many online JavaScript tutorials. These all allow you to try out things in your browser directly, and don't require that you create accounts: | There are many online JavaScript tutorials. These all allow you to try out things in your browser directly, and don't require that you create accounts: | ||
Line 17: | Line 25: | ||
* https://www.learn-js.org/ | * https://www.learn-js.org/ | ||
* https://javascript.info/ - The Modern JavaScript Tutorial | * https://javascript.info/ - The Modern JavaScript Tutorial | ||
Untrusted is a game played in JavaScript. It's designed to teach secure coding and hacking skills. You win the game by modifying programs. | |||
* https://alexnisnevich.github.io/untrusted/ | |||
==More Advanced JavaScript== | ==More Advanced JavaScript== | ||
Line 33: | Line 44: | ||
==Cool Technologies== | ==Cool Technologies== | ||
===Time Lines=== | ===Time Lines=== | ||
* https://timeline.knightlab.com/ - Open source JavaScript timelines | * https://timeline.knightlab.com/ - Open source JavaScript timelines | ||
===Tables=== | |||
=== | * [https://datatables.net Datatables] (This is the one that I'm using) | ||
* [https://datatables.net Datatables] | |||
** [https://datatables.net/extensions/scroller/examples/initialisation/server-side_processing.html 5,000,000 rows server-side] | ** [https://datatables.net/extensions/scroller/examples/initialisation/server-side_processing.html 5,000,000 rows server-side] | ||
** [https://datatables.net/extensions/scroller/examples/initialisation/api_scrolling.html Example showing jump to row 1000] | ** [https://datatables.net/extensions/scroller/examples/initialisation/api_scrolling.html Example showing jump to row 1000] | ||
* [http://tabulator.info Tabulator] | * [http://tabulator.info Tabulator] (This is a little easier to use) | ||
* https://www.sitepoint.com/12-amazing-jquery-tables/ | |||
* https://www.jqueryscript.net/table/ | |||
===Random Numbers=== | ===Random Numbers=== |
Latest revision as of 06:59, 18 September 2020
Why JavaScript?
JavaScript is my recommended first language for aspiring programmers---not Python. The reason is that JavaScript is built into every browser, so no matter where you are or what kind of computer you have, you can start playing with JavaScript. And as soon as you have learned a little, you can do neat things like interactive graphics, extend Google's Chrome Browser, and so on.
Core skills you want to learn:
- JavaScript
- HTML --- the language in which pages are authored
- CSS - Cascading Style Sheets. How to make web pages pretty.
- JQuery - How to use JavaScript effectively.
If you are solely interested in graphics, you might also look at Processing. There are some really good processing books as well.
And if you are looking for playing around with hardware, you might check out CircuitPython.
Recommended JavaScript Tutorials
The most orderly way to learn JavaScript is to simply read the manual on the Mozilla website. There are also tutorials:
If you've seen JavaScript but you've never formally learned it, I recommend:
There are many online JavaScript tutorials. These all allow you to try out things in your browser directly, and don't require that you create accounts:
- https://www.w3schools.com/js/
- https://www.learn-js.org/
- https://javascript.info/ - The Modern JavaScript Tutorial
Untrusted is a game played in JavaScript. It's designed to teach secure coding and hacking skills. You win the game by modifying programs.
More Advanced JavaScript
Online playpens
Online resources:
Books
Selected Blog Posts and Fun Tools
Cool Technologies
Time Lines
- https://timeline.knightlab.com/ - Open source JavaScript timelines
Tables
- Datatables (This is the one that I'm using)
- Tabulator (This is a little easier to use)
- https://www.sitepoint.com/12-amazing-jquery-tables/
- https://www.jqueryscript.net/table/
Random Numbers
Especially Laplace distributions...
- http://jsfiddle.net/KkDVr/2/ - Noise generation, showing on a canvas
- http://jsfiddle.net/Xotic750/DXXhs/ — Gaussian distribution
Probability distributions for JavaScript:
- http://statisticsblog.com/probability-distributions/#laplace
- https://www.npmjs.com/package/probability-distributions
- https://github.com/Mattasher/probability-distributions
Comments on how random numbers work in web browsers:
- https://bocoup.com/blog/random-numbers
- http://simjs.com/random.html
- http://mathjs.org/docs/reference/functions/random.html
- https://www.filosophy.org/post/35/normaldistributed_random_values_in_javascript_using_the_ziggurat_algorithm/
Graphing: