Difference between revisions of "JavaScript"

from HTYP, the free directory anyone can edit if they can prove to me that they're not a spambot
Jump to navigation Jump to search
(debugging tools; minor update)
 
(4 intermediate revisions by the same user not shown)
Line 3: Line 3:
 
In order to use JavaScript to control a web browser, you need to know about the [[Document Object Model]] (DOM) of that browser. Most modern browsers conform at least loosely to a standard DOM, but it is always a good idea to test the particular functions you are using in a variety of browsers. (Pre-packaged code is often written to automatically detect browser type/version and use the appropriate identifiers.)
 
In order to use JavaScript to control a web browser, you need to know about the [[Document Object Model]] (DOM) of that browser. Most modern browsers conform at least loosely to a standard DOM, but it is always a good idea to test the particular functions you are using in a variety of browsers. (Pre-packaged code is often written to automatically detect browser type/version and use the appropriate identifiers.)
  
* '''Debugging tools''': [http://jslint.com/ JSLint], <angular/>, JSTestDriver, jstest, and SinonJS
+
* '''Debugging tools''': [http://jslint.com/ JSLint], <angular/>, JSTestDriver, jstest, SinonJS, IntelliJ IDEA ([[integrated development environment|IDE]])
 +
 
 
==Issues==
 
==Issues==
 
As of 2006, [[FireFox]]'s DOM appeared to have a couple of bugs which only show up in [[Linux]]:
 
As of 2006, [[FireFox]]'s DOM appeared to have a couple of bugs which only show up in [[Linux]]:
Line 11: Line 12:
 
These bugs have probably been fixed in the intervening 6 years, but I haven't tested them since then.
 
These bugs have probably been fixed in the intervening 6 years, but I haven't tested them since then.
 
==Links==
 
==Links==
* [http://developer.mozilla.org/en/docs/JavaScript Mozilla developer center]: JS reference, guide, related info
+
===General===
 +
* {{wikipedia}}
 +
===Mozilla Developer Center===
 +
* [http://developer.mozilla.org/en/docs/JavaScript JavaScript]
 +
** [https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference JavaScript Reference]
 
* '''Document Object Model''':
 
* '''Document Object Model''':
 
** [http://developer.mozilla.org/en/docs/DOM Mozilla developer center]: Gecko DOM reference, related info
 
** [http://developer.mozilla.org/en/docs/DOM Mozilla developer center]: Gecko DOM reference, related info
 +
*** [https://developer.mozilla.org/en-US/docs/Web/API/HTMLElement HTMLElement] - doesn't list standard attachable events
 +
* '''Components''':
 +
** '''XMLHttpRequest''':
 +
*** [https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest reference]
 +
**** [https://developer.mozilla.org/en/docs/Web/API/XMLHttpRequest/Using_XMLHttpRequest tutorial]
 +
===Tutorials / How-to===
 +
* HTMLDog:
 +
** [http://htmldog.com/guides/javascript/advanced/creatingelements/ Creating Elements]
 +
** [http://htmldog.com/guides/javascript/beginner/makingstuffhappen/ Making Stuff Happen]
 +
* [http://jsforcats.com/ JavaScript for Cats]
 +
* [http://nodeschool.io/ NodeCchool] "Open source workshops that teach web software skills. Do them on your own or at a workshop nearby."

Latest revision as of 01:40, 18 December 2017

Computing: Software: Programming: JavaScript

This page is a seed article. You can help HTYP water it: make a request to expand a given page and/or donate to help give us more writing-hours!

Notes

In order to use JavaScript to control a web browser, you need to know about the Document Object Model (DOM) of that browser. Most modern browsers conform at least loosely to a standard DOM, but it is always a good idea to test the particular functions you are using in a variety of browsers. (Pre-packaged code is often written to automatically detect browser type/version and use the appropriate identifiers.)

  • Debugging tools: JSLint, <angular/>, JSTestDriver, jstest, SinonJS, IntelliJ IDEA (IDE)

Issues

As of 2006, FireFox's DOM appeared to have a couple of bugs which only show up in Linux:

  • Popup windows cannot be made to be "always on top" (window.open() with parameter "dependent=1")
  • The onblur event is triggered by moving or resizing the window, as well as when the window loses focus

These bugs have probably been fixed in the intervening 6 years, but I haven't tested them since then.

Links

General

Mozilla Developer Center

Tutorials / How-to