aboutsummaryrefslogtreecommitdiff
path: root/files/he
diff options
context:
space:
mode:
Diffstat (limited to 'files/he')
-rw-r--r--files/he/_redirects.txt59
-rw-r--r--files/he/_wikihistory.json1124
-rw-r--r--files/he/conflicting/web/guide/index.html14
-rw-r--r--files/he/glossary/array/index.html43
-rw-r--r--files/he/glossary/css/index.html50
-rw-r--r--files/he/glossary/html/index.html46
-rw-r--r--files/he/glossary/index.html48
-rw-r--r--files/he/learn/css/index.html64
-rw-r--r--files/he/learn/forms/index.html73
-rw-r--r--files/he/learn/getting_started_with_the_web/index.html61
-rw-r--r--files/he/learn/html/howto/index.html142
-rw-r--r--files/he/learn/html/index.html58
-rw-r--r--files/he/learn/html/introduction_to_html/index.html56
-rw-r--r--files/he/learn/html/tables/index.html35
-rw-r--r--files/he/learn/index.html98
-rw-r--r--files/he/learn/javascript/asynchronous/concepts/index.html203
-rw-r--r--files/he/learn/javascript/asynchronous/index.html43
-rw-r--r--files/he/learn/javascript/asynchronous/introducing/index.html281
-rw-r--r--files/he/learn/javascript/asynchronous/promises/index.html589
-rw-r--r--files/he/learn/javascript/asynchronous/timeouts_and_intervals/index.html651
-rw-r--r--files/he/learn/javascript/building_blocks/build_your_own_function/index.html247
-rw-r--r--files/he/learn/javascript/building_blocks/conditionals/index.html790
-rw-r--r--files/he/learn/javascript/building_blocks/events/index.html588
-rw-r--r--files/he/learn/javascript/building_blocks/functions/index.html386
-rw-r--r--files/he/learn/javascript/building_blocks/index.html51
-rw-r--r--files/he/learn/javascript/building_blocks/looping_code/index.html931
-rw-r--r--files/he/learn/javascript/building_blocks/return_values/index.html180
-rw-r--r--files/he/learn/javascript/first_steps/a_first_splash/index.html634
-rw-r--r--files/he/learn/javascript/first_steps/arrays/index.html564
-rw-r--r--files/he/learn/javascript/first_steps/index.html64
-rw-r--r--files/he/learn/javascript/first_steps/math/index.html427
-rw-r--r--files/he/learn/javascript/first_steps/silly_story_generator/index.html139
-rw-r--r--files/he/learn/javascript/first_steps/strings/index.html172
-rw-r--r--files/he/learn/javascript/first_steps/useful_string_methods/index.html673
-rw-r--r--files/he/learn/javascript/first_steps/variables/index.html333
-rw-r--r--files/he/learn/javascript/first_steps/what_is_javascript/index.html447
-rw-r--r--files/he/learn/javascript/first_steps/what_went_wrong/index.html251
-rw-r--r--files/he/learn/javascript/index.html83
-rw-r--r--files/he/learn/javascript/objects/adding_bouncing_balls_features/index.html214
-rw-r--r--files/he/learn/javascript/objects/basics/index.html257
-rw-r--r--files/he/learn/javascript/objects/index.html54
-rw-r--r--files/he/learn/javascript/objects/inheritance/index.html437
-rw-r--r--files/he/learn/javascript/objects/json/index.html346
-rw-r--r--files/he/learn/javascript/objects/object-oriented_js/index.html275
-rw-r--r--files/he/learn/javascript/objects/object_prototypes/index.html283
-rw-r--r--files/he/learn/server-side/express_nodejs/index.html64
-rw-r--r--files/he/learn/server-side/express_nodejs/introduction/index.html542
-rw-r--r--files/he/learn/server-side/index.html50
-rw-r--r--files/he/mdn/contribute/getting_started/index.html131
-rw-r--r--files/he/mdn/contribute/howto/index.html18
-rw-r--r--files/he/mdn/contribute/index.html66
-rw-r--r--files/he/mdn/index.html18
-rw-r--r--files/he/mozilla/add-ons/index.html104
-rw-r--r--files/he/mozilla/add-ons/webextensions/anatomy_of_a_webextension/index.html144
-rw-r--r--files/he/mozilla/add-ons/webextensions/api/alarms/index.html60
-rw-r--r--files/he/mozilla/add-ons/webextensions/api/browseraction/index.html124
-rw-r--r--files/he/mozilla/add-ons/webextensions/api/index.html55
-rw-r--r--files/he/mozilla/add-ons/webextensions/api/storage/index.html102
-rw-r--r--files/he/mozilla/add-ons/webextensions/browser_support_for_javascript_apis/index.html24
-rw-r--r--files/he/mozilla/add-ons/webextensions/content_scripts/index.html493
-rw-r--r--files/he/mozilla/add-ons/webextensions/index.html147
-rw-r--r--files/he/mozilla/add-ons/webextensions/manifest.json/background/index.html116
-rw-r--r--files/he/mozilla/add-ons/webextensions/manifest.json/index.html125
-rw-r--r--files/he/mozilla/add-ons/webextensions/manifest.json/permissions/index.html199
-rw-r--r--files/he/mozilla/add-ons/webextensions/modify_a_web_page/index.html252
-rw-r--r--files/he/mozilla/add-ons/webextensions/tips/index.html58
-rw-r--r--files/he/mozilla/add-ons/webextensions/user_interface/browser_action/index.html51
-rw-r--r--files/he/mozilla/add-ons/webextensions/user_interface/index.html97
-rw-r--r--files/he/mozilla/add-ons/webextensions/what_are_webextensions/index.html59
-rw-r--r--files/he/mozilla/add-ons/webextensions/your_first_webextension/index.html153
-rw-r--r--files/he/mozilla/add-ons/webextensions/your_second_webextension/index.html458
-rw-r--r--files/he/mozilla/index.html10
-rw-r--r--files/he/orphaned/he/index.html15
-rw-r--r--files/he/orphaned/hebrew_localization/index.html8
-rw-r--r--files/he/orphaned/mdn/community/index.html54
-rw-r--r--files/he/orphaned/mdn/contribute/howto/create_an_mdn_account/index.html43
-rw-r--r--files/he/orphaned/web/hypertext_markup_language/index.html91
-rw-r--r--files/he/orphaned/מושגים/index.html11
-rw-r--r--files/he/web/api/console/index.html294
-rw-r--r--files/he/web/api/console/log/index.html39
-rw-r--r--files/he/web/api/document/index.html488
-rw-r--r--files/he/web/api/document/write/index.html82
-rw-r--r--files/he/web/api/document_object_model/index.html14
-rw-r--r--files/he/web/api/domstring/index.html50
-rw-r--r--files/he/web/api/element/index.html331
-rw-r--r--files/he/web/api/geolocation/index.html109
-rw-r--r--files/he/web/api/geolocation_api/index.html251
-rw-r--r--files/he/web/api/index.html38
-rw-r--r--files/he/web/api/indexeddb_api/browser_storage_limits_and_eviction_criteria/index.html141
-rw-r--r--files/he/web/api/indexeddb_api/index.html165
-rw-r--r--files/he/web/api/storage/clear/index.html52
-rw-r--r--files/he/web/api/storage/getitem/index.html75
-rw-r--r--files/he/web/api/storage/index.html107
-rw-r--r--files/he/web/api/storage/key/index.html55
-rw-r--r--files/he/web/api/storage/length/index.html51
-rw-r--r--files/he/web/api/storage/removeitem/index.html66
-rw-r--r--files/he/web/api/storage/setitem/index.html69
-rw-r--r--files/he/web/api/web_storage_api/index.html111
-rw-r--r--files/he/web/api/window/alert/index.html70
-rw-r--r--files/he/web/api/window/confirm/index.html70
-rw-r--r--files/he/web/api/window/index.html509
-rw-r--r--files/he/web/api/window/localstorage/index.html82
-rw-r--r--files/he/web/api/window/prompt/index.html90
-rw-r--r--files/he/web/api/xmlhttprequest/index.html172
-rw-r--r--files/he/web/css/index.html97
-rw-r--r--files/he/web/css/position/index.html274
-rw-r--r--files/he/web/guide/html/html5/index.html177
-rw-r--r--files/he/web/guide/index.html62
-rw-r--r--files/he/web/guide/localizations_and_character_encodings/index.html62
-rw-r--r--files/he/web/guide/performance/index.html23
-rw-r--r--files/he/web/html/element/a/index.html90
-rw-r--r--files/he/web/html/element/address/index.html77
-rw-r--r--files/he/web/html/element/applet/index.html37
-rw-r--r--files/he/web/html/element/article/index.html102
-rw-r--r--files/he/web/html/element/aside/index.html75
-rw-r--r--files/he/web/html/element/b/index.html68
-rw-r--r--files/he/web/html/element/bdi/index.html60
-rw-r--r--files/he/web/html/element/br/index.html62
-rw-r--r--files/he/web/html/element/canvas/index.html70
-rw-r--r--files/he/web/html/element/center/index.html104
-rw-r--r--files/he/web/html/element/cite/index.html52
-rw-r--r--files/he/web/html/element/del/index.html64
-rw-r--r--files/he/web/html/element/em/index.html64
-rw-r--r--files/he/web/html/element/figcaption/index.html67
-rw-r--r--files/he/web/html/element/figure/index.html112
-rw-r--r--files/he/web/html/element/font/index.html38
-rw-r--r--files/he/web/html/element/footer/index.html62
-rw-r--r--files/he/web/html/element/head/index.html68
-rw-r--r--files/he/web/html/element/header/index.html72
-rw-r--r--files/he/web/html/element/heading_elements/index.html77
-rw-r--r--files/he/web/html/element/hgroup/index.html69
-rw-r--r--files/he/web/html/element/hr/index.html74
-rw-r--r--files/he/web/html/element/html/index.html59
-rw-r--r--files/he/web/html/element/index.html105
-rw-r--r--files/he/web/html/element/ins/index.html58
-rw-r--r--files/he/web/html/element/main/index.html77
-rw-r--r--files/he/web/html/element/mark/index.html86
-rw-r--r--files/he/web/html/element/nav/index.html70
-rw-r--r--files/he/web/html/element/p/index.html74
-rw-r--r--files/he/web/html/element/section/index.html67
-rw-r--r--files/he/web/html/element/strong/index.html69
-rw-r--r--files/he/web/html/element/table/index.html162
-rw-r--r--files/he/web/html/element/time/index.html93
-rw-r--r--files/he/web/html/element/title/index.html61
-rw-r--r--files/he/web/html/index.html108
-rw-r--r--files/he/web/http/index.html91
-rw-r--r--files/he/web/http/status/403/index.html55
-rw-r--r--files/he/web/http/status/index.html197
-rw-r--r--files/he/web/index.html121
-rw-r--r--files/he/web/javascript/guide/index.html125
-rw-r--r--files/he/web/javascript/index.html97
-rw-r--r--files/he/web/javascript/reference/errors/index.html31
-rw-r--r--files/he/web/javascript/reference/functions/default_parameters/index.html216
-rw-r--r--files/he/web/javascript/reference/functions/index.html596
-rw-r--r--files/he/web/javascript/reference/global_objects/array/from/index.html243
-rw-r--r--files/he/web/javascript/reference/global_objects/array/includes/index.html169
-rw-r--r--files/he/web/javascript/reference/global_objects/array/index.html485
-rw-r--r--files/he/web/javascript/reference/global_objects/array/unshift/index.html94
-rw-r--r--files/he/web/javascript/reference/global_objects/index.html183
-rw-r--r--files/he/web/javascript/reference/global_objects/object/assign/index.html272
-rw-r--r--files/he/web/javascript/reference/global_objects/object/index.html184
-rw-r--r--files/he/web/javascript/reference/global_objects/promise/index.html244
-rw-r--r--files/he/web/javascript/reference/global_objects/string/index.html314
-rw-r--r--files/he/web/javascript/reference/index.html58
-rw-r--r--files/he/web/javascript/reference/operators/destructuring_assignment/index.html416
-rw-r--r--files/he/web/javascript/reference/operators/index.html289
-rw-r--r--files/he/web/javascript/reference/operators/operator_precedence/index.html330
-rw-r--r--files/he/web/javascript/reference/statements/const/index.html133
-rw-r--r--files/he/web/javascript/reference/statements/for...of/index.html269
-rw-r--r--files/he/web/javascript/reference/statements/function_star_/index.html212
-rw-r--r--files/he/web/javascript/reference/statements/index.html148
-rw-r--r--files/he/web/javascript/reference/statements/return/index.html151
-rw-r--r--files/he/web/javascript/reference/statements/var/index.html171
173 files changed, 0 insertions, 29329 deletions
diff --git a/files/he/_redirects.txt b/files/he/_redirects.txt
deleted file mode 100644
index e5458ad700..0000000000
--- a/files/he/_redirects.txt
+++ /dev/null
@@ -1,59 +0,0 @@
-# FROM-URL TO-URL
-/he/docs/DOM /he/docs/Web/API/Document_Object_Model
-/he/docs/Glossary/מערך /he/docs/Glossary/array
-/he/docs/HTML /he/docs/Web/HTML
-/he/docs/HTML/Element /he/docs/Web/HTML/Element
-/he/docs/HTML/Element/Heading_Elements /he/docs/Web/HTML/Element/Heading_Elements
-/he/docs/HTML/Element/a /he/docs/Web/HTML/Element/a
-/he/docs/HTML/Element/address /he/docs/Web/HTML/Element/address
-/he/docs/HTML/Element/applet /he/docs/Web/HTML/Element/applet
-/he/docs/HTML/Element/article /he/docs/Web/HTML/Element/article
-/he/docs/HTML/Element/aside /he/docs/Web/HTML/Element/aside
-/he/docs/HTML/Element/b /he/docs/Web/HTML/Element/b
-/he/docs/HTML/Element/bdi /he/docs/Web/HTML/Element/bdi
-/he/docs/HTML/Element/br /he/docs/Web/HTML/Element/br
-/he/docs/HTML/Element/canvas /he/docs/Web/HTML/Element/canvas
-/he/docs/HTML/Element/center /he/docs/Web/HTML/Element/center
-/he/docs/HTML/Element/cite /he/docs/Web/HTML/Element/cite
-/he/docs/HTML/Element/del /he/docs/Web/HTML/Element/del
-/he/docs/HTML/Element/em /he/docs/Web/HTML/Element/em
-/he/docs/HTML/Element/figcaption /he/docs/Web/HTML/Element/figcaption
-/he/docs/HTML/Element/figure /he/docs/Web/HTML/Element/figure
-/he/docs/HTML/Element/font /he/docs/Web/HTML/Element/font
-/he/docs/HTML/Element/footer /he/docs/Web/HTML/Element/footer
-/he/docs/HTML/Element/head /he/docs/Web/HTML/Element/head
-/he/docs/HTML/Element/header /he/docs/Web/HTML/Element/header
-/he/docs/HTML/Element/hgroup /he/docs/Web/HTML/Element/hgroup
-/he/docs/HTML/Element/hr /he/docs/Web/HTML/Element/hr
-/he/docs/HTML/Element/html /he/docs/Web/HTML/Element/html
-/he/docs/HTML/Element/ins /he/docs/Web/HTML/Element/ins
-/he/docs/HTML/Element/main /he/docs/Web/HTML/Element/main
-/he/docs/HTML/Element/mark /he/docs/Web/HTML/Element/mark
-/he/docs/HTML/Element/nav /he/docs/Web/HTML/Element/nav
-/he/docs/HTML/Element/p /he/docs/Web/HTML/Element/p
-/he/docs/HTML/Element/section /he/docs/Web/HTML/Element/section
-/he/docs/HTML/Element/strong /he/docs/Web/HTML/Element/strong
-/he/docs/HTML/Element/table /he/docs/Web/HTML/Element/table
-/he/docs/HTML/Element/time /he/docs/Web/HTML/Element/time
-/he/docs/HTML/Element/title /he/docs/Web/HTML/Element/title
-/he/docs/Hebrew_Localization /he/docs/orphaned/Hebrew_Localization
-/he/docs/JavaScript /he/docs/Web/JavaScript
-/he/docs/Learn/HTML/טבלאות /he/docs/Learn/HTML/Tables
-/he/docs/Learn/HTML/טפסים /he/docs/Learn/Forms
-/he/docs/Learn/HTML/מבוא_לשפת_HTML /he/docs/Learn/HTML/Introduction_to_HTML
-/he/docs/Learn/HTML/פתרון_בעיות /he/docs/Learn/HTML/Howto
-/he/docs/Learn/JavaScript/Building_blocks/תנאים /he/docs/Learn/JavaScript/Building_blocks/conditionals
-/he/docs/MDN/Community /he/docs/orphaned/MDN/Community
-/he/docs/MDN/Contribute/Howto/Create_an_MDN_account /he/docs/orphaned/MDN/Contribute/Howto/Create_an_MDN_account
-/he/docs/MDN/Getting_started /he/docs/MDN/Contribute/Getting_started
-/he/docs/Mozilla/Add-ons/WebExtensions/manifest.json/הרשאות /he/docs/Mozilla/Add-ons/WebExtensions/manifest.json/permissions
-/he/docs/Mozilla/Add-ons/WebExtensions/טיפום /he/docs/Mozilla/Add-ons/WebExtensions/Tips
-/he/docs/Mozilla_MathML_Project/Start-redirect-1 /he/docs/Mozilla_MathML_Project/Start
-/he/docs/Web/API/Geolocation/ממשק_שירותי_מיקום /he/docs/Web/API/Geolocation_API
-/he/docs/Web/Guide/HTML /he/docs/Learn/HTML
-/he/docs/Web/Hypertext_Markup_Language /he/docs/orphaned/Web/Hypertext_Markup_Language
-/he/docs/Web/JavaScript/Reference/Methods_Index /he/docs/Web/JavaScript/Reference
-/he/docs/Web_Development /he/docs/conflicting/Web/Guide
-/he/docs/en /en-US/
-/he/docs/he /he/docs/orphaned/he
-/he/docs/מושגים /he/docs/orphaned/מושגים
diff --git a/files/he/_wikihistory.json b/files/he/_wikihistory.json
deleted file mode 100644
index 39d0314950..0000000000
--- a/files/he/_wikihistory.json
+++ /dev/null
@@ -1,1124 +0,0 @@
-{
- "Glossary": {
- "modified": "2020-10-07T11:09:57.316Z",
- "contributors": [
- "peterbe",
- "chv",
- "SphinxKnight",
- "wbamberg",
- "Sheppy"
- ]
- },
- "Glossary/CSS": {
- "modified": "2019-03-18T21:25:53.823Z",
- "contributors": [
- "haim"
- ]
- },
- "Glossary/HTML": {
- "modified": "2020-10-01T06:50:13.204Z",
- "contributors": [
- "chv"
- ]
- },
- "Learn": {
- "modified": "2020-07-16T22:43:41.705Z",
- "contributors": [
- "meirlamdan",
- "SphinxKnight",
- "ItzikDabush",
- "eternalStudent"
- ]
- },
- "Learn/CSS": {
- "modified": "2020-07-16T22:25:33.951Z",
- "contributors": [
- "TornadoIDS"
- ]
- },
- "Learn/Getting_started_with_the_web": {
- "modified": "2020-07-16T22:33:52.646Z",
- "contributors": [
- "ItzikDabush",
- "fabio.rahamim",
- "chrisdavidmills"
- ]
- },
- "Learn/HTML": {
- "modified": "2020-07-16T22:22:17.538Z",
- "contributors": [
- "RafeyIqbalRahman"
- ]
- },
- "Learn/JavaScript": {
- "modified": "2020-07-16T22:29:39.084Z",
- "contributors": [
- "ItzikDabush",
- "haim"
- ]
- },
- "Learn/JavaScript/Asynchronous": {
- "modified": "2020-07-16T22:33:13.385Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/Asynchronous/Concepts": {
- "modified": "2020-07-16T22:33:28.065Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/Asynchronous/Introducing": {
- "modified": "2020-10-12T10:07:34.325Z",
- "contributors": [
- "JonyCode",
- "YOEL311",
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/Asynchronous/Promises": {
- "modified": "2020-07-16T22:33:23.960Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/Asynchronous/Timeouts_and_intervals": {
- "modified": "2020-07-16T22:33:20.557Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/Building_blocks": {
- "modified": "2020-07-16T22:31:08.087Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/Building_blocks/Build_your_own_function": {
- "modified": "2020-07-19T21:11:05.221Z",
- "contributors": [
- "meirlamdan",
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/Building_blocks/Events": {
- "modified": "2020-07-16T22:31:38.515Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/Building_blocks/Functions": {
- "modified": "2020-07-19T20:25:49.052Z",
- "contributors": [
- "meirlamdan",
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/Building_blocks/Looping_code": {
- "modified": "2020-07-16T22:31:19.721Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/Building_blocks/Return_values": {
- "modified": "2020-07-16T22:31:33.541Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/First_steps": {
- "modified": "2020-07-16T22:29:50.868Z",
- "contributors": [
- "ItzikDabush",
- "haim"
- ]
- },
- "Learn/JavaScript/First_steps/A_first_splash": {
- "modified": "2020-07-16T22:30:18.220Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/First_steps/Arrays": {
- "modified": "2020-07-16T22:30:54.818Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/First_steps/Math": {
- "modified": "2020-07-16T22:30:25.401Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/First_steps/Silly_story_generator": {
- "modified": "2020-07-16T22:31:01.708Z",
- "contributors": [
- "meirlamdan",
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/First_steps/Strings": {
- "modified": "2020-07-16T22:30:39.658Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/First_steps/Useful_string_methods": {
- "modified": "2020-07-16T22:30:47.396Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/First_steps/Variables": {
- "modified": "2020-07-16T22:29:59.363Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/First_steps/What_is_JavaScript": {
- "modified": "2020-07-16T22:30:07.974Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/First_steps/What_went_wrong": {
- "modified": "2020-07-16T22:30:33.417Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/Objects": {
- "modified": "2020-07-16T22:31:49.925Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/Objects/Adding_bouncing_balls_features": {
- "modified": "2020-09-13T05:52:52.288Z",
- "contributors": [
- "770camera"
- ]
- },
- "Learn/JavaScript/Objects/Basics": {
- "modified": "2020-08-06T11:51:11.213Z",
- "contributors": [
- "meirlamdan",
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/Objects/Inheritance": {
- "modified": "2020-07-16T22:32:14.216Z",
- "contributors": [
- "Sheptus",
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/Objects/JSON": {
- "modified": "2020-07-16T22:32:25.717Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/Objects/Object-oriented_JS": {
- "modified": "2020-08-06T15:32:42.627Z",
- "contributors": [
- "meirlamdan",
- "ItzikDabush"
- ]
- },
- "Learn/JavaScript/Objects/Object_prototypes": {
- "modified": "2020-07-16T22:32:20.533Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "Learn/Server-side": {
- "modified": "2020-07-16T22:35:57.571Z",
- "contributors": [
- "meirlamdan"
- ]
- },
- "Learn/Server-side/Express_Nodejs": {
- "modified": "2020-07-16T22:37:52.517Z",
- "contributors": [
- "meirlamdan"
- ]
- },
- "Learn/Server-side/Express_Nodejs/Introduction": {
- "modified": "2020-07-16T22:38:10.281Z",
- "contributors": [
- "meirlamdan"
- ]
- },
- "MDN": {
- "modified": "2019-03-23T22:50:58.746Z",
- "contributors": [
- "wbamberg",
- "Jeremie",
- "eternalStudent"
- ]
- },
- "MDN/Contribute": {
- "modified": "2019-03-23T22:50:52.644Z",
- "contributors": [
- "wbamberg",
- "eternalStudent"
- ]
- },
- "MDN/Contribute/Getting_started": {
- "modified": "2020-09-30T17:11:31.030Z",
- "contributors": [
- "chrisdavidmills",
- "ramiy",
- "dafbyte",
- "wbamberg",
- "idoroiengel",
- "eternalStudent"
- ]
- },
- "MDN/Contribute/Howto": {
- "modified": "2020-12-14T11:30:12.436Z",
- "contributors": [
- "ExE-Boss"
- ]
- },
- "Mozilla": {
- "modified": "2019-03-23T23:27:26.144Z",
- "contributors": [
- "Sheppy"
- ]
- },
- "Mozilla/Add-ons": {
- "modified": "2019-09-09T13:08:10.211Z",
- "contributors": [
- "SphinxKnight",
- "devinea2"
- ]
- },
- "Mozilla/Add-ons/WebExtensions": {
- "modified": "2019-03-18T21:01:33.675Z",
- "contributors": [
- "dafbyte"
- ]
- },
- "Mozilla/Add-ons/WebExtensions/API": {
- "modified": "2020-06-25T04:51:40.197Z",
- "contributors": [
- "AmitYaron",
- "colbyhoward"
- ]
- },
- "Mozilla/Add-ons/WebExtensions/API/alarms": {
- "modified": "2020-10-15T22:22:26.434Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "Mozilla/Add-ons/WebExtensions/API/browserAction": {
- "modified": "2020-10-15T22:30:57.985Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "Mozilla/Add-ons/WebExtensions/API/storage": {
- "modified": "2020-10-15T22:31:19.542Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "Mozilla/Add-ons/WebExtensions/Anatomy_of_a_WebExtension": {
- "modified": "2019-11-18T15:08:05.989Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "Mozilla/Add-ons/WebExtensions/Browser_support_for_JavaScript_APIs": {
- "modified": "2020-10-15T20:55:13.350Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "Mozilla/Add-ons/WebExtensions/Content_scripts": {
- "modified": "2019-08-29T10:24:19.189Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "Mozilla/Add-ons/WebExtensions/Modify_a_web_page": {
- "modified": "2020-07-03T08:40:42.413Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "Mozilla/Add-ons/WebExtensions/What_are_WebExtensions": {
- "modified": "2019-09-03T12:38:06.667Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "Mozilla/Add-ons/WebExtensions/Your_first_WebExtension": {
- "modified": "2019-08-29T10:20:28.270Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "Mozilla/Add-ons/WebExtensions/Your_second_WebExtension": {
- "modified": "2019-09-04T11:03:01.611Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "Mozilla/Add-ons/WebExtensions/manifest.json": {
- "modified": "2020-10-15T22:24:48.553Z",
- "contributors": [
- "Zearin_Galaurum"
- ]
- },
- "Mozilla/Add-ons/WebExtensions/manifest.json/background": {
- "modified": "2020-10-15T22:31:12.418Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "Mozilla/Add-ons/WebExtensions/user_interface": {
- "modified": "2020-06-25T06:33:52.755Z",
- "contributors": [
- "chrisdavidmills"
- ]
- },
- "Mozilla/Add-ons/WebExtensions/user_interface/Browser_action": {
- "modified": "2020-06-25T08:26:23.519Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "Web": {
- "modified": "2019-03-23T23:14:11.445Z",
- "contributors": [
- "dafbyte",
- "fabio.rahamim",
- "jsx",
- "Yahpay",
- "teoli"
- ]
- },
- "Web/API": {
- "modified": "2020-10-03T08:46:15.865Z",
- "contributors": [
- "amitbeck",
- "Avrhamwales",
- "teoli"
- ]
- },
- "Web/API/Console": {
- "modified": "2020-10-15T22:10:17.991Z",
- "contributors": [
- "irenesmith"
- ]
- },
- "Web/API/Console/log": {
- "modified": "2020-10-15T22:10:17.607Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Web/API/DOMString": {
- "modified": "2019-03-18T21:20:59.002Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Web/API/Document": {
- "modified": "2020-10-15T22:09:48.432Z",
- "contributors": [
- "Mlrobinson1993"
- ]
- },
- "Web/API/Document/write": {
- "modified": "2020-10-15T22:09:32.825Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Web/API/Element": {
- "modified": "2020-10-15T22:13:05.474Z",
- "contributors": [
- "chrisdavidmills"
- ]
- },
- "Web/API/Geolocation": {
- "modified": "2019-03-23T23:11:00.714Z",
- "contributors": [
- "teoli"
- ]
- },
- "Web/API/IndexedDB_API": {
- "modified": "2019-11-29T09:18:23.722Z",
- "contributors": [
- "LeonFrempong"
- ]
- },
- "Web/API/IndexedDB_API/Browser_storage_limits_and_eviction_criteria": {
- "modified": "2020-06-18T08:34:41.680Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "Web/API/Storage": {
- "modified": "2020-10-15T22:12:12.917Z",
- "contributors": [
- "gdg"
- ]
- },
- "Web/API/Storage/clear": {
- "modified": "2020-10-15T22:12:24.951Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Web/API/Storage/getItem": {
- "modified": "2020-10-15T22:12:25.257Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Web/API/Storage/key": {
- "modified": "2020-10-15T22:12:24.812Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Web/API/Storage/length": {
- "modified": "2020-10-15T22:12:25.024Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Web/API/Storage/removeItem": {
- "modified": "2020-10-15T22:12:24.848Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Web/API/Storage/setItem": {
- "modified": "2020-10-15T22:12:14.390Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Web/API/Web_Storage_API": {
- "modified": "2020-10-15T22:31:39.589Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "Web/API/Window": {
- "modified": "2020-10-15T22:10:42.230Z",
- "contributors": [
- "Sheppy"
- ]
- },
- "Web/API/Window/alert": {
- "modified": "2020-10-15T22:10:26.250Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Web/API/Window/confirm": {
- "modified": "2020-10-15T22:10:24.935Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Web/API/Window/localStorage": {
- "modified": "2020-10-15T22:22:05.160Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "Web/API/Window/prompt": {
- "modified": "2020-10-15T22:10:19.323Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Web/API/XMLHttpRequest": {
- "modified": "2020-10-15T22:12:48.713Z",
- "contributors": [
- "fscholz",
- "sideshowbarker"
- ]
- },
- "Web/CSS": {
- "modified": "2019-09-11T03:12:30.829Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/CSS/position": {
- "modified": "2020-10-15T22:08:31.453Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Web/Guide": {
- "modified": "2019-03-23T23:05:01.546Z",
- "contributors": [
- "dafbyte",
- "apoorva"
- ]
- },
- "Web/Guide/HTML/HTML5": {
- "modified": "2019-03-18T21:17:17.898Z",
- "contributors": [
- "teoli",
- "Windforce"
- ]
- },
- "Web/Guide/Localizations_and_character_encodings": {
- "modified": "2019-08-29T10:26:50.778Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "Web/Guide/Performance": {
- "modified": "2019-03-18T21:18:07.307Z",
- "contributors": [
- "dafbyte"
- ]
- },
- "Web/HTML": {
- "modified": "2020-07-29T11:39:05.510Z",
- "contributors": [
- "SphinxKnight"
- ]
- },
- "Web/HTML/Element": {
- "modified": "2019-09-09T08:09:34.183Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim",
- "teoli"
- ]
- },
- "Web/HTML/Element/Heading_Elements": {
- "modified": "2019-09-09T08:09:34.951Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/a": {
- "modified": "2019-09-09T08:09:31.251Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim",
- "teoli",
- "Inkbug"
- ]
- },
- "Web/HTML/Element/address": {
- "modified": "2019-09-09T08:09:31.552Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/applet": {
- "modified": "2019-09-09T08:09:52.174Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/article": {
- "modified": "2019-09-09T08:09:34.507Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/aside": {
- "modified": "2019-09-09T08:09:34.599Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/b": {
- "modified": "2019-09-09T08:09:33.591Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/bdi": {
- "modified": "2019-09-09T08:09:34.931Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/br": {
- "modified": "2019-09-09T08:09:31.403Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/canvas": {
- "modified": "2019-09-09T08:09:42.894Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/center": {
- "modified": "2019-09-09T08:09:31.987Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/cite": {
- "modified": "2019-09-09T08:09:41.537Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/del": {
- "modified": "2019-09-09T08:09:33.548Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/em": {
- "modified": "2019-09-09T08:09:48.199Z",
- "contributors": [
- "SphinxKnight",
- "idodana",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/figcaption": {
- "modified": "2019-09-09T08:09:36.865Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/figure": {
- "modified": "2019-09-09T08:09:45.693Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/font": {
- "modified": "2019-09-09T08:09:47.343Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/footer": {
- "modified": "2019-09-09T08:09:34.957Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/head": {
- "modified": "2019-09-09T08:09:34.037Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/header": {
- "modified": "2019-09-09T08:09:47.361Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/hgroup": {
- "modified": "2019-09-09T08:09:33.606Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/hr": {
- "modified": "2019-09-09T08:09:31.704Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/html": {
- "modified": "2019-09-09T08:09:33.860Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/ins": {
- "modified": "2019-09-09T08:09:34.404Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/main": {
- "modified": "2019-09-09T08:09:36.292Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/mark": {
- "modified": "2019-09-09T08:09:35.615Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/nav": {
- "modified": "2019-09-09T08:09:35.863Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/p": {
- "modified": "2019-09-09T08:09:31.599Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/section": {
- "modified": "2019-09-09T08:09:37.847Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/strong": {
- "modified": "2019-09-09T08:09:31.480Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/table": {
- "modified": "2019-09-09T08:09:45.976Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/time": {
- "modified": "2019-09-09T08:09:45.293Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTML/Element/title": {
- "modified": "2019-09-09T08:09:31.348Z",
- "contributors": [
- "SphinxKnight",
- "fabio.rahamim"
- ]
- },
- "Web/HTTP": {
- "modified": "2020-01-23T11:09:25.335Z",
- "contributors": [
- "feifeili18"
- ]
- },
- "Web/HTTP/Status": {
- "modified": "2020-10-15T22:26:35.107Z",
- "contributors": [
- "adammatar"
- ]
- },
- "Web/HTTP/Status/403": {
- "modified": "2020-11-18T16:02:55.271Z",
- "contributors": [
- "chv"
- ]
- },
- "Web/JavaScript": {
- "modified": "2020-03-12T19:36:23.440Z",
- "contributors": [
- "T882200",
- "fabio.rahamim",
- "fscholz",
- "teoli",
- "ziv"
- ]
- },
- "Web/JavaScript/Guide": {
- "modified": "2020-03-12T19:42:40.958Z",
- "contributors": [
- "x2357"
- ]
- },
- "Web/JavaScript/Reference": {
- "modified": "2020-03-12T19:42:07.041Z",
- "contributors": [
- "royGil",
- "Minat"
- ]
- },
- "Web/JavaScript/Reference/Errors": {
- "modified": "2020-03-12T19:45:07.364Z",
- "contributors": [
- "Sheppy"
- ]
- },
- "Web/JavaScript/Reference/Functions": {
- "modified": "2020-10-15T21:57:24.936Z",
- "contributors": [
- "fabio.rahamim",
- "fscholz"
- ]
- },
- "Web/JavaScript/Reference/Functions/Default_parameters": {
- "modified": "2020-10-15T21:57:23.127Z",
- "contributors": [
- "Reuven"
- ]
- },
- "Web/JavaScript/Reference/Global_Objects": {
- "modified": "2020-03-12T19:42:41.419Z",
- "contributors": [
- "fabio.rahamim",
- "x2357"
- ]
- },
- "Web/JavaScript/Reference/Global_Objects/Array": {
- "modified": "2020-08-05T11:06:54.634Z",
- "contributors": [
- "ariel.rotem1000",
- "meirlamdan",
- "MeirOverferst",
- "kdex",
- "ibratoev"
- ]
- },
- "Web/JavaScript/Reference/Global_Objects/Array/from": {
- "modified": "2020-10-15T22:17:20.213Z",
- "contributors": [
- "Whose69",
- "MeirOverferst"
- ]
- },
- "Web/JavaScript/Reference/Global_Objects/Array/includes": {
- "modified": "2019-03-23T22:26:42.843Z",
- "contributors": [
- "Gal_Zakay"
- ]
- },
- "Web/JavaScript/Reference/Global_Objects/Array/unshift": {
- "modified": "2020-10-15T22:01:58.015Z",
- "contributors": [
- "naomitayeb"
- ]
- },
- "Web/JavaScript/Reference/Global_Objects/Object": {
- "modified": "2020-10-15T22:12:27.578Z",
- "contributors": [
- "fscholz"
- ]
- },
- "Web/JavaScript/Reference/Global_Objects/Object/assign": {
- "modified": "2020-11-10T06:21:37.336Z",
- "contributors": [
- "dorheitner"
- ]
- },
- "Web/JavaScript/Reference/Global_Objects/Promise": {
- "modified": "2020-10-15T22:12:11.929Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Web/JavaScript/Reference/Global_Objects/String": {
- "modified": "2020-10-15T22:09:01.642Z",
- "contributors": [
- "fabio.rahamim",
- "HuangYuSan"
- ]
- },
- "Web/JavaScript/Reference/Operators": {
- "modified": "2020-12-14T11:30:30.401Z",
- "contributors": [
- "arai"
- ]
- },
- "Web/JavaScript/Reference/Operators/Destructuring_assignment": {
- "modified": "2020-03-12T19:42:42.276Z",
- "contributors": [
- "dafbyte",
- "BlackB1RD",
- "kdex",
- "ShakedAmar"
- ]
- },
- "Web/JavaScript/Reference/Operators/Operator_Precedence": {
- "modified": "2020-03-12T19:42:13.747Z",
- "contributors": [
- "cobicarmel",
- "jnfsmile"
- ]
- },
- "Web/JavaScript/Reference/Statements": {
- "modified": "2020-03-12T19:42:34.939Z",
- "contributors": [
- "royGil",
- "Sebastianz"
- ]
- },
- "Web/JavaScript/Reference/Statements/const": {
- "modified": "2020-10-15T22:11:57.477Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Web/JavaScript/Reference/Statements/for...of": {
- "modified": "2020-03-12T19:44:55.627Z",
- "contributors": [
- "morwin"
- ]
- },
- "Web/JavaScript/Reference/Statements/function*": {
- "modified": "2020-10-15T22:12:13.549Z",
- "contributors": [
- "dafbyte"
- ]
- },
- "Web/JavaScript/Reference/Statements/return": {
- "modified": "2020-10-15T22:12:39.963Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Web/JavaScript/Reference/Statements/var": {
- "modified": "2020-10-15T22:10:51.321Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Web/API/Document_Object_Model": {
- "modified": "2019-01-16T14:20:09.020Z",
- "contributors": [
- "ziv"
- ]
- },
- "Glossary/array": {
- "modified": "2019-04-14T20:37:05.958Z",
- "contributors": [
- "MeirOverferst"
- ]
- },
- "orphaned/he": {
- "modified": "2019-03-24T00:06:58.385Z",
- "contributors": [
- "ziv"
- ]
- },
- "orphaned/Hebrew_Localization": {
- "modified": "2019-01-16T14:19:44.573Z",
- "contributors": [
- "ziv"
- ]
- },
- "Learn/HTML/Tables": {
- "modified": "2020-07-16T22:25:11.770Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Learn/Forms": {
- "modified": "2020-07-16T22:20:57.218Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Learn/HTML/Introduction_to_HTML": {
- "modified": "2020-07-16T22:22:47.567Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Learn/HTML/Howto": {
- "modified": "2020-07-16T22:22:28.745Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "Learn/JavaScript/Building_blocks/conditionals": {
- "modified": "2020-07-16T22:31:13.828Z",
- "contributors": [
- "ItzikDabush"
- ]
- },
- "orphaned/MDN/Community": {
- "modified": "2019-09-11T08:02:56.848Z",
- "contributors": [
- "SphinxKnight",
- "dafbyte"
- ]
- },
- "orphaned/MDN/Contribute/Howto/Create_an_MDN_account": {
- "modified": "2019-03-18T21:21:11.313Z",
- "contributors": [
- "dafbyte"
- ]
- },
- "Mozilla/Add-ons/WebExtensions/manifest.json/permissions": {
- "modified": "2020-10-15T22:24:49.961Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "Mozilla/Add-ons/WebExtensions/Tips": {
- "modified": "2019-08-30T04:55:04.968Z",
- "contributors": [
- "AmitYaron"
- ]
- },
- "conflicting/Web/Guide": {
- "modified": "2019-01-16T14:20:09.744Z",
- "contributors": [
- "ziv"
- ]
- },
- "Web/API/Geolocation_API": {
- "modified": "2019-03-23T23:11:11.069Z",
- "contributors": [
- "omeriko"
- ]
- },
- "orphaned/Web/Hypertext_Markup_Language": {
- "modified": "2019-09-09T08:06:46.920Z",
- "contributors": [
- "fabio.rahamim"
- ]
- },
- "orphaned/מושגים": {
- "modified": "2019-03-24T00:07:06.819Z",
- "contributors": [
- "ziv"
- ]
- }
-} \ No newline at end of file
diff --git a/files/he/conflicting/web/guide/index.html b/files/he/conflicting/web/guide/index.html
deleted file mode 100644
index f7277680cb..0000000000
--- a/files/he/conflicting/web/guide/index.html
+++ /dev/null
@@ -1,14 +0,0 @@
----
-title: פיתוח לאינטרנט
-slug: conflicting/Web/Guide
-original_slug: Web_Development
----
-<div>
-<p>נושא זה מכיל את כל האספקטים הנוגעים לפיתוח אתרי אינטרנט ואפליקציות אינטרנט.</p>
-<p>למדו כיצד ליצור החל מדפי אינטרנט פשוטים ועד אתרי אינטרנט מורכבים.</p>
-<div>
-<h2 id="נושאים">נושאים</h2>
-<dl> <dt><a class="internal" href="/he/DOM" title="he/DOM">DOM</a></dt> <dd>Document Object Model, משמש כממשק עבור מסמכי HTML ו-XML, המספק ייצוג מבני למסמך על מנת לאפשר שינויים.</dd>
-</dl>
-</div>
-</div>
diff --git a/files/he/glossary/array/index.html b/files/he/glossary/array/index.html
deleted file mode 100644
index ac367d5154..0000000000
--- a/files/he/glossary/array/index.html
+++ /dev/null
@@ -1,43 +0,0 @@
----
-title: מערך
-slug: Glossary/array
-translation_of: Glossary/array
-original_slug: Glossary/מערך
----
-<p dir="rtl"> </p>
-
-<div dir="rtl"><span style="font-size: 1rem; letter-spacing: -0.00278rem;">מערך הוא אוסף מסודר של ערכים (או "פרימיטיבים" או "אובייקטים" תלוי בשפה) כל פריט באוסף נקרא איבר.</span></div>
-
-<div dir="rtl"><span style="font-size: 1rem; letter-spacing: -0.00278rem;">משתמשים במערכים בכדי לאכסן ערכים מרובים במשתנה יחיד. בשונה ממשתנה(רגיל) שיוכל לאכסן ערך יחיד.</span><br>
- </div>
-
-<div dir="rtl"><span style="font-size: 1rem; letter-spacing: -0.00278rem;">לכל איבר במערך יש מספר המוצמד אליו שנקרא אינדקס ,אשר מאפשר לך לגישה אליו.<br>
-בג'אווה סקריפט המערכים מתחילים מאינדקס אפס ואפשר לשנות אותם על ידי שימוש במתודות(methods) שונות.</span></div>
-
-<div dir="rtl"> </div>
-
-<div dir="rtl">מערך בג'אווה סקריפט נראה כך:</div>
-
-<p dir="rtl"> </p>
-
-<pre><code>var myArray = [1, 2, 3, 4];
-var catNamesArray = ["Danny", "Yossi", "Hila"];
-//מערך בג'אווה סקריפט יכול להכיל סוגים שונים של מידע כפי שמתואר מעל</code></pre>
-
-<p dir="rtl"> </p>
-
-<p dir="rtl"> </p>
-
-<h2 id="Learn_more">Learn more</h2>
-
-<h3 id="General_knowledge">General knowledge</h3>
-
-<ul>
- <li>{{Interwiki("wikipedia", "Array data structure", "Array")}} on Wikipedia</li>
-</ul>
-
-<h3 id="Technical_reference">Technical reference</h3>
-
-<ul>
- <li>JavaScript {{jsxref("Array")}} on MDN</li>
-</ul>
diff --git a/files/he/glossary/css/index.html b/files/he/glossary/css/index.html
deleted file mode 100644
index cae8af060f..0000000000
--- a/files/he/glossary/css/index.html
+++ /dev/null
@@ -1,50 +0,0 @@
----
-title: CSS
-slug: Glossary/CSS
-tags:
- - CSS
- - מילון מונחים
- - קידוד סקריפטים
-translation_of: Glossary/CSS
----
-<p style="direction: rtl;"><span class="seoSummary"><strong>CSS</strong> (גליונות סגנון מדורגים {=Cascading Style Sheets}) הינה שפה הצהרתית אשר אחראית על איך יראה דף האינטרנט ב{{glossary("דפדפן")}}.</span> הדפדפן מחיל את הצהרות הסגנון של הCSS על האלמנטים הנבחרים על מנת להציגם כראוי. הצהרת סגנון מכילה מאפיינים ואת הערכים שלהם, אשר קובעים איך ייראה דף האינטרנט.</p>
-
-<p style="direction: rtl;">CSS הינה אחת משלושת טכנולוגיות היסוד של האינטרנט, יחד עם {{Glossary("HTML")}} ו{{Glossary("JavaScript")}}. למעשה CSS מסגננת את האלמנטים של ה{{Glossary("Element","HTML")}}, אך יכולה לשמש גם שפת סיגנון לשפות תגיות אחרות כמו {{Glossary("SVG")}} או {{Glossary("XML")}}.</p>
-
-<p style="direction: rtl;">כלל CSSסי הינו מערכת של {{Glossary("מאפיין CSS","מאפיינים")}} המשוייכת ל{{Glossary("CSS selector", "סלקטור")}}. להלן דוגמא שצובעת כל פסקת HTML בצהוב על רקע שחור:</p>
-
-<pre class="brush: css" dir="rtl"><span style="font-size: 1rem; letter-spacing: -0.00333rem;">/* הסלקטור בשורה הבאה מצביע על כך שכל הפסיקות במסמך יושפעו מ'הכלל' הזה. */</span>
-p {
-
-<span style="font-size: 1rem; letter-spacing: -0.00333rem;"> /* המאפיין בשורה הבאה מגדיר את צבע הטקסט, במקרה הזה צהוב. */</span>
- color: yellow;
-
-<span style="font-size: 1rem; letter-spacing: -0.00333rem;"> /* המאפיין בשורה הבאה</span><span style="font-size: 1rem; letter-spacing: -0.00333rem;"> מגדיר את צבע הרקע</span><span style="font-size: 1rem; letter-spacing: -0.00333rem;">, במקרה הזה שחור. */</span>
- background-color: black
-}</pre>
-
-<div style="direction: rtl;"> </div>
-
-<p style="direction: rtl;">"מדורגים" מתייחס לכלל שקובע לפי איזה סדר הסלקטורים יוכלו להביא את השינויים שלהם לסגנון הדף. זהו פיצ'ר מאוד נצרך, מכיוון שאתר מורכב יכול להכיל אלפים של כללי CSS.</p>
-
-<h2 id="למד_עוד" style="direction: rtl;">למד עוד</h2>
-
-<h3 id="ידע_כללי" style="direction: rtl;">ידע כללי</h3>
-
-<ul>
- <li style="direction: rtl;"><a href="https://developer.mozilla.org/en-US/Learn/CSS">Learn CSS</a></li>
- <li style="direction: rtl;">{{interwiki("wikipedia", "CSS")}} בויקיפדיה</li>
-</ul>
-
-<h3 id="התייחסות_טכנית" style="direction: rtl;">התייחסות טכנית</h3>
-
-<ul>
- <li style="direction: rtl;"><a href="/en-US/docs/Web/CSS">The CSS documentation on MDN</a></li>
- <li style="direction: rtl;"><a href="http://www.w3.org/Style/CSS/current-work" rel="external">The CSS Working Group current work</a></li>
-</ul>
-
-<h3 id="למד_אודות_CSS" style="direction: rtl;">למד אודות CSS</h3>
-
-<ul>
- <li style="direction: rtl;"><a href="http://www.codecademy.com/en/tracks/web" rel="external">The web course on codecademy.com</a></li>
-</ul>
diff --git a/files/he/glossary/html/index.html b/files/he/glossary/html/index.html
deleted file mode 100644
index c5064257d8..0000000000
--- a/files/he/glossary/html/index.html
+++ /dev/null
@@ -1,46 +0,0 @@
----
-title: HTML
-slug: Glossary/HTML
-translation_of: Glossary/HTML
----
-<div>{{QuickLinksWithSubpages("/he-IL/docs/Glossary")}}</div>
-
-<p><strong>HTML</strong> (קיצור של HyperText Markup Language) היא 'שפה תיאורית' המציינת את מבנה דף האינטרנט.</p>
-
-<h2 id="קצת_היסטוריה">קצת היסטוריה</h2>
-
-<p>בשנת 1990, כחלק מחזונו של ה-{{Glossary("World Wide Web","Web")}}, טים ברנרס-לי הגדיר את המושג {{Glossary("hypertext")}}, לאחר שנה הגדיר זאת בעיקר באמצעות {{Glossary("SGML")}}. ה-{{Glossary("IETF")}} החל לציין רשמית HTML בשנת 1993, ואחרי כמה טיוטות שוחררה גרסה 2.0 בשנת 1995. בשנת 1994 ייסד ברנרס-לי את {{Glossary("W3C")}} כדי לפתח את ה-Web. בשנת 1996 השתלט W3C על עבודת ה-HTML ופרסם את המלצת ה-HTML 3.2 כעבור שנה. HTML 4.0 שוחרר בשנת 1999 והפך לסטנדרט {{Glossary("ISO")}} בשנת 2000.</p>
-
-<p>באותה תקופה, W3C כמעט נטש את HTML לטובת {{Glossary("XHTML")}}, מה שהניע את הקמתה של קבוצה עצמאית שנקראת {{Glossary("WHATWG")}} ב-2004. תודות ל- WHATWG, העבודה על {{Glossary("HTML5")}} המשיכה: שני הארגונים פרסמו את הטיוטה הראשונה בשנת 2008 ואת התקן הסופי בשנת 2014.</p>
-
-<h2 id="קונספט_ותחביר">קונספט ותחביר</h2>
-
-<p>מסמך HTML הוא מסמך טקסט רגיל שמאורגן ומחולק באמצעות {{Glossary("element","elements")}}. אלמנטים מוקפים בפתיחה וסגירה תואמים - "תגיות" {{Glossary("tag","tags")}}. כל תגית מתחילה ומסתיימת בסוגריים זוויתיים (<code>&lt;&gt;</code>). ישנם כמה תגיות ריקות או מבוטלות שלא יכולות לכלול טקסט כלשהו, ​​למשל {{htmlelement("img")}}.</p>
-
-<p>אפשר להרחיב את תגיות ה-HTML עם {{Glossary("attribute","attributes")}}, המספקים מידע ותכונות נוספות, שמשפיעים על האופן בו הדפדפן מפרש את האלמנט:</p>
-
-<p><img alt="Detail of the structure of an HTML element" src="https://mdn.mozillademos.org/files/7659/anatomy-of-an-html-element.png" style="height: 181px; width: 609px;"></p>
-
-<p>קובץ HTML נשמר בדרך כלל עם סיומת <code>htm.</code> או <code>html.</code>, המוגשת על ידי {{Glossary("Server","web server")}}, וניתנת לעיבוד והצגה על ידי כל {{Glossary("Browser","Web browser")}}.</p>
-
-<h2 id="למד_עוד">למד עוד</h2>
-
-<h3 id="ידע_כללי">ידע כללי</h3>
-
-<ul>
- <li>בוויקיפדיה {{interwiki("wikipedia", "HTML", "HTML")}}</li>
-</ul>
-
-<h3 id="לימוד_HTML">לימוד HTML</h3>
-
-<ul>
- <li><a href="/en-US/Learn/HTML">Our HTML tutorial </a></li>
- <li><a href="https://www.codecademy.com/en/tracks/web" rel="external">The web course on codecademy.com</a></li>
-</ul>
-
-<h3 id="התייחסויות_טכניות">התייחסויות טכניות</h3>
-
-<ul>
- <li><a href="/en-US/docs/Web/HTML">The HTML documentation on MDN</a></li>
- <li><a href="https://www.w3.org/TR/html5/" rel="external">The HTML specification</a></li>
-</ul>
diff --git a/files/he/glossary/index.html b/files/he/glossary/index.html
deleted file mode 100644
index da2d505248..0000000000
--- a/files/he/glossary/index.html
+++ /dev/null
@@ -1,48 +0,0 @@
----
-title: 'MDN Web Docs Glossary: Definitions of Web-related terms'
-slug: Glossary
-tags:
- - Beginner
- - Definitions
- - Dictionary
- - Glossary
- - Index
- - Landing
- - NeedsTranslation
- - Terminology
- - TopicStub
-translation_of: Glossary
----
-<div style="width: 44%; float: right; margin: 4px 0 .5em 1em; line-height: 1.4;">{{LearnBox({"title":"Learn a new term:"})}}</div>
-
-<p class="summary" style="padding-top: 0; border-top-width: 0;">טכנולוגיות האינטרנט מכילות רשימות ארוכות של ביטויים וקיצורים המשמשים לתיעוד ולכתיבת קוד. מילון מונחים זה מספק הגדרות של מילים וקיצורים שעליך לדעת כדי להבין ולפתח בהצלחה בעולם ה-Web.</p>
-
-<h2 id="מילון_מונחים">מילון מונחים</h2>
-
-<p>{{GlossaryList({"split": "h3", "css": "multiColumnList"})}}</p>
-
-<h2 id="תורמים_למילון_המונחים">תורמים למילון המונחים</h2>
-
-<p>מילון מונחים זה הוא עבודה שאינה נגמרת בעיצומה. אתה יכול לעזור ולשפר על ידי <a href="/en-US/docs/MDN/Contribute/Howto/Write_a_new_entry_in_the_Glossary">כתיבת ערכים חדשים</a> או על ידי עדכון ושיפור הערכים הקיימים. הדרך הקלה ביותר להתחיל היא ללחוץ על הקישור הבא או לבחור באחד מהתנאים המוצעים להלן.</p>
-
-<p><strong><a href="/en-US/docs/new?parent=4391">הוסף ערך חדש למילון</a></strong></p>
-
-<p>{{GlossaryList({"terms":["at-rule", "ALPN", "Attack", "Byte-Order Mark", "client", "Character set", "cryptosystem", "debug", "digital signature", "execution", "flex-direction", "GLSL", "Interface", "Library", "Memory management", "routers", "Self-Executing Anonymous Function", "Stylesheet", "Vector image"], "filter": "notdefined", "css": "multiColumnList"})}}</p>
-
-<p>אם אתה רוצה לדעת יותר כיצד לתרום למילון המונחים, בדוק <a href="/en-US/docs/MDN/Doc_status/Glossary">דף המצב של תיעוד מילון המונחים</a>.</p>
-
-<h2 id="ראה_עוד">ראה עוד</h2>
-
-<ul>
- <li><a href="/en-US/docs/MDN/Community">הצטרף לקהילת MDN</a></li>
-</ul>
-
-<div class="hidden">
-<h2 id="Subnav">Subnav</h2>
-
-<section id="Quick_Links">
-<ol>
- <li><strong><a href="/en-US/docs/Glossary">MDN Web Docs Glossary</a></strong>{{ListSubpagesForSidebar("/en-us/docs/Glossary", 1)}}</li>
-</ol>
-</section>
-</div>
diff --git a/files/he/learn/css/index.html b/files/he/learn/css/index.html
deleted file mode 100644
index 92e818ddb8..0000000000
--- a/files/he/learn/css/index.html
+++ /dev/null
@@ -1,64 +0,0 @@
----
-title: CSS
-slug: Learn/CSS
-tags:
- - Beginner
- - CSS
- - CodingScripting
- - Debugging
- - Landing
- - NeedsContent
- - NeedsTranslation
- - Topic
- - TopicStub
- - length
- - specificity
-translation_of: Learn/CSS
----
-<div>{{LearnSidebar}}</div>
-
-<p class="summary">Cascading Stylesheets — or {{glossary("CSS")}} — is the first technology you should start learning after {{glossary("HTML")}}. Whereas HTML is used to define the structure and semantics of your content, CSS is used to style it and lay it out. So for example, you can use CSS to alter the font, color, size and spacing of your content, split it into multiple columns, or add animations and other decorative features.</p>
-
-<h2 id="Learning_pathway">Learning pathway</h2>
-
-<p>You should really learn the basics of HTML before attempting any CSS. We'd recommend that you work through our <a href="/en-US/docs/Learn/HTML/Introduction_to_HTML">Introduction to HTML</a> module first — you can then learn about:</p>
-
-<ul>
- <li>CSS, starting with the <a href="/en-US/docs/Learn/CSS/Introduction_to_CSS">Introduction to CSS</a> module</li>
- <li>More advanced <a href="/en-US/Learn/HTML#Modules">HTML modules</a></li>
- <li><a href="/en-US/docs/Learn/JavaScript">JavaScript</a>, and how to use it to add dynamic functionality to web pages</li>
-</ul>
-
-<p>We'd recommend that you learn HTML and CSS at the same time, moving back and forth between the two topics. This is because HTML is far more interesting with CSS, and you can't really learn CSS without knowing HTML.</p>
-
-<p>Before starting this topic, you should also have at least basic familiarity with using computers, and using the Web passively (i.e. just looking at it, consuming the content.) You should have a basic work environment set up as detailed in <a href="/en-US/docs/Learn/Getting_started_with_the_web/Installing_basic_software">Installing basic software</a>, and understand how to create and manage files, as detailed in <a href="/en-US/docs/Learn/Getting_started_with_the_web/Dealing_with_files">Dealing with files</a> — both are parts of our <a href="/en-US/docs/Learn/Getting_started_with_the_web">Getting started with the web</a> complete beginner's module.</p>
-
-<p>It is recommended that you work through <a href="/en-US/docs/Learn/Getting_started_with_the_web">Getting started with the web</a> before attempting this topic, however it isn't absolutely necessary; much of what is covered in the CSS basics article is also covered in our Introduction to CSS module, albeit in a lot more detail.</p>
-
-<h2 id="Modules">Modules</h2>
-
-<p>This topic contains the following modules, in a suggested order for working through them. You should definitely start with the first one.</p>
-
-<dl>
- <dt><a href="/en-US/docs/Learn/CSS/Introduction_to_CSS">Introduction to CSS</a></dt>
- <dd>This module gets you started with the basics of how CSS works, including selectors and properties, writing CSS rules, applying CSS to HTML, how to specify length, color, and other units in CSS, cascade and inheritance, box model basics, and debugging CSS.</dd>
- <dt><a href="/en-US/docs/Learn/CSS/Styling_text">Styling text</a></dt>
- <dd>Here we look at text styling fundamentals, including setting font, boldness, and italics, line and letter spacing, and drop shadows and other text features. We round off the module by looking at applying custom fonts to your page, and styling lists and links.</dd>
- <dt><a href="/en-US/docs/Learn/CSS/Styling_boxes">Styling boxes</a></dt>
- <dd>Next up, we look at styling boxes, one of the fundamental steps towards laying out a web page. In this module we recap the box model then look at controlling box layouts by setting padding, borders and margins, setting custom background colors, images and other features, and fancy features such as drop shadows and filters on boxes.</dd>
- <dt><a href="/en-US/docs/Learn/CSS/CSS_layout">CSS layout</a></dt>
- <dd>At this point we've already looked at CSS fundamentals, how to style text, and how to style and manipulate the boxes that your content sits inside. Now it's time to look at how to place your boxes in the right place in relation to the viewport, and one another. We have covered the necessary prerequisites so you can now dive deep into CSS layout, looking at different display settings, traditional layout methods involving float and positioning, and new fangled layout tools like flexbox.</dd>
- <dt>Responsive design (TBD)</dt>
- <dd>With so many different types of devices able to browse the Web these days, <a href="/en-US/docs/Web/Guide/Responsive_design">responsive web design</a> (RWD) has become a core web development skill. This module will cover the basic principles and tools of RWD, explain how to apply different CSS to a document depending on device features like screen width, orientation, and resolution, and explore the technologies available for serving different video and images depending on such features.</dd>
-</dl>
-
-<h2 id="Solving_common_CSS_problems">Solving common CSS problems</h2>
-
-<p><a href="/en-US/docs/Learn/CSS/Howto">Use CSS to solve common problems</a> provides links to sections of content explaining how to use CSS to solve very common problems when creating a webpage.</p>
-
-<h2 id="See_also">See also</h2>
-
-<dl>
- <dt><a href="/en-US/docs/Web/CSS">CSS on MDN</a></dt>
- <dd>The main entry point for CSS documentation on MDN, where you'll find detailed reference documentation for all features of the CSS language. Want to know all the values a property can take? This is a good place to go.</dd>
-</dl>
diff --git a/files/he/learn/forms/index.html b/files/he/learn/forms/index.html
deleted file mode 100644
index 6287ec1814..0000000000
--- a/files/he/learn/forms/index.html
+++ /dev/null
@@ -1,73 +0,0 @@
----
-title: טפסי HTML
-slug: Learn/Forms
-translation_of: Learn/Forms
-original_slug: Learn/HTML/טפסים
----
-<div>{{LearnSidebar}}</div>
-
-<p class="summary">This module provides a series of articles that will help you master HTML forms. HTML forms are a very powerful tool for interacting with users; however, for historical and technical reasons, it's not always obvious how to use them to their full potential. In this guide, we'll cover all aspects of HTML forms, from structure to styling, from data handling to custom widgets.</p>
-
-<h2 id="Prerequisites">Prerequisites</h2>
-
-<p>Before starting this module, you should at least work through our <a href="/en-US/docs/Learn/HTML/Introduction_to_HTML">Introduction to HTML</a>. At this point you should find the {{anch("Basic guides")}} easy to understand, and also be able to make use of our <a href="/en-US/docs/Learn/HTML/Forms/The_native_form_widgets">Native form widgets</a> guide.</p>
-
-<p>The rest of the module however is a bit more advanced — it is easy to put form widgets on a page, but you can't actually do much with them without using some advanced form features, CSS, and JavaScript. Therefore, before you look at the other sections we'd recommend that you go away and learn some <a href="/en-US/docs/Learn/CSS">CSS</a> and <a href="/en-US/docs/Learn/JavaScript">JavaScript</a> first.</p>
-
-<div class="note">
-<p><strong>Note</strong>: If you are working on a computer/tablet/other device where you don't have the ability to create your own files, you could try out (most of) the code examples in an online coding program such as <a href="http://jsbin.com/">JSBin</a> or <a href="https://thimble.mozilla.org/">Thimble</a>.</p>
-</div>
-
-<h2 id="Basic_guides">Basic guides</h2>
-
-<dl>
- <dt><a href="/en-US/docs/Learn/HTML/Forms/Your_first_HTML_form">Your first HTML form</a></dt>
- <dd>The first article in our series provides your very first experience of creating an HTML form, including designing a simple form, implementing it using the right HTML elements, adding some very simple styling via CSS, and how data is sent to a server.</dd>
- <dt><a href="/en-US/docs/Learn/HTML/Forms/How_to_structure_an_HTML_form">How to structure an HTML form</a></dt>
- <dd>With the basics out of the way, we now look in more detail at the elements used to provide structure and meaning to the different parts of a form.</dd>
-</dl>
-
-<h2 id="What_form_widgets_are_available">What form widgets are available?</h2>
-
-<dl>
- <dt><a href="/en-US/docs/Learn/HTML/Forms/The_native_form_widgets">The native form widgets</a></dt>
- <dd>We now look at the functionality of the different form widgets in detail, looking at what options are available to collect different types of data.</dd>
-</dl>
-
-<h2 id="Validating_and_submitting_form_data">Validating and submitting form data</h2>
-
-<dl>
- <dt><a href="/en-US/docs/Learn/HTML/Forms/Sending_and_retrieving_form_data">Sending form data</a></dt>
- <dd>This article looks at what happens when a user submits a form — where does the data go, and how do we handle it when it gets there? We also look at some of the security concerns associated with sending form data.</dd>
- <dt><a href="/en-US/docs/Learn/HTML/Forms/Form_validation">Form data validation</a></dt>
- <dd>Sending data is not enough — we also need to make sure that the data users fill out in forms is in the correct format we need to process it successfully, and that it won't break our applications. We also want to help our users to fill out our forms correctly and don't get frustrated when trying to use our apps. Form validation helps us achieve these goals — this article tells you what you need to know.</dd>
-</dl>
-
-<h2 id="Advanced_guides">Advanced guides</h2>
-
-<dl>
- <dt><a href="/en-US/docs/Learn/HTML/Forms/How_to_build_custom_form_widgets">How to build custom form widgets</a></dt>
- <dd>You'll come across some cases where the native form widgets just don't provide what you need, e.g. because of styling or functionality. In such cases, you may need to build your own form widget out of raw HTML. This article explains how you'd do this and the considerations you need to be aware of when doing so, with a practical case study.</dd>
- <dt><a href="/en-US/docs/Learn/HTML/Forms/Sending_forms_through_JavaScript">Sending forms through JavaScript</a></dt>
- <dd>This article looks at ways to use a form to assemble an HTTP request and send it via custom JavaScript, rather than standard form submission. It also looks at why you'd want to do this, and the implications of doing so. (See also Using FormData objects.)</dd>
- <dt><a href="/en-US/docs/Learn/HTML/Forms/HTML_forms_in_legacy_browsers">HTML forms in legacy browsers</a></dt>
- <dd>Article covering feature detection, etc. This should be redirected to the cross browser testing module, as the same stuff is covered better there.</dd>
-</dl>
-
-<h2 id="Form_styling_guides">Form styling guides</h2>
-
-<dl>
- <dt><a href="/en-US/docs/Learn/HTML/Forms/Styling_HTML_forms">Styling HTML forms</a></dt>
- <dd>This article provides an introduction to styling forms with CSS, including all the basics you might need to know for basic styling tasks.</dd>
- <dt><a href="/en-US/docs/Learn/HTML/Forms/Advanced_styling_for_HTML_forms">Advanced styling for HTML forms</a></dt>
- <dd>Here we look at some more advanced form styling techniques that need to be used when trying to deal with some of the more difficult-to-style elements.</dd>
- <dt><a href="/en-US/docs/Learn/HTML/Forms/Property_compatibility_table_for_form_widgets">Property compatibility table for form widgets</a></dt>
- <dd>This last article provides a handy reference allowing you to look up what CSS properties are compatible with what form elements.</dd>
-</dl>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li><a href="/en-US/docs/Web/HTML/Element#Forms">HTML forms element reference</a></li>
- <li><a href="/en-US/docs/Web/HTML/Element/input">HTML &lt;input&gt; types reference</a></li>
-</ul>
diff --git a/files/he/learn/getting_started_with_the_web/index.html b/files/he/learn/getting_started_with_the_web/index.html
deleted file mode 100644
index b0c020b580..0000000000
--- a/files/he/learn/getting_started_with_the_web/index.html
+++ /dev/null
@@ -1,61 +0,0 @@
----
-title: תחילת הדרך עם ה-Web
-slug: Learn/Getting_started_with_the_web
-tags:
- - Beginner
- - CSS
- - Design
- - Guide
- - HTML
- - Index
- - NeedsTranslation
- - TopicStub
- - 'l10n:priority'
- - publishing
- - theory
-translation_of: Learn/Getting_started_with_the_web
----
-<div>{{LearnSidebar}}</div>
-
-<div class="summary">
-<p><em>Getting started with the Web</em> is a concise series introducing you to the practicalities of web development. You'll set up the tools you need to construct a simple webpage and publish your own simple code.</p>
-</div>
-
-<h2 id="The_story_of_your_first_website">The story of your first website</h2>
-
-<p>It's a lot of work to create a professional website, so if you're new to web development we encourage you to start small. You won't build another Facebook right away, but it's not hard to get your own simple website online, so we'll start there.</p>
-
-<p>By working through the articles listed below in order, you will go from nothing to getting your first webpage online. Let's go!</p>
-
-<h3 dir="rtl" id="התקנת_תוכנות_בסיסיות"><a href="/he/Learn/Getting_started_with_the_web/Installing_basic_software">התקנת תוכנות בסיסיות </a></h3>
-
-<p>When it comes to tools for building a website, there's a lot to pick from. If you're just starting out, you might be confused by the array of code editors, frameworks, and testing tools out there. In <a href="/he/Learn/Getting_started_with_the_web/Installing_basic_software">Installing basic software</a> we show you step-by-step how to install just the software you need to begin some basic web development.</p>
-
-<h3 dir="rtl" id="עיצוב_ונראות"><a href="/he/Learn/Getting_started_with_the_web/What_will_your_website_look_like">עיצוב ונראות</a></h3>
-
-<p dir="rtl">מומלץ לתכנן את אתר האינטרנט לפני בנייתו, יש להכיר את הקווים המנחים שלו כגון: גודל הבאנרים, היכן ימוקם הלוגו? מהו הגובה המתאים, גופן, צבעים ועוד.</p>
-
-<h3 dir="rtl" id="התמודדות_עם_קבצים"><a href="/he/Learn/Getting_started_with_the_web/Dealing_with_files">התמודדות עם קבצים</a></h3>
-
-<p>A website consists of many files: text content, code, stylesheets, media content, and so on. When you're building a website, you need to assemble these files into a sensible structure and make sure they can talk to one another. <a href="/en-US/Learn/Getting_started_with_the_web/Dealing_with_files">Dealing with files</a> explains how to set up a sensible file structure for your website and what issues you should be aware of.</p>
-
-<h3 dir="rtl" id="היכרות_עם_HTML"><a href="/he/Learn/Getting_started_with_the_web/HTML_basics">היכרות עם HTML </a></h3>
-
-<p dir="rtl">שפת HTML היא שפת תגיות המשמשת לבניה, עיצוב ועריכה של דפי אינטרנט.<br>
- זוהי שפה פשוטה לכתיבה ובאמצעותה ניתן להוסיף אל דף האינטרנט אלמנטים שונים כגון: טבלה, תמונות, קישורים, פסקאות ועוד.</p>
-
-<h3 dir="rtl" id="היכרות_עם_CSS"><a href="/en-US/Learn/Getting_started_with_the_web/CSS_basics">היכרות עם CSS </a></h3>
-
-<p>Cascading Stylesheets (CSS) is the code that you use to style your website. For example, do you want the text to be black or red? Where should content be drawn on the screen? What background images and colors should be used to decorate your website? <a href="/en-US/Learn/Getting_started_with_the_web/CSS_basics">CSS basics</a> takes you through what you need to get started.</p>
-
-<h3 dir="rtl" id="היכרות_עם_Javascript"><a href="/en-US/Learn/Getting_started_with_the_web/JavaScript_basics">היכרות עם Javascript </a></h3>
-
-<p>JavaScript is the programming language that you use to add interactive features to your website — for example: games, things that happen when buttons are pressed or data is entered in forms, dynamic styling effects, animation, and much more. <a href="/en-US/Learn/Getting_started_with_the_web/JavaScript_basics">JavaScript basics</a> gives you an idea of what is possible with this exciting language, and how to get started.</p>
-
-<h3 dir="rtl" id="פרסום_האתר"><a href="/en-US/Learn/Getting_started_with_the_web/Publishing_your_website">פרסום האתר</a></h3>
-
-<p dir="rtl">כעת, לאחר שהקוד מוכן וכל קבצי האתר מאורגנים כל שנותר הוא להעלות אותו לאינטרנט כדי שכולם יוכלו לבקר בו, ראה <a href="https://developer.mozilla.org/en-US/docs/Learn/Getting_started_with_the_web/Publishing_your_website">מאמר זה</a> המסביר כיצד לפרסם את האתר.</p>
-
-<h3 dir="rtl" id="כיצד_פועל_האינטרנט"><a href="https://developer.mozilla.org/en-US/docs/Learn/Getting_started_with_the_web/How_the_Web_works">כיצד פועל האינטרנט?</a></h3>
-
-<p dir="rtl">מה קורה ברקע לאחר שאנחנו נכנסים לאתר האהוב עלינו? כיצד הנתונים מגיעים מהשרת והיכן הם מאוחסנים?</p>
diff --git a/files/he/learn/html/howto/index.html b/files/he/learn/html/howto/index.html
deleted file mode 100644
index cc703642a6..0000000000
--- a/files/he/learn/html/howto/index.html
+++ /dev/null
@@ -1,142 +0,0 @@
----
-title: השתמש ב-HTML כדי לפתור בעיות נפוצות
-slug: Learn/HTML/Howto
-translation_of: Learn/HTML/Howto
-original_slug: Learn/HTML/פתרון_בעיות
----
-<div>{{LearnSidebar}}</div>
-
-<p class="summary">The following links point to solutions to common everyday problems you'll need to solve with HTML.</p>
-
-<div class="column-container">
-<div class="column-half">
-<h3 id="Basic_structure">Basic structure</h3>
-
-<p>The most basic application of HTML is document structure. If you're new to HTML you should start with this.</p>
-
-<ul>
- <li><a href="/en-US/Learn/HTML/Introduction_to_HTML/Getting_started#Anatomy_of_an_HTML_document">How to create a basic HTML document</a></li>
- <li><a href="/en-US/docs/Learn/HTML/Howto/Divide_a_webpage_into_logical_sections">How to divide a webpage into logical sections</a></li>
- <li><a href="/en-US/Learn/HTML/Introduction_to_HTML/HTML_text_fundamentals#The_basics_headings_and_paragraphs">How to set up a proper structure of headings and paragraphs</a></li>
-</ul>
-
-<h3 id="Basic_text-level_semantics">Basic text-level semantics</h3>
-
-<p>HTML specializes in providing semantic information for a document, so HTML answers many questions you might have about how to get your message across best in your document.</p>
-
-<ul>
- <li><a href="/en-US/Learn/HTML/Introduction_to_HTML/HTML_text_fundamentals#Lists">How to create list of items with HTML</a></li>
- <li><a href="/en-US/Learn/HTML/Introduction_to_HTML/HTML_text_fundamentals#Emphasis_and_importance">How to stress or emphasize content</a></li>
- <li><a href="/en-US/Learn/HTML/Introduction_to_HTML/HTML_text_fundamentals#Emphasis_and_importance">How to indicate that text is important</a></li>
- <li><a href="/en-US/Learn/HTML/Introduction_to_HTML/Advanced_text_formatting#Representing_computer_code">How to display computer code with HTML</a></li>
- <li><a href="/en-US/Learn/HTML/Multimedia_and_embedding/Images_in_HTML#Annotating_images_with_figures_and_figure_captions">How to annotate images and graphics</a></li>
- <li><a href="/en-US/Learn/HTML/Introduction_to_HTML/Advanced_text_formatting#Abbreviations">How to mark abbreviations and make them understandable</a></li>
- <li><a href="/en-US/Learn/HTML/Introduction_to_HTML/Advanced_text_formatting#Quotations">How to add quotations and citations to webpages</a></li>
- <li><a href="/en-US/docs/Learn/HTML/Howto/Define_terms_with_HTML">How to define terms with HTML</a></li>
-</ul>
-</div>
-
-<div class="column-half">
-<h3 id="Hyperlinks">Hyperlinks</h3>
-
-<p>One of the main reasons for HTML is make navigation easy with {{Glossary("hyperlink", "hyperlinks")}}, which can be used in many different ways:</p>
-
-<ul>
- <li><a href="/en-US/Learn/HTML/Introduction_to_HTML/Creating_hyperlinks">How to create a hyperlink</a></li>
- <li><a href="/en-US/Learn/HTML/Introduction_to_HTML/Creating_hyperlinks#Active_learning_creating_a_navigation_menu">How to create a table of contents with HTML</a></li>
-</ul>
-
-<h3 id="Images_multimedia">Images &amp; multimedia</h3>
-
-<ul>
- <li><a href="/en-US/Learn/HTML/Multimedia_and_embedding/Images_in_HTML#How_do_we_put_an_image_on_a_webpage">How to add images to a webpage</a></li>
- <li><a href="/en-US/Learn/HTML/Multimedia_and_embedding/Video_and_audio_content">How to add video content to a webpage</a></li>
-</ul>
-
-<h3 id="Scripting_styling">Scripting &amp; styling</h3>
-
-<p>HTML only sets up document structure. To solve presentation issues, use {{glossary("CSS")}}, or use scripting to make your page interactive.</p>
-
-<ul>
- <li><a href="/en-US/Learn/CSS/Introduction_to_CSS/How_CSS_works#How_to_apply_your_CSS_to_your_HTML">How to use CSS within a webpage</a></li>
- <li><a href="/en-US/docs/Learn/HTML/Howto/Use_JavaScript_within_a_webpage">How to use JavaScript within a webpage</a></li>
-</ul>
-
-<h3 id="Embedded_content">Embedded content</h3>
-
-<ul>
- <li><a href="/en-US/Learn/HTML/Multimedia_and_embedding/Other_embedding_technologies">How to embed a webpage within another webpage</a></li>
- <li><a href="/en-US/Learn/HTML/Multimedia_and_embedding/Other_embedding_technologies#The_%3Cembed%3E_and_%3Cobject%3E_elements">How to add Flash content within a webpage</a></li>
-</ul>
-</div>
-</div>
-
-<h2 id="Uncommon_or_advanced_problems">Uncommon or advanced problems</h2>
-
-<p>Beyond the basics, HTML is very rich and offers advanced features for solving complex problems. These articles help you tackle the less common use cases you may face:</p>
-
-<div class="column-container">
-<div class="column-half">
-<h3 id="Forms">Forms</h3>
-
-<p>Forms are a complex HTML structure made to send data from a webpage to a web server. We encourage you to go over our <a href="/en-US/docs/Web/Guide/HTML/Forms">full dedicated guide</a>. Here is where you should start:</p>
-
-<ul>
- <li><a href="/en-US/docs/Web/Guide/HTML/Forms/My_first_HTML_form">How to create a simple Web form</a></li>
- <li><a href="/en-US/docs/Web/Guide/HTML/Forms/How_to_structure_an_HTML_form">How to structure a Web form</a></li>
-</ul>
-
-<h3 id="Tabular_information">Tabular information</h3>
-
-<p>Some information, called tabular data, needs to be organized into tables with columns and rows. It's one of the most complex HTML structures, and mastering it is not easy:</p>
-
-<ul>
- <li><a href="/en-US/docs/Learn/HTML/Howto/Create_a_data_spreadsheet">How to create a data spreadsheet</a></li>
- <li><a href="/en-US/docs/Learn/HTML/Howto/Make_HTML_tables_accessible">How to make HTML tables accessible</a></li>
- <li><a href="/en-US/docs/Learn/HTML/Howto/Optimize_HTML_table_rendering">How to optimize HTML table rendering</a></li>
-</ul>
-
-<h3 id="Data_representation">Data representation</h3>
-
-<ul>
- <li><a href="/en-US/docs/Learn/HTMLHowto/Represent_numeric_values_with_HTML">How to represent numeric values with HTML</a></li>
- <li><a href="/en-US/docs/Learn/HTML/Howto/Use_data_attributes">How to use data attributes</a></li>
- <li><a href="/en-US/docs/Learn/HTML/Howto/Associate_human_readable_content_with_arbitrary_computer_data_structures">How to associate human readable content with arbitrary computer data structures</a></li>
-</ul>
-</div>
-
-<div class="column-half">
-<h3 id="Advanced_text_semantics">Advanced text semantics</h3>
-
-<ul>
- <li><a href="/en-US/docs/Learn/HTML/Howto/Take_control_of_HTML_line_breaking">How to take control of HTML line breaking</a></li>
- <li><a href="/en-US/docs/Learn/HTML/Howto/Mark_text_insertion_and_deletion">How to mark changes (added and removed text)</a></li>
-</ul>
-
-<h3 id="Advanced_images_multimedia">Advanced images &amp; multimedia</h3>
-
-<ul>
- <li><a href="/en-US/docs/Learn/HTML/Multimedia_and_embedding/Responsive_images">How to add responsive image to a webpage</a></li>
- <li><a href="/en-US/docs/Learn/HTML/Multimedia_and_embedding/Adding_vector_graphics_to_the_Web">How to add vector image to a webpage</a></li>
- <li><a href="/en-US/docs/Learn/HTML/Howto/Add_a_hit_map_on_top_of_an_image">How to add a hit map on top of an image</a></li>
-</ul>
-
-<h3 id="Internationalization">Internationalization</h3>
-
-<p>HTML is not monolingual. It provides tools to handle common internationalization issues.</p>
-
-<ul>
- <li><a href="/en-US/docs/Learn/HTML/Howto/Add_multiple_languages_into_a_single_webpage">How to add multiple languages into a single webpage</a></li>
- <li><a href="/en-US/docs/Learn/HTML/Howto/Handle_Japanese_ruby_characters">How to handle Japanese ruby characters</a></li>
- <li><a href="/en-US/docs/Learn/HTML/Howto/Display_time_and_date_with_HTML">How to display time and date with HTML</a></li>
-</ul>
-
-<h3 id="Performance">Performance</h3>
-
-<ul>
- <li><a href="/en-US/docs/Learn/HTML/Howto/Author_fast-loading_HTML_pages">How to author fast-loading HTML pages</a></li>
-</ul>
-</div>
-</div>
-
-<p><span class="hidden"> </span><span class="hidden"> </span><span class="hidden"> </span><span class="hidden"> </span> </p>
diff --git a/files/he/learn/html/index.html b/files/he/learn/html/index.html
deleted file mode 100644
index df97989e28..0000000000
--- a/files/he/learn/html/index.html
+++ /dev/null
@@ -1,58 +0,0 @@
----
-title: 'Learning HTML: Guides and tutorials'
-slug: Learn/HTML
-tags:
- - Beginner
- - Guide
- - HTML
- - Intro
- - Learn
- - NeedsTranslation
- - Topic
- - TopicStub
-translation_of: Learn/HTML
----
-<div>{{LearnSidebar}}</div>
-
-<p class="summary">To build websites, you should know about {{Glossary('HTML')}} — the fundamental technology used to define the structure of a webpage. HTML is used to specify whether your web content should be recognized as a paragraph, list, heading, link, image, multimedia player, form, or one of many other available elements or even a new element that you define.</p>
-
-<h2 id="Learning_pathway">Learning pathway</h2>
-
-<p>Ideally, you should start your learning journey by learning HTML. Start by reading <a href="/en-US/docs/Web/Guide/HTML/Introduction">Introduction to HTML</a>. You may then move on to learning about more advanced topics such as:</p>
-
-<ul>
- <li><a href="/en-US/docs/Learn/CSS">CSS</a>, and how to use it to style HTML (for example alter your text size and fonts used, add borders and drop shadows, layout your page with multiple columns, add animations and other visual effects.)</li>
- <li><a href="/en-US/docs/Learn/JavaScript">JavaScript</a>, and how to use it to add dynamic functionality to web pages (for example find your location and plot it on a map, make UI elements appear/disappear when you toggle a button, save users' data locally on their computers, and much much more.)</li>
-</ul>
-
-<p>Before starting this topic, you should have at least basic familiarity with using computers and using the web passively (i.e. just looking at it, consuming the content). You should have a basic work environment set up as detailed in <a href="/en-US/docs/Learn/Getting_started_with_the_web/Installing_basic_software">Installing basic software</a>, and understand how to create and manage files, as detailed in <a href="/en-US/docs/Learn/Getting_started_with_the_web/Dealing_with_files">Dealing with files</a> — both are parts of our <a href="/en-US/docs/Learn/Getting_started_with_the_web">Getting started with the web</a> complete beginner's module.</p>
-
-<p>It is recommended that you work through <a href="/en-US/docs/Learn/Getting_started_with_the_web">Getting started with the web </a>before attempting this topic, however, it isn't absolutely necessary; much of what is covered in the <a href="/en-US/docs/Learn/Getting_started_with_the_web/HTML_basics">HTML basics</a> article is also covered in our <a href="/en-US/docs/Learn/HTML/Introduction_to_HTML">Introduction to HTML</a> module, albeit in a lot more detail.</p>
-
-<h2 id="Modules">Modules</h2>
-
-<p>This topic contains the following modules, in a suggested order for working through them. You should definitely start with the first one.</p>
-
-<dl>
- <dt><a href="/en-US/docs/Learn/HTML/Introduction_to_HTML">Introduction to HTML</a></dt>
- <dd>This module sets the stage, getting you used to important concepts and syntax, looking at applying HTML to text, how to create hyperlinks, and how to use HTML to structure a webpage.</dd>
- <dt><a href="/en-US/docs/Learn/HTML/Multimedia_and_embedding">Multimedia and embedding</a></dt>
- <dd>This module explores how to use HTML to include multimedia in your web pages, including the different ways that images can be included, and how to embed video, audio, and even entire other webpages.</dd>
- <dt><a href="/en-US/docs/Learn/HTML/Tables">HTML Tables</a></dt>
- <dd>Representing tabular data on a webpage in an understandable, {{glossary("Accessibility", "accessible")}} way can be a challenge. This module covers basic table markup, along with more complex features such as implementing captions and summaries.</dd>
- <dt><a href="/en-US/docs/Learn/HTML/Forms">HTML Forms</a></dt>
- <dd>Forms are a very important part of the Web — these provide much of the functionality you need for interacting with websites, e.g. registering and logging in, sending feedback, buying products, and more. This module gets you started with creating the client-side parts of forms.</dd>
-</dl>
-
-<h2 id="Solving_common_HTML_problems">Solving common HTML problems</h2>
-
-<p><a href="/en-US/docs/Learn/HTML/Howto">Use HTML to solve common problems</a> provides links to sections of content explaining how to use HTML to solve very common problems when creating a webpage: dealing with titles, adding images or videos, emphasizing content, creating a basic form, etc.</p>
-
-<h2 id="See_also">See also</h2>
-
-<div class="document-head" id="wiki-document-head">
-<dl>
- <dt><a href="/en-US/docs/Web/HTML">HTML (HyperText Markup Language)</a> on MDN</dt>
- <dd>The main entry point for HTML documentation on MDN, including detailed element and attribute references — if you want to know what attributes an element has or what values an attribute has, for example, this is a great place to start.</dd>
-</dl>
-</div>
diff --git a/files/he/learn/html/introduction_to_html/index.html b/files/he/learn/html/introduction_to_html/index.html
deleted file mode 100644
index d81e82b56b..0000000000
--- a/files/he/learn/html/introduction_to_html/index.html
+++ /dev/null
@@ -1,56 +0,0 @@
----
-title: מבוא לשפת HTML
-slug: Learn/HTML/Introduction_to_HTML
-translation_of: Learn/HTML/Introduction_to_HTML
-original_slug: Learn/HTML/מבוא_לשפת_HTML
----
-<div>{{LearnSidebar}}</div>
-
-<p class="summary">At its heart, {{glossary("HTML")}} is a fairly simple language made up of <a href="/en-US/docs/Glossary/Element">elements</a>, which can be applied to pieces of text to give them different meaning in a document (Is it a paragraph? Is it a bulleted list? Is it part of a table?), structure a document into logical sections (Does it have a header? Three columns of content? A navigation menu?), and embed content such as images and videos into a page. This module will introduce the first two of these, and introduce fundamental concepts and syntax you need to know to understand HTML.</p>
-
-<h2 id="Prerequisites">Prerequisites</h2>
-
-<p>Before starting this module, you don't need any previous HTML knowledge, but you should have at least basic familiarity with using computers and using the web passively (i.e., just looking at it and consuming content). You should have a basic work environment set up (as detailed in <a href="https://developer.mozilla.org/en-US/docs/Learn/Getting_started_with_the_web/Installing_basic_software">Installing basic software</a>), and understand how to create and manage files (as detailed in <a href="https://developer.mozilla.org/en-US/docs/Learn/Getting_started_with_the_web/Dealing_with_files">Dealing with files</a>). Both are parts of our <a href="https://developer.mozilla.org/en-US/docs/Learn/Getting_started_with_the_web">Getting started with the web</a> complete beginner's module.</p>
-
-<div class="note">
-<p><strong>Note</strong>: If you are working on a computer/tablet/other device that doesn't let you create your own files, you can try out (most of) the code examples in an online coding program such as <a href="http://jsbin.com/">JSBin</a> or <a href="https://thimble.mozilla.org/">Thimble</a>.</p>
-</div>
-
-<h2 id="Guides">Guides</h2>
-
-<p>This module contains the following articles, which will take you through all the basic theory of HTML and provide ample opportunity for you to test out some skills.</p>
-
-<dl>
- <dt><a href="/en-US/docs/Learn/HTML/Introduction_to_HTML/Getting_started">Getting started with HTML</a></dt>
- <dd>Covers the absolute basics of HTML, to get you started — we define elements, attributes, and other important terms, and show where they fit in the language. We also show how a typical HTML page is structured and how an HTML element is structured, and explain other important basic language features. Along the way, we'll play with some HTML to get you interested!</dd>
- <dt><a href="/en-US/docs/Learn/HTML/Introduction_to_HTML/The_head_metadata_in_HTML">What’s in the head? Metadata in HTML</a></dt>
- <dd>The <a href="/en-US/docs/Glossary/Head">head</a> of an HTML document is the part that <strong>is not</strong> displayed in the web browser when the page is loaded. It contains information such as the page {{htmlelement("title")}}, links to {{glossary("CSS")}} (if you want to style your HTML content with CSS), links to custom favicons, and metadata (data about the HTML, such as who wrote it, and important keywords that describe the document).</dd>
- <dt><a href="/en-US/docs/Learn/HTML/Introduction_to_HTML/HTML_text_fundamentals">HTML text fundamentals</a></dt>
- <dd>One of HTML's main jobs is to give text meaning (also known as <a href="/en-US/docs/Glossary/Semantics">semantics</a>), so that the browser knows how to display it correctly. This article looks at how to use HTML to break up a block of text into a structure of headings and paragraphs, add emphasis/importance to words, create lists, and more.</dd>
- <dt><a href="/en-US/docs/Learn/HTML/Introduction_to_HTML/Creating_hyperlinks">Creating hyperlinks</a></dt>
- <dd>Hyperlinks are really important — they are what makes the web a web. This article shows the syntax required to make a link, and discusses best practices for links.</dd>
- <dt><a href="/en-US/docs/Learn/HTML/Introduction_to_HTML/Advanced_text_formatting">Advanced text formatting</a></dt>
- <dd>There are many other elements in HTML for formatting text that we didn't get to in the <a href="/en-US/docs/Learn/HTML/Introduction_to_HTML/HTML_text_fundamentals">HTML text fundamentals</a> article. The elements in here are less well-known, but still useful to know about. In this article you'll learn about marking up quotations, description lists, computer code and other related text, subscript and superscript, contact information, and more.</dd>
- <dt><a href="/en-US/docs/Learn/HTML/Introduction_to_HTML/Document_and_website_structure">Document and website structure</a></dt>
- <dd>As well as defining individual parts of your page (such as "a paragraph" or "an image"), HTML is also used to define areas of your website (such as "the header," "the navigation menu," or "the main content column.") This article looks into how to plan a basic website structure and how to write the HTML to represent this structure.</dd>
- <dt><a href="/en-US/docs/Learn/HTML/Introduction_to_HTML/Debugging_HTML">Debugging HTML</a></dt>
- <dd>Writing HTML is fine, but what if something goes wrong, and you can't work out where the error in the code is? This article will introduce you to some tools that can help.</dd>
-</dl>
-
-<h2 id="Assessments">Assessments</h2>
-
-<p>The following assessments will test your understanding of the HTML basics covered in the guides above.</p>
-
-<dl>
- <dt><a href="/en-US/docs/Learn/HTML/Introduction_to_HTML/Marking_up_a_letter">Marking up a letter</a></dt>
- <dd>We all learn to write a letter sooner or later; it is also a useful example to test out text formatting skills. In this assessment you'll be given a letter to mark up.</dd>
- <dt><a href="/en-US/docs/Learn/HTML/Introduction_to_HTML/Structuring_a_page_of_content">Structuring a page of content</a></dt>
- <dd>This assessment tests your ability to use HTML to structure a simple page of content, containing a header, a footer, a navigation menu, main content, and a sidebar.</dd>
-</dl>
-
-<h2 id="See_also">See also</h2>
-
-<dl>
- <dt><a href="https://teach.mozilla.org/activities/web-lit-basics/">Web literacy basics 1</a></dt>
- <dd>An excellent Mozilla foundation course that explores and tests a lot of the skills talked about in the <em>Introduction to HTML</em> module. Learners get familiar with reading, writing, and participating on the web in this six-part module. Discover the foundations of the web through production and collaboration.</dd>
-</dl>
diff --git a/files/he/learn/html/tables/index.html b/files/he/learn/html/tables/index.html
deleted file mode 100644
index a3e36d0d44..0000000000
--- a/files/he/learn/html/tables/index.html
+++ /dev/null
@@ -1,35 +0,0 @@
----
-title: טבלאות HTML
-slug: Learn/HTML/Tables
-translation_of: Learn/HTML/Tables
-original_slug: Learn/HTML/טבלאות
----
-<div>{{LearnSidebar}}</div>
-
-<p class="summary">A very common task in HTML is structuring tabular data, and it has a number of elements and attributes for just this purpose. Coupled with a little <a href="/en-US/docs/Learn/CSS">CSS</a> for styling, HTML makes it easy to display tables of information on the web such as your school lesson plan, the timetable at your local swimming pool, or statistics about your favorite dinosaurs or football team. This module takes you through all you need to know about structuring tabular data using HTML.</p>
-
-<h2 id="Prerequisites">Prerequisites</h2>
-
-<p>Before starting this module, you should already have covered the basics of HTML — see <a href="/en-US/docs/Learn/HTML/Introduction_to_HTML">Introduction to HTML</a>.</p>
-
-<div class="note">
-<p><strong>Note</strong>: If you are working on a computer/tablet/other device where you don't have the ability to create your own files, you could try out (most of) the code examples in an online coding program such as <a href="http://jsbin.com/">JSBin</a> or <a href="https://thimble.mozilla.org/">Thimble</a>.</p>
-</div>
-
-<h2 id="Guides">Guides</h2>
-
-<p>This module contains the following articles:</p>
-
-<dl>
- <dt><a href="/en-US/docs/Learn/HTML/Tables/Basics">HTML table basics</a></dt>
- <dd>This article gets you started with HTML tables, covering the very basics such as rows and cells, headings, making cells span multiple columns and rows, and how to group together all the cells in a column for styling purposes.</dd>
- <dt><a href="/en-US/docs/Learn/HTML/Tables/Advanced">HTML table advanced features and accessibility</a></dt>
- <dd>In the second article in this module, we look at some more advanced features of HTML tables — such as captions/summaries and grouping your rows into table head, body and footer sections — as well as looking at the accessibility of tables for visually impaired users.</dd>
-</dl>
-
-<h2 id="Assessments">Assessments</h2>
-
-<dl>
- <dt><a href="/en-US/docs/Learn/HTML/Tables/Structuring_planet_data">Structuring planet data</a></dt>
- <dd>In our table assessment, we provide you with some data on the planets in our solar system, and get you to structure it into an HTML table.</dd>
-</dl>
diff --git a/files/he/learn/index.html b/files/he/learn/index.html
deleted file mode 100644
index 792ffac056..0000000000
--- a/files/he/learn/index.html
+++ /dev/null
@@ -1,98 +0,0 @@
----
-title: מדריך Web Development
-slug: Learn
-translation_of: Learn
----
-<div class="summary">
-<p>ברוכים הבאים לאזור הלמידה של MDN. קבוצה זו של מאמרים שואפת לספק לאנשים חסרי רקע בתכנות את הכלים הדרושים על מנת להתחיל לפתח אתרי אינטרנט ויישומי אינטרנט..</p>
-
-<p>מטרתו של אזור זה של MDN היא לא לקחת אתכם מ-"מתחילים" -"מומחה" אלא לקחת אתכם מ-"מתחילים" ל"נוח". משם אתם אמורים להיות מסוגלים להתקדם בכוחות עצמכם, ללמוד מיתר התכנים באתר שלנו ובאתרים אחרים.</p>
-
-<p>אם אתם חסרי רקע לחלוטין בתכנות חשוב להבין ש-web development יכול להיות מאתגר - אנו נסייע כמה שניתן על מנת לספק מספיק פרטים כדי שתוכלו להרגיש בנוח וללמוד את הנושאים כראוי.</p>
-</div>
-
-<div class="warning">
-<p><strong>חשוב</strong>: התוכן באיזור הלמידה מתעדכן באופן שוטף. אם יש לכם שאלות בנוגע לנושאים שאנו דנים בהם או שתרצו שנוסיף נושאים חדשים, הרגישו חופשי ליצור עמנו קשר ב {{anch("Contact us")}}</p>
-</div>
-
-<h2 id="היכן_להתחיל">היכן להתחיל?</h2>
-
-<p>אנחנו רוצים לפגוש אותך היכן שאתה נמצא. מה מהתיאורים הבאים מתאים לך יותר?</p>
-
-<ul class="card-grid">
- <li><span>מתחילים - הכרות ראשונית עם סביבת האינטרנט</span>
-
- <p>אם אתם חסרי רקע ב-web development אנחנו ממליצים לכם להתחיל עם מודול  <a href="/he/Learn/Getting_started_with_the_web">"מתחילים עם סביבת אינטרנט"</a> אשר מספק את כל הבסיס וההקדמה כדי ל-web development.</p>
- </li>
- <li><span>מתקדמים - הכרות עם HTML ו-CSS</span>
- <p>אם כבר יש לכם את ידע הבסיס, ואתם רוצים להתקדם ללמוד {{glossary("HTML")}} ו - {{glossary("CSS")}} יותר לעומק, אנו ממליצים לכם על סדרת המודולים בנושא <a href="https://developer.mozilla.org/he/docs/Learn/HTML">HTML</a> - וסדרת המודולים בנושא <a href="https://developer.mozilla.org/he/docs/Learn/CSS">CSS</a> שלנו. </p>
- </li>
- <li><span>מתקדמים - הכרות עם JavaScript</span>
- <p>אם אתם מרגישים כבר בנוח עם HTML ועם CSS, או אם אתם מעוניינים בעיקר ללמוד את שפת התכנות JavaScript, אנו ממליצים ללכת להתקדם לסדרת המודולים בנושא <a href="/he/docs/Learn/JavaScript">JavaScript — Dynamic client-side scripting</a> או ל-<a href="https://developer.mozilla.org/he/docs/Learn/Server-side">Server-side website programming</a>. אנחנו נשמח גם אם תסייעו להרחיב את <a href="/he/Learn/How_to_contribute">איזור הלמידה</a>. </p>
- </li>
- <li><span>Frameworks and tooling:</span>
- <p>לאחר שליטה בסיסית ב  HTML, CSS, ו JavaScript כדאי ללמוד על <a href="https://wiki.developer.mozilla.org/en-US/docs/Learn/Tools_and_testing/Understanding_client-side_tools">client-side web development tools</a>, and then consider digging into <a href="https://wiki.developer.mozilla.org/en-US/docs/Learn/Tools_and_testing/Client-side_JavaScript_frameworks">client-side JavaScript frameworks</a>, and <a href="https://wiki.developer.mozilla.org/en-US/docs/Learn/Server-side">server-side website programming</a>. </p>
- </li>
-</ul>
-
-<div class="note">
-<p><strong>הערה:</strong> ה<a href="/he/docs/Glossary">מילון </a>שלנו מכיל הסבר לכל מונח וביטוי. נסו להפיק ממנו את המירב.</p>
-</div>
-
-<p>{{LearnBox({"title":"Random glossary entry"})}}</p>
-
-<h2 id="נושאי_הלימוד">נושאי הלימוד</h2>
-
-<p>אלו הנושאים שנגע בהם באיזור הלימוד של MDN:</p>
-
-<dl>
- <dt><a href="/he/docs/Learn/Getting_started_with_the_web">תחילת הדרך עם ה-Web</a></dt>
- <dd>מספק הכרות בסיסית ומעשית לפיתוח אינטרנט עבור מתחילים וחסרי רקע.</dd>
- <dt><a href="/en-US/docs/Learn/HTML">HTML - בונים את האינטרנט </a></dt>
- <dd>HTML זו השפה שבה אנחנו משתמשים על מנת לתת מבנה לתוכן שלנו ולהגדיר מה המשמעות שלהם או מטרתם. נושא זה מלמד את שפת HTML לעומק.  </dd>
- <dt><a href="/he/docs/Learn/CSS">CSS - מעצבים את האינטרנט</a></dt>
- <dd>CSS היא השפה שאנחנו משתמשים בה על מנת לעצב את התוכן שלנו ועל מנת לפרוס את התוכן שלנו באתר, כמו גם להוסיף הנפשות ואנימציות שונות. נושא זה מלמד היבטים רבים של שפת CSS והכלים העומדים לרשותנו. </dd>
- <dt><a href="/he/docs/Learn/JavaScript">JavaScript - תכנות צד לקוח </a></dt>
- <dd>JavaScript היא שפת תכנות דינאמית אשר משמשת על מנת להוסיף פונקציונליות דינאמית לאתרי אינטרנט. נושא זה מלמד את כל הכלים והנושאים הנדרשים על מנת להבין ולכתוב בשפת  JavaScript.</dd>
- <dt><a href="https://wiki.developer.mozilla.org/en-US/docs/Learn/Forms">Web forms — Working with user data</a></dt>
- <dd>Web forms are a potent tool for interacting with users — most commonly, they are used for collecting data from users, or allowing them to control a user interface. In the articles listed below, we'll cover all the essential aspects of structuring, styling, and interacting with web forms.</dd>
- <dt><a href="https://wiki.developer.mozilla.org/en-US/docs/Learn/Accessibility">נגישות אתרים</a></dt>
- <dd>נגישות אתרים זה מושג המאגד בתוכו מספר פרקטיקות מקובלות אשר מטרתן היא להפוך את התוכן ברשת לנגיש עבור כמה שיותר אנשים, ללא השפעה של מוגבלות פיזית, סוג המכשיר, מיקום וגורמים נוספים. נושא זה נוגע בכל מה שאתם צריכים לדעת בנושא.</dd>
- <dt><a href="https://wiki.developer.mozilla.org/en-US/docs/Learn/Performance">Web Performance - הפיכת האתר למהיר ורספונסיבי</a></dt>
- <dd>ביצועים זו האמנות של הפיכת אתרי אינטרנט ויישומים מבוססי web למהירים ורספונסיביים לאינטראקציות של המשתמש, ללא השפעה של מהירות הגלישה של המשתמש, גודל המסך, הגבלות מכשיר וכד׳. </dd>
- <dt><a href="https://wiki.developer.mozilla.org/en-US/docs/Learn/Tools_and_testing">כלים ובדיקות</a></dt>
- <dd>נושא זה מכסה את כל הכלים שמפתחים צריכים על מנת לבחון ולבדוק את הפיתוח שלהם. </dd>
- <dt><a href="https://wiki.developer.mozilla.org/en-US/docs/Learn/Server-side">תכנות צד-שרת</a></dt>
- <dd>גם אם אתם מתרכזים בפיתוח צד-לקוח, יהיה זה שימושי והכרחי מאוד עבורכם להבין מהם שרתים ומהו קוד של צד השרת וכיצד הם עובדים יחד. נושא זה מעניק הכרות כללית כיצד צד השרת עובד, ומדריכים מפורטים המראים כיצד לבנות יישום צד שרת באמצעות שתי פריימוורקים פופולרים - Django (Python) and Express (node.js). </dd>
-</dl>
-
-<h2 id="דוגמאות_הקוד_שלנו">דוגמאות הקוד שלנו</h2>
-
-<p>כל דוגמאות הקוד שלנו זמינים כמובן גם ב-<a href="https://github.com/mdn/learning-area/">GitHub</a>. אם תרצו להוריד עותק מרוכז שלהם למחשב, תוכלו להוריד <a href="https://github.com/mdn/learning-area/archive/master.zip">קובץ ZIP</a> מרוכז.</p>
-
-<p>אם אתם מעדיפים להעתיק את המאגר בדרך יותר מורכבת אך מאפשרת לכם לקבל עדכונים אוטומטיים לדוגמאות הקוד, ראו ההסבר בשפה האנגלית <a href="https://developer.mozilla.org/en-US/docs/Learn">פה</a>. </p>
-
-<h2 id="צרו_עמנו_קשר">צרו עמנו קשר</h2>
-
-<p>אם תרצו ליצור עמנו קשר בכל נושא, הדרך הטובה ביותר היא ב-<a href="https://discourse.mozilla-community.org/t/learning-web-development-marking-guides-and-questions/16294">learning area discourse thread</a> או בערוצי ה-<a href="https://developer.mozilla.org/en-US/docs/MDN/Community/Conversations#Chat_in_IRC">IRC</a>. היינו רוצים לשמוע האם לדעתכם חסר משהו באתר, או נושא לא מוסבר לעומק או לא ברור וכמובן אם מצאתם שגיאה. כמובן, הרגישו חופשי לפנות בכל שאלה או בעיה. </p>
-
-<p>אם אתם מעוניינים לעזור ולפתח את התוכן פה באתר שלנו שלנו, ראו את המאמר בנושא <a href="/e he/Learn/How_to_contribute">how you can help</a> וצרו עמנו קשר. אנחנו יותר מנשמח לדבר אתכם בנושא בין אם אתם סטודנטים, מורים, מפתחים מנוסים או סתם בא לכם לעזור לשפר את חווית הלמידה של הגולשים באתר.</p>
-
-<h2 id="ראו_גם">ראו גם</h2>
-
-<dl>
- <dt><a href="https://www.mozilla.org/en-US/newsletter/developer/">Mozilla developer newsletter</a></dt>
- <dd>הניוזלטר שלנו למפתחי Web - מקור מידע מעולה לכל רמות הניסיון. </dd>
- <dt><a href="https://www.youtube.com/playlist?list=PLo3w8EB99pqLEopnunz-dOOBJ8t-Wgt2g">Web demystified</a></dt>
- <dd>סדרה מצויינת של סרטוני וידאו המסבירה את הבסיס של פיתוח Web, נועדה בעיקר לחסרי רקע. נוצרה על ידי  <a href="https://twitter.com/JeremiePat">Jérémie Patonnier</a>.</dd>
- <dt><a href="https://www.codecademy.com/">Codecademy</a></dt>
- <dd>אתר אינטראקטיבי מעולה ללימוד שפות תכנות מהבסיס.</dd>
- <dt><a href="https://code.org/">Code.org</a></dt>
- <dd>אתר בסיסי לתכנות אשר נועד בעיקר לחסרי רקע/ילדים.</dd>
- <dt><a href="https://www.freecodecamp.org/">freeCodeCamp.org</a></dt>
- <dd>אתר אינטראקטיבי מעולה ללימוד פיתוח Web.</dd>
- <dt><a href="https://learning.mozilla.org/activities">Teaching activities</a></dt>
- <dd>A series of teaching activities for teaching (and learning) created by the Mozilla Foundation, covering everything from basic web literacy and privacy to JavaScript and hacking Minecraft.</dd>
- <dt><a href="https://edabit.com/">Edabit</a></dt>
- <dd>Hundreds of free interactive coding challenges in various languages.</dd>
-</dl>
diff --git a/files/he/learn/javascript/asynchronous/concepts/index.html b/files/he/learn/javascript/asynchronous/concepts/index.html
deleted file mode 100644
index 273c184474..0000000000
--- a/files/he/learn/javascript/asynchronous/concepts/index.html
+++ /dev/null
@@ -1,203 +0,0 @@
----
-title: עקרונות תכנות א-סינכרוני כלליים
-slug: Learn/JavaScript/Asynchronous/Concepts
-translation_of: Learn/JavaScript/Asynchronous/Concepts
----
-<div>{{LearnSidebar}}{{NextMenu("Learn/JavaScript/Asynchronous/Introducing", "Learn/JavaScript/Asynchronous")}}</div>
-
-<p>
- במאמר זה אנחנו נעבור על מספר עקרונות חשובים בנושא תכנות א-סינכרוני וכיצד זה נראה בדפדפנים וב-JavaScript. חשוב להבין עקרונות אלו לפני שממשיכים למאמרים הבאים במודול זה.
-</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>Basic computer literacy, a reasonable understanding of JavaScript fundamentals.</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>
- הבנה של העקרונות הבסיסיים מאחורי תכנות א-סינכרוני וכיצד אלו באים לידי ביטוי בדפדפנים וב-JavaScript.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Asynchronous_-_א-סינכרוני">Asynchronous - א-סינכרוני?</h2>
-
-<p>
- באופן נורמלי, קוד של תוכנית רץ בצורה עצמאית, כאשר רק דבר אחד קורה בכל רגע נתון. אם פונקציה מסויימת נשנעת על התוצאה של פונקציה אחרת, היא חייבית לחכות לפונקציה האחרת לסיים ולהחזיר את התוצאה ועד שזה לא קורה, כל התוכנית עוצרת מנקודת מבטו של המשתמש.</p>
-
-<p>Mac אלו המשתמשים ב-, לדוגמא,
- לפעמים רואים עיגול צבעוני... עיגול זה בעצם אומר למשתמש ״התוכנית הנוכחית שאתה מתמש בה הייתה צריכה לעצור ולחכות שמשהו הסתיים, וזה לוקח זמן..״ </p>
-
-<p><img alt="multi-colored macos beachball busy spinner" src="https://mdn.mozillademos.org/files/16577/beachball.jpg" style="display: block; margin: 0 auto;"></p>
-
-<p>
- זו חווית שימוש מעצבנת, ולא ממש שימוש יעיל ביכולות המחשב, במיוחד בעידן שלמחשבים יש מספר ליבות מעבד זמינות. אין שום סיבה שאנחנו נחכה למשהו כשאנחנו יכולים להמשיך במקביל בעבודה שלנו בזמן שהמחשב עובד על אותה פעולה ויעדכן אותנו כשהפעולה הסתיימה. זה מאפשר לנו לבצע פעולות אחרות במקביל, וזה בעיקרון הבסיס של תכנות א-סינכרוני - <strong>asynchronous programming</strong>. זה תלוי בסביבת הפיתוח שבה אנחנו משתמשים (דפדני אינטרנט במקרה שלנו) להעניק למפתח APIs שיאפשרו לנו להריץ משימות באופן א-סינכרוני
-
-
- </p>
-
-<h2 id="Blocking_code">Blocking code</h2>
-
-<p>
- טכניקות א-סינכרוניות הן שימושיות מאוד, במיוחד בפיתוח web. כאשר יישום web רץ בדפדפן ומריץ שורות קוד מבלי להחזיר את השליטה לדפדפן, הדפדפן יכול להיראות כאילו הוא ״קפא״. זה נקרא <strong>blocking</strong>. הדפדפן חסום מלהמשיך ולטפל בפעולות מצד המשתמש ולבצע פעולות נוספות עד אשר יישום ה-web מחזיר את השליטה למעבד.</p>
-
-<p>
- נסתכל על מספר דוגמאות על מנת להסביר למה אנחנו מתכוונים ב- blocking
-
-</p>
-
-<p>ב <a href="https://github.com/mdn/learning-area/tree/master/javascript/asynchronous/introducing">simple-sync.html</a> דוגמא שלנו (<a href="https://mdn.github.io/learning-area/javascript/asynchronous/introducing/simple-sync.html">או כ דף אינטרנט</a>),
-
- הוספנו מאזין אירוע מסוג click לכפתור כך שבכל פעם שהכפתור יילחץ, הוא יריץ פעולה שלוקחת המון זמן (מחשבת 10 מיליון תאריכים ואז מחזירה את האחרון לקונסולה) ולאחר מכן מוסיפה פסקה ל-DOM: </p>
-
-<pre class="brush: js">const btn = document.querySelector('button');
-btn.addEventListener('click', () =&gt; {
- let myDate;
- for(let i = 0; i &lt; 10000000; i++) {
- let date = new Date();
- myDate = date
- }
-
- console.log(myDate);
-
- let pElem = document.createElement('p');
- pElem.textContent = 'This is a newly-added paragraph.';
- document.body.appendChild(pElem);
-});</pre>
-
-<p>
- כשאתם מריצים את הדוגמא למלעלה, פתחו את הקונסולה ואז לחצו על הכפתור - אתם תשימו לב שהפסקה אינה מופיעה עד אשר חישוב התאיריכים הסתיים והוצגה ההודעה לקונסולה. הקוד רץ בסדר שבה הוא מופיע בקוד המקור והפעולה האחרונה לא תרוץ עד אשר הפעולה הקודמת לא סיימה.</p>
-
-<div class="blockIndicator note">
-<p><strong>לתשומת לב</strong>: הדוגמא הקודמת דיי לא מציאותית. אנחנו לעול לא נחשב 10 מיליון תאריכים בתוכנית אמיתית. דוגמא זו נועדה לתת לכם רק את ההבנה של תכנות א-סינכרוני. </p>
-</div>
-
-<p>בדוגמא השנייה שלנו, <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/introducing/simple-sync-ui-blocking.html">simple-sync-ui-blocking.html</a> (<a href="https://mdn.github.io/learning-area/javascript/asynchronous/introducing/simple-sync-ui-blocking.html">ראו כדף אינטרנט</a>),
- אנחנו מנסים לדמות משהו קצת יותר ריאלי שאתם אולי תיתקלו בו בדף אמיתי. אנחנו חוסמים את האינטראקציה של המשתמש עם העיבוד של ממשק המשתמש. בדוגמא זו יש לנו שני כפתורים:</p>
-
-<ul>
- <li>כפתור בשם "Fill canvas" אשר כאשר הוא נלחץ, אלמנט ה- {{htmlelement("canvas")}} מתמלא במיליון כדורים כחולים. </li>
- <li>כפתור בשם "Click me for alert" אשר כאשר הוא נלחץ מופיעה הודעה למשתמש</li>
-</ul>
-
-<pre class="brush: js">function expensiveOperation() {
- for(let i = 0; i &lt; 1000000; i++) {
- ctx.fillStyle = 'rgba(0,0,255, 0.2)';
- ctx.beginPath();
- ctx.arc(random(0, canvas.width), random(0, canvas.height), 10, degToRad(0), degToRad(360), false);
- ctx.fill()
- }
-}
-
-fillBtn.addEventListener('click', expensiveOperation);
-
-alertBtn.addEventListener('click', () =&gt;
- alert('You clicked me!')
-);</pre>
-
-<p>
- אם תלחצו עלהכפתור הראשון ואז ישר לאחר מכן על השני אתם תראו שההודעה למשתמש לא מופיע עד אשר העיגולים לא סיימו להיות מעובדים. הפעולה הראשונה חוסמת את ביצוע הפעולה השנייה עד אשר הפעולה הראשונה תסתיים. </p>
-
-<div class="blockIndicator note">
-<p><strong>לתשומת לב</strong>:
- זהו אמנם נראה לא טוב, אך זוהי רק דוגמא למה שמפתחים נתקלים בה ביישומים אמיתיים. </p>
-</div>
-
-<p>
- מדוע זה קורה? התשובה נעוצה בכך ש-JavaScript היא <strong>single threaded</strong>. בנקודה, אנחנו נרצה להציג בפניכם את הרעיון של <strong>threads</strong>.</p>
-
-<h2 id="Threads">Threads</h2>
-
-<p><strong>Thread</strong> הוא בעיקרון תהליך יחיד שתוכנית יכולה להשתמש בה על מנת להשלים משימות. כל תהליך כזה יכול לבצע משימה אחת בכל פעם: </p>
-
-<pre>Task A --&gt; Task B --&gt; Task C</pre>
-
-<p>
- כל משימה תרוץ באופן טורי, רציף, אך לא סימולטני. משימה צריכה להסתיים כדי שהבאה בתור תחל בריצה. </p>
-
-<p>
- כפי שאמרנו מקודם, הרבה מחשבים הם בעלי מספר רב של ליבות, כך שהם יכולים לבצע מספר דברים בבת אחת. שפות תכנות שתומכות בליבות מרובות יכולות להתשמש בליבות אלו על מנת לבצע מספר פעולות באופן סימולטני ובמקביל: </p>
-
-<pre>Thread 1: Task A --&gt; Task B
-Thread 2: Task C --&gt; Task D</pre>
-
-<h3 id="JavaScript_-_single_threaded">JavaScript - single threaded</h3>
-
-<p>JavaScript היא single-threaded.
- אפילו אם יש מספר ליבות, אנחנו יכולים רק להריץ משימה על thread יחיד, שנקרא <strong>main thread</strong>. הדוגמא שלנו מלמעלה מורצת כך: </p>
-
-<pre>Main thread: Render circles to canvas --&gt; Display alert()</pre>
-
-<p>
- לאחר זמן מסויים, JavaScript קיבלה מס׳ כלים על מנת להתמודד עם בעיות אלו.
-
- <a href="/en-US/docs/Web/API/Web_Workers_API">Web workers</a>
- מאפשר לנו לשלוח חלק מהביצוע של JavaScript ל-thread נפרד שנקרא בשם worker, כך שאנחנו יכולים להריץ קודי JavaScript באופן סימולטני מקביל. בדרך כלל אנחנו נשתמש ב-worker להריץ תהליכי
-
- allow you to send some of the JavaScript processing off to a separate thread, called a worker, so that you can run multiple JavaScript chunks simultaneously. You'd generally use a worker to run expensive processes off the main thread so that user interaction is not blocked.</p>
-
-<pre> Main thread: Task A --&gt; Task C
-Worker thread: Expensive task B</pre>
-
-<p>
- כעת, לאחר שאנחנו יודעים זאת, נסתכל על <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/introducing/simple-sync-worker.html">simple-sync-worker.html</a> או <a href="https://mdn.github.io/learning-area/javascript/asynchronous/introducing/simple-sync-worker.html">כדף אינטרנט</a>, ונפתח את הקונסולה.
- בקובץ זה כתבנו מחדש את הדוגמא שלנו לחישוב 10 מיליון תאריכים בworker thread נפרד. כעת כשאנחנו לוחצים על הכפתור, הדפדן מסוכל להציג את הפסקה לפני שחישוב התאיריכים הסתיימו. הפעולה הראשונה כבר לא חוסמת את הפעולה השנייה.
-
- </p>
-
-<h2 id="Asynchronous_code_קוד_א-סינכרוני">Asynchronous code קוד א-סינכרוני</h2>
-
-<p>Web workers הם מאוד שימושיים, אבל יש להם הגבלות.
- אחת מהן היא שהם לא יכולים לגשת ל-{{Glossary("DOM")}} - אנחנו לא יכולים לגרום ל-worker לעשות שום דבר שיכול לעדכן את ממשק המשתמש, את ה-UI. אנחנו לא נוכל לעבד מיליון כדורים כחולים בתוך ה-worker שלנו. הוא בעיקרון יכול רק לעשות מניפולציות מספריות.
-</p>
-
-<p>
- הבעיה השנייה היא שלמרות שהקוד שרץ בתוך ה-000000 לא חוסם, הוא עדיין בסופו של דבר סינכרוני. זה הופך לבעיה כשאר פונקציה מתבססת על התוצאה של חישובים של תהליכים שקדמו לפונקציה. הסתכלו על התרשים הבא:</p>
-
-<pre>Main thread: Task A --&gt; Task B</pre>
-
-<p>
- במקרה זה, משימה A עושה משהו כמו הבאת תמונה מהשרת, ואז משימה B עושה משהו עם התמונה הזו, כגון החלת פילטר. אם אנחנו נתחיל את משימה A ואז ישר נריץ את משימה B , אנחנו נקבל שגיאה כי התמנוה עדיין לא זמינה, כי משימה A לא הסתיימה עדיין. </p>
-
-<pre> Main thread: Task A --&gt; Task B --&gt; |Task D|
-Worker thread: Task C -----------&gt; | |</pre>
-
-<p>
- במקרה הזה לדוגמא, יש לנו את משימה D שמבצעת שימוש בתוצאות של משימה B ומשימה C. אם אנחנו יכולים להבטיח שהתוצאות של שתי משימות אלו יהיהו זמינות בואתו הזמן, אז זה יכול להיות תקין, אבל זה בדרך כלל לא קורה. אם משימה D תנסה לרוץ לפני שהערכים שהיא צריכה לקבל זמינים עבורה, זה יחזיר לנו רוב הסיכויים שגיאה.</p>
-
-<p>
- על מנת לתקן בעיות שכאלו, דפדנים מאפשרים לנו להריץ מס׳ פעולות באופן א-סינכרוני. תכונות כמו <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise">Promises</a> מאפשרות לנו לקבוע משימה שתרוץ, כמו לדוגמא הבאת תמונה מהשרת, ולחכות עד אשר התוצאה של אותה משימה תוחזר שנריץ פעולה מסויימת אחרת.</p>
-
-<pre>Main thread: Task A Task B
- Promise: |__async operation__|</pre>
-
-<p>
- מאחר שהפעולה מתרחשת במקום אחר, ה-main thread לא חסום בזמן שהפעולה הא-סינכרונית מתרחשת.
-
-</p>
-
-<p>
- אנחנו נסתכל כיצד אנחנו יכולים לרשום קוד א-סינכרוני במאמר הבא.
- </p>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>
- עיצוב תוכנה מודרני סובב יותר ויותר סביב שימוש בתכנות א-סינכרוני, כדי לאפשר לתוכניות לעשות יותר מדבר אחד בכל פעם. כאשר נשתמש ב-API חדשים ובעלי יכולות מתקדמות, אנחנו נמצא יותר מקרים שבהם הדרך היחידה לבצע משהו מסויים היא רק באופן א-סינכרוני. זה היה דיי קשה בעבר לכתוב קוד א-סינכרוני. אמנם עדיין לוקח זמן להתרגל לכך, אבל זה נעשה הרבה יותר קל. ביתר המאמרים במודול זה אנחנו נסביר מדוע קוד א-סינכרוני הוא רלוונטי וחשוב וכיצד נעצב את הקוד על מנת להימנע מחלק מהבעיות שסקרנו במאמר זה.
-
-
- יותר מדבר אחד בכל פעם. כשאתה משתמש בממשקי API חדשים וחזקים יותר, תמצא מקרים נוספים שבהם הדרך היחידה לעשות דברים היא בצורה אסינכרונית. פעם היה קשה לכתוב קוד אסינכרוני. זה עדיין לוקח להתרגל, אבל זה נעשה הרבה יותר קל. בשאר מודול זה נבדוק יותר מדוע חשוב קוד אסינכרוני וכיצד לתכנן קוד שנמנע מכמה מהבעיות שתוארו לעיל.</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Concepts">עקרונות תכנות א-סינכרוני כלליים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Introducing">הצגת asynchronous JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Timeouts_and_intervals">Asynchronous JavaScript: שימוש ב-Intervals ו-Timeouts</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Promises">טיפול בפעולות א-סינכרוניות באמצעות Promises</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Async_await">הפיכת Asynchronous Programming לקל יותר עם async ועם await</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Choosing_the_right_approach">בחירת האפשרות המתאימה</a></li>
-</ul>
diff --git a/files/he/learn/javascript/asynchronous/index.html b/files/he/learn/javascript/asynchronous/index.html
deleted file mode 100644
index 01ec7babb7..0000000000
--- a/files/he/learn/javascript/asynchronous/index.html
+++ /dev/null
@@ -1,43 +0,0 @@
----
-title: Asynchronous JavaScript
-slug: Learn/JavaScript/Asynchronous
-translation_of: Learn/JavaScript/Asynchronous
----
-<div>{{LearnSidebar}}</div>
-
-<p class="summary"><span class="seoSummary">במודות זה אנחנו נסתכל על {{Glossary("asynchronous")}} {{Glossary("JavaScript")}}, ומדוע זה חשוב, וכיצד אנחנו יכולים להשתמש בזה על מנת לטפל בפעולות חוסמות () כמו הבאת משאבים מהשרת.</span></p>
-
-<h2 id="Prerequisites">Prerequisites</h2>
-
-<p>Asynchronous JavaScript הוא יחסית נושא מתקדם ואנו ממליצים לכם לעבור על המודולים <a href="/he/docs/Learn/JavaScript/First_steps"> צעדים ראשונים ב-JavaScript</a> ועל<a href="/he/docs/Learn/JavaScript/Building_blocks"> אבני הבניין של </a> <a href="/he/docs/Learn/JavaScript/Building_blocks">JavaScript </a>לפני שתתחילו ללמוד מודול זה.</p>
-
-<p>אם אינכם בקיאים בקונספט של תכנות א-סינכרוני, אנא התחילו עם המאמר <a href="/he/docs/Learn/JavaScript/Asynchronous/Concepts">עקרונות תכנות א-סינכרוני</a> במודול זה. אם אתם כן בקיאים, אתם ככל הנראה יכולים להתחיל ב-<a href="/he/docs/Learn/JavaScript/Asynchronous/Introducing">הצגת Asynchronous JavaScript</a>.</p>
-
-<div class="note">
-<p><strong>הערה</strong>: אם אתם עובדים על מחשב\טבלט\מכשיר אחר שאין לכם אפשרות ליצור עליו קבצים אישיים, אתם יכולים לנסות את (רוב) דוגמאות הקוד על תוכנות קוד אינטרנטיות כמו <a href="http://jsbin.com/">JSBin</a> או <a href="https://thimble.mozilla.org/">Thimble</a>.</p>
-</div>
-
-<h2 id="מדריכים">מדריכים</h2>
-
-<dl>
- <dt><a href="/he/docs/Learn/JavaScript/Asynchronous/Concepts">עקרונות תכנות א-סינכרוני כלליים</a> </dt>
- <dd>
- <p>במאמר זה אנחנו נעבור על מספר עקרונות חשובים בנושא תכנות א-סינכרוני וכיצד עקרונות אלו באים לידי ביטוי בדפדפנים וב-JavaScript. אתם אמורים להבין עקרונות אלו בטרם תמשיכו למאמרים נוספים במודול זה.</p>
- </dd>
- <dt><a href="/he/docs/Learn/JavaScript/Asynchronous/Introducing">הצגת Asynchronous JavaScript</a></dt>
- <dd>במאמר זה נסקור בקצרה את הבעיות הקשורות ל-JavaScript סינכרונית, ונסתכל לראשונה על האופציות השונות ב-JavaScript א-סינכרוני שניתקל בהן, ונראה כיצד טכניקות אלו יכולות לפתור לנו בעיות.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/Asynchronous/Loops_and_intervals">Asynchronous JavaScript: שימוש ב-Intervals ו-Timeouts </a></dt>
- <dd>במאמר זה נסתכל על המתודות המסורתיות שקיימות ב-JavaScript להרצת קוד בצורה א-סינכרונית לאחר שזמן מסויים עבר או בקבועי זמן מסויימים ונדון במקרים שהם רלוונטיים לשימוש וכן נדון בסוגיות הטבועות בהם.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/Asynchronous/Promises">טיפול בפעולות א-סינכרוניות באמצעות Promises </a></dt>
- <dd>Promises הם בעיקרון תכונה חדשה יחסית של שפת JavaScript המאפשרת לך לדחות פעולות נוספות עד      לאחר השלמת הפעולה הקודמת, או להגיב לכישלונה. זה מאוד שימושי להגדרת רצף של פעולות שיעבדו בצורה מסויימת. מאמר זה מראה לך כיצד promises עובדות, היכן תראה אותן בשימוש ב- WebAPIs,      ואיך לכתוב promises משלך.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/Asynchronous/Async_await">הפיכת Asynchronous Programming לקל יותר עם async ועם await</a></dt>
- <dd>Promises יכולות להיות קצת מורכבות לביצוע והבנה, ודפדפנים מודרניים הטמיעו את הפונקציות <code>async</code> ואת האופרטור <code>await</code> - הראשון מאפשר לפונקציות סטנדרטיות להתנהג בצורה עקיפה כא-סינכרוניות עם Promises ואילו בשני אנחנו יכולים לעשות שימוש בתוך פונקציות <code>async</code> על מנת לחכות ל-promises לפני שהפונקציה ממשיכה, כך שנוכל לקשור promises בצורה קלה יותר. מאמר זה מסביר את <code>async</code>/<code>await</code>.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/Asynchronous/Choosing_the_right_approach">בחירת האפשרות המתאימה</a></dt>
- <dd>בסיום המודול אנחנו נדון בהבדלים שבין הטכניקות השונות שנגענו בהם, ונדון באיזו טכניקה יהיה מומלץ להשתמש במקרים השונים.</dd>
-</dl>
-
-<h2 id="ראו_גם">ראו גם</h2>
-
-<ul>
- <li><a href="https://eloquentjavascript.net/11_async.html">Asynchronous Programming</a> ב- <a href="https://eloquentjavascript.net/">Eloquent JavaScript</a> ספר אינטרנטי של Marijn Haverbeke.</li>
-</ul>
diff --git a/files/he/learn/javascript/asynchronous/introducing/index.html b/files/he/learn/javascript/asynchronous/introducing/index.html
deleted file mode 100644
index 3f5a342e1e..0000000000
--- a/files/he/learn/javascript/asynchronous/introducing/index.html
+++ /dev/null
@@ -1,281 +0,0 @@
----
-title: הצגת asynchronous JavaScript
-slug: Learn/JavaScript/Asynchronous/Introducing
-translation_of: Learn/JavaScript/Asynchronous/Introducing
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/Asynchronous/Concepts", "Learn/JavaScript/Asynchronous/Timeouts_and_intervals", "Learn/JavaScript/Asynchronous")}}</div>
-
-<p class="summary">במאמר זה אנחנו נסקור שוב את הבעיות הקשורות ב-Synchronous JavaScript, ונסתכל לראשונה על הטכניקות לא-סינכרוניות שניתקל בהן, וכיצד הן יכולות לסייע לנו לפתור בעיות אלו.</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>Basic computer literacy, a reasonable understanding of JavaScript fundamentals.</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>להבין מהי שAsynchronous JavaScript וכיצד היא שונה מ-Synchronous JavaScript, ומתי להשתמש בה.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Synchronous_JavaScript">Synchronous JavaScript</h2>
-
-<p>על מנת שנוכל להבין מה זה <strong>{{Glossary("asynchronous")}}</strong> JavaScript אנחנו צריכים תחילה להבין מה זה <strong>{{Glossary("synchronous")}}</strong> JavaScript. חלק זה של המאמר יסקור שוב חלק מהמידע שכבר עברנו עליו במאמר הקודם.</p>
-
-<p>הרבה מהפונקציונליות שראינו במודולים הקודמים של מדריך זה היו דיי סינכרוניים - אנחנו מריצים קוד מסויים והתוצאה של אותה ריצה מוחזרת כאשר הדפדפן יכול להחזיר את התוצאה. נסתכל כעת על דוגמא פשוטה ב-<a href="https://mdn.github.io/learning-area/javascript/asynchronous/introducing/simple-sync.html">דף זה</a>, <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/introducing/simple-sync.html">או בקוד המקור</a>:</p>
-
-<pre class="brush: js notranslate">const btn = document.querySelector('button');
-btn.addEventListener('click', () =&gt; {
- alert('You clicked me!');
-
- let pElem = document.createElement('p');
- pElem.textContent = 'This is a newly-added paragraph.';
- document.body.appendChild(pElem);
-});
-</pre>
-
-<p>בקוד זה, השורות מורצות אחת אחרי השנייה:</p>
-
-<ol>
- <li>אנחנו יוצרים הפנייה לאלמנט {{htmlelement("button")}} שכבר זמין ב-DOM.</li>
- <li>אנחנו מוסיפים מטפל אירוע בשם <code><a href="/en-US/docs/Web/API/Element/click_event">click</a></code> כך שכאשר הכפתור נלחץ:
- <ol>
- <li>הודעת <code><a href="/en-US/docs/Web/API/Window/alert">()alert</a></code> מוצגת למשתמש.</li>
- <li>ברגע שהודעה זו נסגרת, אנחנו יוצרים אלמנט {{htmlelement("p")}}.</li>
- <li>לאחר מכן אנחנו מכניסים לתוך האלמנט  {{htmlelement("p")}} תוכן.</li>
- <li>בסוף אנחנו משייכים את ה- {{htmlelement("p")}} ל-body.</li>
- </ol>
- </li>
-</ol>
-
-<p>בעוד שכל תהליך שכזה נמצא בהרצה או עיבוד, שום דבר אחר לא יכול להתרחש - יתר העיבוד מושהה. זה מכיוון שכפי שראינו ב<a href="/he/docs/Learn/JavaScript/Asynchronous/Introducing">מאמר הקודם</a> ש-<a href="/en-US/docs/Learn/JavaScript/Asynchronous/Concepts#JavaScript_is_single_threaded">JavaScript היא single threaded</a>. רק דבר אחד יכול להתרחש בכל פעם על ה-single main thread, וכל היתר חסום לביצוע או לעיבוד עד אשר אותה פעולה תושלם.</p>
-
-<p>בדוגמא למעלה, אחרי שלחצנו על הכפתור, הפסקה לא הופיעה עד לאחר שכפתור ה-OK לא נלחץ בחלונית הקופצת. אתם יכולים לנסות זאת בעצמכם:</p>
-
-<div class="hidden">
-<pre class="brush: html notranslate">&lt;<span class="pl-ent">button</span>&gt;Click me&lt;/<span class="pl-ent">button</span>&gt;</pre>
-</div>
-
-<p>{{EmbedLiveSample('Synchronous_JavaScript', '100%', '70px')}}</p>
-
-<div class="blockIndicator note">
-<p><strong>לתשומת לב</strong>: חשוב לזכור שאמנם <code><a href="/en-US/docs/Web/API/Window/alert">()alert</a></code> מאוד שימושי לשם הסבר על פעולות סינכרוניות שחוסמות את המשך הפעילות, זוהי פונקציה שאינה בשימוש רב ביישומים אמיתיים מטעמים של חווית משתמש לרוב.</p>
-</div>
-
-<h2 id="Asynchronous_JavaScript">Asynchronous JavaScript</h2>
-
-<p>לאור הסיבות שנסקרו למעלה, הרבה Web API משתמשים בקוד א-סינכרוני על מנת לפעול, במיוחד אלו שניגשים או מביאים משאב מסויים מגורם חיצוני, כמו הבאה של קובץ מהרשת, גישה למאגר מידע והחזרת מידע מתוכו, הפעלת של הזרמת וידאו באמצעות מצלמת רשת וכד׳.</p>
-
-<p>מדוע העבודה עם קוד א-סינכרוני היא מורכבת? נסתכל על דוגמא זריזה. כאשר אנחנו מבקשים תמונה משרת מסויים, איננו יכולים לקבל את התשובה באופן מיידי. זה אומר שהפסאודו-קוד הרשום להלן לא יעבוד:</p>
-
-<pre class="brush: js notranslate">var response = fetch('myImage.png');
-var blob = response.blob();
-// display your image blob in the UI somehow</pre>
-
-<p>זה מכיוון שאנחנו לא יודעים כמה זמן ייקח לתמונה להגיע מהשרת, אז כאשר אנחנו נרצה להריץ את שורת הקוד הבאה, היא תחזיר לנו שגיאה (אולי לסירוגין, אולי בכל פעם) מכיוון שה-<code>response</code> אינו זמין עבורנו עדיין. במקום זאת, אנחנו צריכים שהקוד שלנו יחכה ל-<code>response</code> שיוחזר אלינו לפני שאנחנו מנסים לעשות עם <code>response</code> פעולה כלשהי.</p>
-
-<p>יש שני סוגים עיקריים של קוד א-סינכרוני שאנחנו ניתקל בהם בקוד javascript, יש את ה-callbacks הותיקים ואת ה-promises החדשים יותר.  במאמר זה נסקור את שניהם.</p>
-
-<h2 id="Async_callbacks">Async callbacks</h2>
-
-<p>Async callbacks אלו פונקציות המועברות כפרמטר (ארגומנט) לפונקציה אחרת, כאשר אנחנו קוראים לפונקציה אחרת אשר מריצה קוד ברקע. כאשר הקוד שברקע סיים לרוץ, הוא קורא לאותן פונקציות callbacks על מנת לציין שהפעולה שהייתה ברקע הסתיימה או לציין שמשהו הסתיים.</p>
-
-<p>שימוש ב-callbacks יחסית נחשב מיושן כעת, אבל אנחנו עדיין נראה שימוש רב שלהם ב-APIs ישנים אבל עדיין מאוד שימושיים.</p>
-
-<p>דוגמא ל-async callback אפשר לראות בפרמטר השני של {{domxref("EventTarget.addEventListener", "addEventListener()")}} (כפי שראינו בפעולה למעלה):</p>
-
-<pre class="brush: js notranslate">btn.addEventListener('click', () =&gt; {
- alert('You clicked me!');
-
- let pElem = document.createElement('p');
- pElem.textContent = 'This is a newly-added paragraph.';
- document.body.appendChild(pElem);
-});</pre>
-
-<p>הפרמטר הראשון הוא הסוג של האירוע שאנחנו רוצים להאזין להתרחשות שלו, והפרמטר השני הוא פונקציית callback שמופעלת ברגע שהאירוע מתרחש.</p>
-
-<p>כאשר אנחנו מעבירים callback function כפרמטר לפונקציה אחרת, אנחנו רק מעבירים את הגדרת הפונקציה כפרמטר, כלומר ה-callback function לא מופעל באופן מיידי. הוא נקרא לאחר מכן (“called back”) באופן א-סינכרוני איפשהו בתוך הגוף של הפונקציה שקיבלה אותו כפרמטר. הפונקציה שקיבלה אותו כפרמטר היא האחראית להפעיל את ה-callback function כשנצטרך.</p>
-
-<p>אנחנו יכולים לכתוב פונקציות משלנו שיכילו callback function באופן דיי פשוט יחסית. נסתכל על דוגמא שמעלה משאב באמצעות <a href="/en-US/docs/Web/API/XMLHttpRequest"><code>XMLHttpRequest</code> API</a> (<a href="https://mdn.github.io/learning-area/javascript/asynchronous/introducing/xhr-async-callback.html">דף האינטרנט</a>, ו- <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/introducing/xhr-async-callback.html">קוד המקור</a>):</p>
-
-<pre class="brush: js notranslate">function loadAsset(url, type, callback) {
- let xhr = new XMLHttpRequest();
- xhr.open('GET', url);
- xhr.responseType = type;
-
- xhr.onload = function() {
- callback(xhr.response);
- };
-
- xhr.send();
-}
-
-function displayImage(blob) {
- let objectURL = URL.createObjectURL(blob);
-
- let image = document.createElement('img');
- image.src = objectURL;
- document.body.appendChild(image);
-}
-
-loadAsset('coffee.jpg', 'blob', displayImage);</pre>
-
-<p>כאן יצרנו את פונקציית <code>()displayImage</code> שפשוט מקבלת blob שמועבר אליה ויוצרת לו URL באמצעות URL.createObjectURL(blob). לאחר מכן הפונקציה יוצרת אלמנט HTML מסוג <code>img</code>, משימה לו את הערך של ה-<code>src</code> לאותו URL שנוצר לנו ומשייכת את ה-image ל-body. </p>
-
-<p>בנוסף, יצרנו פונקציה בשם <code>()loadAsset</code> שמקבלת כפרמטרים כתובת URL, סוג הקובץ וכן פונקציית callback (שימו לב שהשם שנתנו לפרמטר - <code>callback</code> - הוא לשם הנוחות בלבד וניתן לקרוא לפרמטר זה בכל שם). פונקציית <code>()displayImage</code> משתמשת ב-<code>XMLHttpRequest</code> (לרוב משתמשים בקיצור שלו - "XHR") על מנת להביא משאב מ-URL מסויים לפני שמעבירים את התגובה של אותה <code>XMLHttpRequest</code> לפונקציית callback שלנו - לפונקציית  <code>()displayImage</code>.</p>
-
-<p>במקרה הזה, פונקציית ה-callback שלנו מחכה ש-XHR יסיים להוריד את המשאב שהוא הביא (באמצעות שימוש במטפל אירוע מסוג <code><a href="/en-US/docs/Web/API/XMLHttpRequestEventTarget/onload">onload</a></code>), וזאת לפני שהיא תקבל את המשאב.</p>
-
-<p>Callbacks הם מאוד ורסטיליים - לא רק שהם מאפשרים לנו לשלוט בסדר שבו פונקציות ירוצו ואיזה מידע יועבר ביניהן, הן גם מאפשרות לנו להעביר מידע לפונקציות שונות בהתאם לנסיבות. כך שאנחנו יכולים להריץ פעולות שונות על המשאב שהתקבל או התגובה שהתקבלה כמו <code>processJSON()</code>, <code>displayText()</code>, וכד׳. </p>
-
-<p>שימו לב שלא כל ה-Callbacks הם א-סינכרוניים וחלקם הם סינכרוניים. כך לדוגמא, כאשר אנחנו משתמשים ב- {{jsxref("Array.prototype.forEach()")}} על מנת לעבור באמצעות לולאה על איברים במערך (<a href="https://mdn.github.io/learning-area/javascript/asynchronous/introducing/foreach.html">ראו כדף אינטרנט</a>, וכן <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/introducing/foreach.html">את קוד המקור</a>):</p>
-
-<pre class="brush: js notranslate">const gods = ['Apollo', 'Artemis', 'Ares', 'Zeus'];
-
-gods.forEach(function (eachName, index){
- console.log(index + '. ' + eachName);
-});</pre>
-
-<p>בדוגמא זו, אנחנו עוברים על מערך של Greek gods ומדפיסים את מספרי האינדקס והערכים לקונסולה. הפרמטר שאנחנו נותנים ל-<code>()forEach</code> הוא פונקציית callback, אשר בעצמו מקבל שני פרמטרים, שם הפריט במערך ומספר האינדקס. יחד עם זאת, היא  לא מחכה לשום דבר, היא פשוט רצה באופן אוטומטי. </p>
-
-<h2 id="Promises">Promises</h2>
-
-<p>Promises אלו בעצם הסגנון החדש לקוד א-סינכרוני שאנחנו נראה שמבוצע בהם שימוש ב-Web APIs מודרניים. דוגמא טובה לכך היא <code><a href="/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch">fetch()</a></code> API, אשר הוא בעצם כמו גרסה מודרנית ויעילה יותר של {{domxref("XMLHttpRequest")}}. נסתכל על דוגמא מהמאמר שלנו בנושא <a href="/he/docs/Learn/JavaScript/Client-side_web_APIs/Fetching_data">הבאת מידע מהשרת</a> אשר תגיעו אליו בהמשך:</p>
-
-<pre class="brush: js notranslate">fetch('products.json').then(function(response) {
-  return response.json();
-}).then(function(json) {
-  products = json;
-  initialize();
-}).catch(function(err) {
-  console.log('Fetch problem: ' + err.message);
-});</pre>
-
-<div class="blockIndicator note">
-<p><strong>לתשומת לב</strong>: אתם יכולים למצוא את הגרסה הסופית ב- GitHub (<a href="https://github.com/mdn/learning-area/blob/master/javascript/apis/fetching-data/can-store-xhr/can-script.js">ראו כאן את קוד המקור</a>, וגם <a href="https://mdn.github.io/learning-area/javascript/apis/fetching-data/can-store-xhr/">כדף אינטרנט</a>).</p>
-</div>
-
-<p>כאן אנחנו רואים ש-<code>fetch</code><code>()</code> לוקח פרמטר אחד - את ה-URL של המשאב שנאחנו רוצים להביא מהרשת - והוא מחזיר <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise">promise</a>. ה-promise היא בעצם אובייקט המייצג השלמה או כישלון של פעולת ה-שaysync. בצורה מסויימת, זו הדרך של הדפדפן להגיד ״אני מבטיח לחזור אליך עם תשובה ברגע שאוכל״. מכאן השם promise.</p>
-
-<p>צריך להתרגל לרעיון הזה על ידי תרגול. זה מרגיש קצת מוזר בהתחלה, כמו החתול של שרדינגר - {{interwiki("wikipedia", "Schrödinger's cat")}}. אף אחת מהאפשרויות לא קרתה עדיין, אז פעולת ההבאה - פעולת ה-fetch, כרגע מחכה לתוצאה של פעולת הדפדפן - להשלמה שלה בעתיד. לאחר מכן שיש לנו שלושה קודי בלוק שמשורשרים לסוף <code>fetch()</code>:</p>
-
-<ul>
- <li>שני בלוקים של <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/then">then()</a></code>. שניהם מכילים callback function שתרוץ אם הפעולה שקדמה לה הצליחה, וכל callback מקבל כקלט, את התוצאה של הפעולה המוצלחת הקודמת, כך שאנחנו יכולים להמשיך ולעשות עם התוצאה משהו. כל <code>.then()</code> מחזיר הבטחה - promise נוספת, כלומר אנחנו יכולים לקשור כמה וכמה בלוקי קוד של <code>.then()</code> אחד לשני, כך שיהיוה הרבה פעולות א-סינכרוניות שירוצו בסדר מסויים, אחת אחרי השנייה.</li>
- <li>בלוק הקוד של <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/catch">catch()</a></code> בסוף ירוץ אם אחד מהבלוקים של <code>.then()</code> ייכשל - בדרך דומה ל-<code><a href="/en-US/docs/Web/JavaScript/Reference/Statements/try...catch">try...catch</a></code> הסינכרוני. אובייקט שגיאה - error object - ייהפך לזמין בתוך ה-<code>catch()</code>, והוא יוכל לשמש עבור דיווח על סוג השגיאה שהתרחשה. שימו לב כי promises הסינכרוני לא עובד עם <code>try...catch</code>, למרות שהוא כן יעבוד עם <a href="/en-US/docs/Learn/JavaScript/Asynchronous/Async_await">async/await</a>, כפי שנראה בהמשך המאמר.</li>
-</ul>
-
-<div class="blockIndicator note">
-<p><strong>לתשומת לב</strong>: אתם תלמדו עוד הרבה על promises בהמשך המודול הזה, אז אל דאגה אם לא הבנתם אותם עד הסוף. זוהי רק סקירה.</p>
-</div>
-
-<h3 id="The_event_queue">The event queue</h3>
-
-<p>פעולות א-סינכרוניות כמו promises מושמות לתוך ה-<strong>event queue</strong>, אשר רץ לאחר שה-main thread סיים את העיבודים שלו, כך שהם לא יחסמו קוד JavaScript שבא אחריהם. הפעולות שב-promises יושלמו ברגע שיתאפשר, ויחזירו את התוצאה שלהן לסביבת הjavascript. Async operations like promises are put into an <strong>event queue</strong>, which runs after the main thread has finished processing so that they <em>do not block</em> subsequent JavaScript code from running. The queued operations will complete as soon as possible then return their results to the JavaScript environment.</p>
-
-<h3 id="Promises_מול_callbacks">Promises מול callbacks</h3>
-
-<p>ל-Promises יש קצת דמיון ל-callbacks הוותיקים. הם בעיקרון אבוייקט שהוחזר, אליו אנחנו מחברים פונקציות callbacks, ולא צריכים להעביר callbacks לתוך פונקציה.</p>
-
-<p>יחד עם זאת, promises נוצרו במיוחד עבור טיפול בפעולת א-סינכרוניות, ויש להם הרבה יתרונות על ה-callbacks הוותיקים:</p>
-
-<ul>
- <li>ראשית, אנחנו יכולים לקשור מספר פעולות א-סינכרוניות ביחד באמצעות שימוש בכמה <code>.then()</code>, והעברה התוצאה של אחד כקלט של זה שאחריו. זה הרבה יותר קשה לביצוע עם callbacks, מה שבדרך מסתיים עם "pyramid of doom", אשר ידוע גם כ-ה</li>
- <li>Promise callbacks תמיד ייקראו בסדר שבו הם מושמים ב- event queue.</li>
- <li>Error טיפול ב- הוא הרבה יותר קל - כל השגיאות מטופלות על ידי בלוק <code>.catch()</code> אחד בסוף הבדלוק, ולא באמצעות טיפול בכל שלב של ה-פירמידה.</li>
- <li>Avoid inversion control: unlike callbacks will lose full control of how the function will be executed when passing a callback to a third-party library. <a href="https://www.youtube.com/watch?v=bAlczbDUXx8">A great demonstration</a> by Stevie Jay.</li>
-</ul>
-
-<h2 id="ההתנהגות_של_קוד_א-סינכרוני">ההתנהגות של קוד א-סינכרוני</h2>
-
-<p>בואו נעמיק בדוגמא שתסביר לנו יותר לעומק את ההתהנגות של קוד א-סינכרוני, שמראה מה יכול לקראת כשאנחנו לא בקיאים לגמי בסדר של הרצת הקוד וההבעיות שיש בניסיון לטפל בקוד א-סינכרוני כמו בקוד סינכרוני. הודמא הבא היא יחסית דומה למה שראינו בעבר. <a href="https://mdn.github.io/learning-area/javascript/asynchronous/introducing/async-sync.html">sכדף אינטרנט</a>, וגם <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/introducing/async-sync.html">קוד המקור</a>). הבדל אחד הוא שכללנו מספר ביטויים של {{domxref("console.log()")}} על ממנת להמחיש את הסדר שאנחנו נחשוב שבו הקוד ירוץ</p>
-
-<pre class="brush: js notranslate">console.log ('Starting');
-let image;
-
-fetch('coffee.jpg').then((response) =&gt; {
- console.log('It worked :)')
- return response.blob();
-}).then((myBlob) =&gt; {
- let objectURL = URL.createObjectURL(myBlob);
- image = document.createElement('img');
- image.src = objectURL;
- document.body.appendChild(image);
-}).catch((error) =&gt; {
- console.log('There has been a problem with your fetch operation: ' + error.message);
-});
-
-console.log ('All done!');</pre>
-
-<p>הדפדפן יתחיל להריץ את הקוד, הוא יראה את ה-<code>console.log()</code> הראשון ויריץ אותו. ולאחר מכן ייצור את המשתנה <code>image</code> .</p>
-
-<p>הוא לאחר מכן ימשיך לשורה הבאה, ויתחיל להריץ את הבלוק קוד של <code>fetch()</code>, אבל מכיוון ש-<code>fetch()</code> מורץ באופן א-סינכרוני בלי חסימה, הדפדפן ימשיך לקוד שלאחר הקוד של ה-promise-related code, ולכן יגיע ל-<code>console.log()</code> האחרון ( <code>All done!</code>) ואותו יציג לקונסולה. ימשיך לרוץ</p>
-
-<p>רק ברגע שהבלוק של ה-code&gt;fetch() סיים לחלוטין לרוץ והביא תוצאה - result באמצעות הבלוקים של <code>.then()</code>, אנחנו נראה לבסוף את הההודעה שב-<code>console.log()</code> השני (<code>It worked ;)</code>). כך שההודעות הופיעו בסדר שונה ממה שאולי חשבתם:</p>
-
-<ul>
- <li>Starting</li>
- <li>All done!</li>
- <li>It worked :)</li>
-</ul>
-
-<p>אם זה מבלבל אתכם, הסתכלו על הדוגמא הבאה:</p>
-
-<pre class="brush: js notranslate">console.log("registering click handler");
-
-button.addEventListener('click', () =&gt; {
- console.log("get click");
-});
-
-console.log("all done");</pre>
-
-<p>זה מאוד דומה בהתנהגות - ה-<code>console.log()</code> הראשון והשלישי יציגו את ההודעות שלהן מיד, אבל ה-<code>console.log()</code> השני יהיה חסום להצגה עד אשר מישהו ילחץ על הכפתור. הדוגמא הקודמת פועלת בדרך דוה, למעט כך שבמקרה שההודעה השנייה חסומה בשרשרת ההבטחות המביאות משאב מסויים ומוצגת רק כאשר שרשרת ההבטטחות הושלמה, ולא כאשר המשתמש ילחץ על כפתור. .</p>
-
-<p>בדוגמה של קוד פחות טריוויאלי, קוד מהסוג של הדוגמא הראשונה עלולה לגרום לבעיה - אינכם יכולים לכלול בלוק קוד אסינכרוני המחזיר תוצאה, עליה אתם מסתמכים בהמשך בבלוק קוד סינכרוני. אינכם כולים להבטיח שפונקציית ה-שaysync תחזור לפני שהדפדפן יעבד את חסימת האסינכרון.</p>
-
-<p>על מנת לראות זאת בפעולה, נסו לעשות עותק מקומי של To see this in action, try taking a local copy of <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/introducing/async-sync.html">הדוגמאו תשלנו</a>, ושנו את ה- <code>console.log()</code> שלישית כך:</p>
-
-<pre class="brush: js notranslate">console.log ('All done! ' + image + 'displayed.');</pre>
-
-<p>אתם אמורים לקבל שגיאה בקונסולה במקום ההודעה השלישית :</p>
-
-<pre class="notranslate"><span class="message-body-wrapper"><span class="message-flex-body"><span class="devtools-monospace message-body">TypeError: image is undefined; can't access its "src" property</span></span></span></pre>
-
-<p>זה מכיוון שבזמן שהדפדפן מנסה להריץ את ה-<code>console.log()</code> השלישית, הבלוק קוד של <code>fetch()</code> עדיין לא סיים לרות, כך שהמשתנה <code>image</code> לא ניתן לו ערך עדיין.</p>
-
-<h2 id="למידה_עצמאית_פכו_את_הכל_ל-_async!">למידה עצמאית: פכו את הכל ל- async!</h2>
-
-<p>על מנת לתקן את ה- <code>fetch()</code>, ולהפוך את שלושת -<code>console.log()</code> להיות מופעים בסדר הרצוי, אתם יכולים לעשות את ה-<code>console.log()</code> השלישי שירוץ גם הוא בצורה א-סינכרוני. את זה ניתן לעשות באמצעות העברה שלו לתוך <code>.then()</code> אחר, אשר משורשר לתוך הסוף של ה-<code>.then()</code> השני, או באמצעות פשוט העברה שלו לתוך ה-<code>.then()</code> השני. נסו לתקן זאת.</p>
-
-<div class="blockIndicator note">
-<p><strong>לתשומת לב</strong>: אם נתקעתם, אתם יכולים למצוא את התשובה <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/introducing/async-sync-fixed.html">כאן</a> או כ <a href="https://mdn.github.io/learning-area/javascript/asynchronous/introducing/async-sync-fixed.html">דף אינטרנט</a> also). אתם גם יכולים למצוא עוד הרבה על promises במדריך שלנו בנושא <a href="/en-US/docs/Learn/JavaScript/Asynchronous/Promises">טיפול בפעולות א-סינכרוניות באמצעות Promises</a>, בהמשך המודול הזה.</p>
-</div>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>במבנה הבסיסי שלה, JavaScript היא סינכרונית, שפה single-threaded,כך רק פעולה אחת יכולה להיות מעובדת בכל זמן נתון. יחד עם זאת, הדפדפנים הגדירו פונקציות ו-APIs שמאפשרים לנו לרשום פונקציות שלא ירוצו באופן סינכרוני, ובמקום זאת, יופעלו באופן א-סינכרוני כאשר אירוע מסויים מתרחש. זה אומר שאנחנו יכולים לתת לקוד שלנו לעשות דברים אחרים באותו הזמן, מבלי לחסום או לעצור את ה-main thread.</p>
-
-<p>בין אם אנחנו רוצים להירץ קוד באופן סינכרוני או א-סינכרוני, זה תלוי במה שאנחנו מנסים לעשות.</p>
-
-<p>יש פעמים שאנחנו נרצה שדברים יועלו ויתרחשו במיידי. לדוגמא, כאשר המתשמש מגדיר סגנון לאתר ואתם רוצים שהסגנון יוחל באופן מיידי.</p>
-
-<p>אם אנחנו מריצים פעולה מסויימת שלוקח לה זמן, כמו לדוגמא גישה למאגר מידע ושימוש בתוצאות על מנת ליצור תבניות לדגומא, זה יהיה עדיף להעביר את הפעולה הזו מחוץ ל-main thread, כך שתתצבע באופן א-סינכרוני. עם הזמן, אתם תלמדו מתי זה היה הגיוני לבחור בטכניקה א-סינכרונית ולא בסינכורנית.</p>
-
-<ul>
-</ul>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/Asynchronous/Concepts", "Learn/JavaScript/Asynchronous/Timeouts_and_intervals", "Learn/JavaScript/Asynchronous")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Concepts">עקרונות תכנות א-סינכרוני כלליים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Introducing">הצגת asynchronous JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Timeouts_and_intervals">Asynchronous JavaScript: שימוש ב-Intervals ו-Timeouts</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Promises">טיפול בפעולות א-סינכרוניות באמצעות Promises</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Async_await">הפיכת Asynchronous Programming לקל יותר עם async ועם await</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Choosing_the_right_approach">בחירת האפשרות המתאימה</a></li>
-</ul>
diff --git a/files/he/learn/javascript/asynchronous/promises/index.html b/files/he/learn/javascript/asynchronous/promises/index.html
deleted file mode 100644
index 87c8839084..0000000000
--- a/files/he/learn/javascript/asynchronous/promises/index.html
+++ /dev/null
@@ -1,589 +0,0 @@
----
-title: Graceful asynchronous programming with Promises
-slug: Learn/JavaScript/Asynchronous/Promises
-translation_of: Learn/JavaScript/Asynchronous/Promises
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/Asynchronous/Timeouts_and_intervals", "Learn/JavaScript/Asynchronous/Async_await", "Learn/JavaScript/Asynchronous")}}</div>
-
-<p class="summary"><span class="seoSummary"><strong>Promises</strong> הן תכונה חדשה יחסית ב-JavaScript, אשר מאפשרת לנו לדחות פעולות מסוייומות עד אשר פעולותדמות להן יושלמו, או שיגיבו לכך שהן נכשלו. זוהי תכונה מאוד שימושית על מנת ליצור רצף של פעולות א-סינכרוניות שיעבדו בצור הטובה. מאמר זה נועד להסביר כיצד promises עובדות, כיצד אנו נראה אותם בשימוש ב-web APIs וכיצד נכתוב promises משלנו. </span></p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>Basic computer literacy, a reasonable understanding of JavaScript fundamentals.</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>להבין מהן promises וכיצד להשתמש בהן.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="מהן_promises">מהן promises?</h2>
-
-<p>סקרנו קצת <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise">Promises</a> במאמר הראשון במודול זה, אבל במאמר זה נסקור אותן יותר לעומק.?</p>
-
-<p>בעיקרון promise הוא בעצם אובייקט שמייצג מצב ביניים של פעולה - בפועל, promise היא מעין הבטחה שתוצאה מסויימת תוחזר בנקודה מסויימת בעתיד. אין שום הבטחה מתי הפעולה תושלם ומתי התוצאה תוחזר, אבל יש הבטחה שכאשר התוצאה מוכנה, או שכאשר הפעוללה נכשלה, הקוד שסיפקנו ירוץ על מנת לעשות משהו עם תוצאה מוצלחת או להתמודד עם כשלון בפעולה.</p>
-
-<p>באופן כללי, אנחנו פחות מתעניינים בזמן שייקח לפעולה א-סינכרונית להחזיר את התוצאה שלה (אלא אם כן מדובר בזמן יותר מדי ארוך), ואנחנו יותר מעוניינים בכך שתהיה לנו אפשרות להגיב לאותה תגובה כאשר היא תחזור, לא משנה מהי התגובה. וכמובן, זה נחמד שאותה פעולה לא חוסמת את הקוד מלרוץ.</p>
-
-<p>אחד מהשימושים של promise שאנחנו נראה הוא ב-web APIs שמחזירים promise. נניח ויש לנו יישום וידאו צ׳אט. ליישום זה יש חלון עם רשימת החברים של המשתמש, ובלחיצה על כפתור ליד שם החבר, תחל שיחת וידאו עם אותו חבר.</p>
-
-<p>מטפל האירוע של הכפתור הזה קורא ל- {{domxref("MediaDevices.getUserMedia", "getUserMedia()")}} על מנת לקבל גישה למיקרופון ולמצלמה של המשתמש. מאחר ו-<code>()getUserMedia</code> חייב לוודא שלמשתמש יש אישור להשתמש באותם מכשירים ולבקש מהמשתמש לבחור איזה מיקרופון ואיזו מצלמה להשתמש בהם או בכל שילוב אחר. בזמן הבקשה הזו, פעולה זו יכולה לחסום את המשך התוכנית לא רק עד אשר כל האישורים האלו התקבלו, אלא גם עד אשר המצלמה והמיקרופון יתחברו. בנוסף, המשתמש אולי לא יגיב באופן מיידי לבקשות אלו. זה יכול לקחת הרבה זמן.</p>
-
-<p>מאחר והקריאה ל- <code>()getUserMedia</code> נעשית מה- browser's main thread, הדפדפן חסום עד אשר <code>()getUserMedia</code> תסיים. ברור כמובן שזו לא אפשרות מקובלת בימים אלו. ללא promises, כל דבר בדפדפן היה נהפך ללא שימושי עד אשר המשתמש יחליט מה לעשות עם המצלמה והמיקרופון. אז במקום לחכות למשתמש, לקבל את המכשירים שנבחרו, ולהחזיר את ה-{{domxref("MediaStream")}} שנוצר למקורות אלו, <code>()getUserMedia</code> מחזיר {{jsxref("promise")}} אשר נפתר עם {{domxref("MediaStream")}} ברגע שהוא זמין.</p>
-
-<p>הקוד של יישום הוידאו צאט שלנו, עשוי להיראות כך?:?</p>
-
-<pre class="brush: js">function handleCallButton(evt) {
- setStatusMessage("Calling...");
- navigator.mediaDevices.getUserMedia({video: true, audio: true})
- .then(chatStream =&gt; {
- selfViewElem.srcObject = chatStream;
- chatStream.getTracks().forEach(track =&gt; myPeerConnection.addTrack(track, chatStream));
- setStatusMessage("Connected");
- }).catch(err =&gt; {
- setStatusMessage("Failed to connect");
- });
-}
-</pre>
-
-<p>הפונקציה הזו מתחילה בכך שהיא משתמש בפונקציה שנקראת <code>()setStatusMessage</code> על מנת לעדכן שורת עדכון למשתמש עם הטקסט: "Calling...", שמעידה על כך שמבוצע ניסיול החל בשיחה. לאחר מכן היא קוראת לפונקציה <code>()getUserMedia</code>, ומבקשת שתחל בסטרים (stream) ?שיש לו גם וידאו וגם אודיו וברגע שהסטרים יהיה מוכן, היא ממשיכה בפעולות לשם הקמת הסטרים וחיבור המצלמה והאודיו. לאחר מכן היא מציגה למשתמש הודעה ״Connected״. </p>
-
-<p>אם <code>()getUserMedia</code> תיכשל, בלוק הקוד של <code>catch</code> ירוץ. הוא משתמש שוב ב- <code>()setStatusMessage</code> על מנת להציג למשתמש שהתרחשה שגיאה. </p>
-
-<p>הדבר החשוב כן הוא שהקריאה של <code>()getUserMedia</code> מוחזרת כמעט באופן מיידי, גם אם הסטרים של המצלמה לא התקבל עדיין. אפילו אם הפונקציה של <code>()handleCallButton</code> סיימה להריץ את הקוד שבתוכה והחזירה את השליטה לקוד שקרא לה, כאשר <code>()getUserMedia</code> תסיים את הפעולה שלה, בין אם בהצלחה ובין אם תתרחש שגיאה, פונקציה זו תקרא שוב לאותו מטפל אירוע שסיפקנו לה. כלומר, היישום ימשיך לעבוד ולא יחכה לזרם הוידאו ולא ימנע מיתר הקוד להמשיך לרוץ. </p>
-
-<div class="blockIndicator note">
-<p><strong>לתשומת לב:</strong>  לפרטים נוספים אודות נושא מורכב זה של וידאו ואודיו, ראו <a href="/docs/Web/API/WebRTC_API/Signaling_and_video_calling">Signaling and video calling</a>.</p>
-</div>
-
-<h2 id="הבעיה_עם_callbacks">הבעיה עם callbacks</h2>
-
-<p>על מנת להבין לעומק מדוע promises הן דבר טוב, יעזור לנו לחשוב על ה-callbacks המיושנות ולהבין מדוע הן בעייתיות. </p>
-
-<p>ננסה להמחיש זאת באמצעות דוגמא להזמנת פיצה כאנלוגיה. יש מספר שלבים שאנחנו צריכים לעשות ולהשלים בהצלחה, אשר לא ממש הגיוני לבצע אותם בסדר אחר או לבצע אותם בסדר הנכון, אבל בלי לחכות שהשלב הקודם הסתיים:</p>
-
-<ol>
- <li>בחירת התוספות לפיצה - זה יכול לקחת זמן אם אנחנו לא ממש בטוחים איזו תוספת אנחנו רוצים על הפיצה ושלב זה יכול להיכשל אם בסופו של דבר לא קיבלנו החלטה איזו תוספת אנחנו רוצים, או אם בסוף החלטנו לאכול משהו אחר. </li>
- <li>בהנחה והחלטנו על תוספת, לאחר מכן אנחנו מבצעים הזמנה של הפיצה שאנחנו רוצים. שלב זה יכול לקחת זמן עד אשר הפיצה תהיה מוכנה, ואף יכול להיכשל אם לפיצרייה אין את המרכיבים הנכונים. </li>
- <li>בשלב האחרון אנחנו אוספים את הפיצה ואוכלים, גם שלב זה יכול להיכשל אם לא שילמנו לדוגמא על הפיצה או לא באנו לאסוף את הפיצה. </li>
-</ol>
-
-<p>עם ה-<a href="/en-US/docs/Learn/JavaScript/Asynchronous/Introducing#Callbacks">callbacks</a> הישנות, קוד מופשט שלנו ייראה בערך כך: </p>
-
-<pre class="brush: js">chooseToppings(function(toppings) {
- placeOrder(toppings, function(order) {
- collectOrder(order, function(pizza) {
- eatPizza(pizza);
- }, failureCallback);
- }, failureCallback);
-}, failureCallback);</pre>
-
-<p>קוד זה הוא מבולגן וקשה להבנה, ולפעמים גם נקרא כ-callback hell, הוא גם דורש שהפונקציה <code>()failureCallback</code> תיקרא כמה פעמים (בעבור כל פונקציה משורשרת) ויש לו גם חסרונות נוספים.</p>
-
-<h3 id="שדרוג_עם_promises">שדרוג עם  promises</h3>
-
-<p>Promises הופכות את סיטואציות כמו למעלה להרבה יותר פשוטות לכתיבה, פירוש וריצה. אם נציג את הקוד המופשט שלנו שוב באמצעות promises א-סינכרוניות, הוא ייראה כך:</p>
-
-<pre class="brush: js">chooseToppings()
-.then(function(toppings) {
- return placeOrder(toppings);
-})
-.then(function(order) {
- return collectOrder(order);
-})
-.then(function(pizza) {
- eatPizza(pizza);
-})
-.catch(failureCallback);</pre>
-
-<p>זה כבר הרבה יותר טוב- הרבה יותר קל להבין מה קורה כאן והיינו צריכים רק בלוק קוד אחד של <code>()</code><code>catch.</code> בעבור כל השגיאות שאולי יתרחשו. כל הקוד הזה אינו חוסם את ה-main thread (כך שאנחנו יכולים להמשיך לראות טלווזיה עד אשר הפיצה תהיה מוכנה), וכל פעולה תחכה בוודאות עד אשר הפעולה הקודמת תסיים לפני שהיא תרוץ. אנחנו יכולים לקשור מספר פעולות א-סינכרוניות כך שיתרחשו אחת אחרי השנייה מכיוון שכל בלוק קוד של <code>(.....)then.</code> מחזיר promise חדשה, שנפתח כאשר הקוד שבתוך ה-<code>(.....)then.</code> הרלוונטי מסיים לרוץ. </p>
-
-<p>באמצעות שימוש בפונקציות חץ (arrow functions), אנחנו אפילו יכולים להפוך את הקוד לעוד יותר פשוט: </p>
-
-
-
-<pre class="brush: js">chooseToppings()
-.then(toppings =&gt;
- placeOrder(toppings)
-)
-.then(order =&gt;
- collectOrder(order)
-)
-.then(pizza =&gt;
- eatPizza(pizza)
-)
-.catch(failureCallback);</pre>
-
-<p>או אפילו בצורה הזו:</p>
-
-<pre class="brush: js">chooseToppings()
-.then(toppings =&gt; placeOrder(toppings))
-.then(order =&gt; collectOrder(order))
-.then(pizza =&gt; eatPizza(pizza))
-.catch(failureCallback);</pre>
-
-<p>זה עובד מכיוון שעם פונקציות חץ, <code>x &lt;= ()</code> הוא סינטקסס חוקי והוא קיצור של <code>{return x} &lt;= ()</code>.</p>
-
-<p>אנחנו אפילו יכולים לרשום את הקוד שלנו בצורה כזו, מאחר שהפונקציות רק מעביר את הארגומנטים שלהם בצורה ישירה, אין צורך באמת לשכבה נוספת של פונקציה:</p>
-
-<pre class="brush: js">chooseToppings().then(placeOrder).then(collectOrder).then(eatPizza).catch(failureCallback);</pre>
-
-<p>יחד עם זאת, סינטקס זה לא ניתן לשימוש שוב, ולא ממש ברור לקריאה. </p>
-
-<div class="blockIndicator note">
-<p><strong>לתשומת לב</strong>: אנחנו אפילו יכולים לעשות שיפורים נוספים בסינטקס באמצעות הסינטקס של <code>async</code>/<code>await</code>, אשר נסקור אותו בהמשך המודול.</p>
-</div>
-
-<p>בבסיס שלהן, promises דומות למאזיני אירוע - event lisenters אך עם הבדלים ביניהם:</p>
-
-<ul>
- <li>promis יכולה להצליח או להיכשל רק פעם אחת. היא לא יכול הלהציח פעמיים או להיכשל פעמיים והיא לא יכולה לעבור ממצב של הצלחה למצב של כישולון או ההפך, ברגע שהפעולה הסתייימה. </li>
- <li>אם promise הצליחה או נכשלה ואלחר מכן אנחנו רוצים להוסיף success/failure callback, ה-callback הנכון הוא שייקרא, למרות שהאירוע עצמו התרחש לפני כן. </li>
-</ul>
-
-<h2 id="הסבר_של_הסינטקט_הבסיסי_של_promise">הסבר של הסינטקט הבסיסי של promise</h2>
-
-<p>Promises חשובות מאוד להבנה מכיוון שמרבית ה-Web API המודרניים משתמשים בהן בעבור פונקציות שעלולות לבצע פעולות ארוכות. </p>
-
-<p>בהמשך המאמר הזה אנחנו נראה כיצד לכתוב promises משלנו, אבל כאן אנחנו נסכתל על דוגמאות פשוטות שאנחנו ניתקל בהן ב-Web API שונים.</p>
-
-<p>בדוגמא הראשונה שלנו, אנחנו נשתמש במתודת <code><a href="/en-US/docs/Web/API/WindowOrWorkerGlobalScope/fetch">fetch()</a></code>, על מנת להביא תמונה מהאינטרנט, במתודת {{domxref("Body.blob", "blob()")}} על מנת להמיר את התוכן הגולמי של התגובה שקיבלנו לאובייקט {{domxref("Blob")}} , ולאחר מכן נציג את אותו blob בתוך אלמנט {{htmlelement("img")}}. זהו מאוד דומה לדוגמא שהסתכלנו עליה ב<a href="/en-US/docs/Learn/JavaScript/Asynchronous/Introducing#Asynchronous_JavaScript">מאמר הראשון במודול</a>, אבל אנחנו נעשה את זה מעט שונה כך שאתם תבנו את ה-promise. </p>
-
-<ol>
- <li>
- <p>ראשית, הורידו את ה-<a href="https://github.com/mdn/learning-area/blob/master/html/introduction-to-html/getting-started/index.html">HTML template</a> ואת ה-<a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/promises/coffee.jpg">image file</a> שאנחנו נייבא. </p>
- </li>
- <li>
- <p>הוסיפו אלמנט {{htmlelement("script")}} בתחתית ה-{{htmlelement("body")}} בקובץ ה-HTML.</p>
- </li>
- <li>
- <p>בתוך האלמנט {{HTMLElement("script")}} , הוסיפו את השורה הבאה: </p>
- </li>
- <li>
- <pre class="brush: js">let promise = fetch('coffee.jpg');</pre>
-
- <p>שורה זו קוראת למתודת <code>()fetch</code> ומעבירה אליה כפרמטר את ה-URL של התמונה שאנחנו רוצים לייבא מהרשת. אנחנו מאחסנים את אובייקט ה-promise שיוחזר אלינו מ-<code>()fetch</code> בתוך משתנה שנקרא לו promise. כפי שאמרנו בעבר, האובייקט הזה מייצג מצב ביניים שבהתחלה הוא לא הצלחה ולא כישלון - מצב זה נקרא <strong>pending.</strong></p>
- </li>
- <li>על מנת להגיב להצלחה של הפעולה כאשר היא תקרה, במקרה הזה כאשר {{domxref("Response")}} תוחזר אלינו, אנחנו נפעיל את המתודת <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/then">()</a></code><code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/then">then.</a></code> של אובייקט ה-promise. ה-callback בתוך בלוק הקוד של <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/then">()</a></code><code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/then">then.</a></code> (שנקרא גם <strong>executor</strong>), ירוץ רק כאשר פעולת ה-promise תושלם בהצלחה ותחזיר אובייקט {{domxref("Response")}} - במונחי promise, כאשר ה-promise תגיע למצב של הושלמה, <strong>fulfilled</strong>. היא תעביר את האובייקט {{domxref("Response")}} כפרמטר. </li>
- <li>
- <div class="blockIndicator note">
- <p><strong>לתשומת לב</strong>: הדרך שבה הבלוק <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/then">()</a></code><code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/then">then.</a></code> עובד היא דומה לדרך שבה אנחנו מוסיפים מאזין אירוע - event listener - לאובייקט באמצעות המתודה <code>()AddEventListener</code>. מאזין האירוע לא ירוץ עד אשר האירוע יתרחש (ובאותה נשימה, כאשר ה-promise הושלמה בהצלחה). ההבדל העיקרי ביניהם הוא ש-<code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/then">()</a></code><code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/then">then.</a></code> ירוץ רק פעם אחת בכל פעם שמשתמשים בו ואילו מאזין האירוע יכול להיות מופעל כמה פעמים. </p>
- </div>
-
- <p>אנחנו מייד נריץ את מתודת  <code>()blob</code> על התגובה הזו, על מנת לוודא שגוף התגובה הורד בהצלחה, וכאשר הוא זמין נהפוך אותו לאובייקט <code>Blob</code> שאנחנו יכולים לעשות איתו משהו. התוצאה של זה תוחזר לנו כך :</p>
-
- <pre class="brush: js">response =&gt; response.blob()</pre>
-
- <p>שזה קיצור של: </p>
-
- <pre class="brush: js">function(response) {
- return response.blob();
-}</pre>
-
- <p>עד כאן עם ההסבר, אנא הוסיפו את הקוד הבא מתחת לשורה הראשונה של JavaScript: </p>
-
- <pre class="brush: js">let promise2 = promise.then(response =&gt; response.blob());</pre>
- </li>
- <li>
- <p>כל קריאה ל-<code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/then">()</a></code><code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/then">then.</a></code> יוצרת promise חדשה. זהו מאוד שימושי - מכיוון שמתודת -  <code>()blob</code> מחזירה גם היא promise, אנחנו יכולים לטפל באובייקט ה-<code>Blob</code> שהיא מחזירה בעת ההשלמה שלו באמצעות הפעלה של מתודת <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/then">()</a></code><code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/then">then.</a></code> על ה-promise השנייה. מכיוון שאנחנו רוצים לעשות משהו קצת יותר מורכב לאותו blob מאשר רק להריץ מתודה אחת עליו ולהחזיר את התוצאה, אנחנו צריכים לעטוף את גוף הפונקצייה בסוגריים מסולסלות - אחרת זה יגרום לשגיאה. הוסיפו את השורה הבאה מתחת לקוד הנוכחי שלכם: </p>
- </li>
- <li>
- <pre class="brush: js">let promise3 = promise2.then(myBlob =&gt; {
-
-})</pre>
- </li>
- <li>
- <p>כעת, נכניס את הקוד הבא שהוא הפונקציה שתופעל, לתוך הסוגריים המסולסלות:</p>
-
- <pre class="brush: js">let objectURL = URL.createObjectURL(myBlob);
-let image = document.createElement('img');
-image.src = objectURL;
-document.body.appendChild(image);</pre>
-
- <p>מה שעשינו כאן אנחנו מריצים בעצם מריצים מתודת {{domxref("URL.createObjectURL()")}} , מעבירים אליה כפרמרט את ה-<code>Blob</code> שהוחזר אלינו כאשר ה-promise השנייה הושלמה. זה מחזיר לנו URL שמצביע על האובייקט. לאחר מכן יצרנו אלמנט {{htmlelement("img")}} , וקבענו את ה-<code>src</code> שלו שיהיה שווה ל-URL של האובייקט ושייכנו אותו ל-DOM, כך שהתמונה תוצג על גבי הדף. </p>
- </li>
-</ol>
-
-<p>אם תשמרו ותרעננו את הדף, אתם תראו שהתמונה מוצגת על גבי הדף. </p>
-
-<div class="blockIndicator note">
-<p><strong>לתשומת לב</strong>:  אתם בטח תשימו לב שדוגמאות אלו ארוכות מדי בשביל פעולה פשוטה שיכולנו לבצע באמצעות יצירת אלמנט <code>&lt;img&gt;</code> וקביעת ה-<code>src</code> שלו לאותו URL של התמונה במקום לעשות זאת באמצעות <code>()fetch</code> ובאמצעות <code>()blob</code>. יחד עם זאת, דוגמא זו נועדה על מנת להסביר בפשטות את תהליך ה-promises.</p>
-</div>
-
-<h3 id="תגובה_לכישלון">תגובה לכישלון </h3>
-
-<p>יש משהו חסר בדוגמא שלנו - כרגע, אין משהו שמגדיר כיצד להתמודד עם שגיאה כאשר ה-promise נכשלת, או <strong>rejects</strong> במונחים של promises. אנחנו יכולים להוסיף טיפול בשגיאה באמצעות הרצת מתודת <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/catch">()catch</a>.</code> של ה-promise הקודמת:</p>
-
-<pre class="brush: js">let errorCase = promise3.catch(e =&gt; {
- console.log('There has been a problem with your fetch operation: ' + e.message);
-});</pre>
-
-
-
-<p>To see this in action, try misspelling the URL to the image and reloading the page. The error will be reported in the console of your browser's developer tools.</p>
-
-<p>This doesn't do much more than it would if you just didn't bother including the <code>.catch()</code> block at all, but think about it — this allows us to control error handling exactly how we want. In a real app, your <code>.catch()</code> block could retry fetching the image, or show a default image, or prompt the user to provide a different image URL, or whatever.</p>
-
-<div class="blockIndicator note">
-<p><strong>Note</strong>: You can see <a href="https://mdn.github.io/learning-area/javascript/asynchronous/promises/simple-fetch.html">our version of the example live</a> (see the <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/promises/simple-fetch.html">source code</a> also).</p>
-</div>
-
-<h3 id="Chaining_the_blocks_together">Chaining the blocks together</h3>
-
-<p>This is a very longhand way of writing this out; we've deliberately done this to help you understand what is going on clearly. As shown earlier on in the article, you can chain together <code>.then()</code> blocks (and also <code>.catch()</code> blocks). The above code could also be written like this (see also <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/promises/simple-fetch-chained.html">simple-fetch-chained.html</a> on GitHub):</p>
-
-<pre class="brush: js">fetch('coffee.jpg')
-.then(response =&gt; response.blob())
-.then(myBlob =&gt; {
- let objectURL = URL.createObjectURL(myBlob);
- let image = document.createElement('img');
- image.src = objectURL;
- document.body.appendChild(image);
-})
-.catch(e =&gt; {
- console.log('There has been a problem with your fetch operation: ' + e.message);
-});</pre>
-
-<p>Bear in mind that the value returned by a fulfilled promise becomes the parameter passed to the next <code>.then()</code> block's executor function.</p>
-
-<div class="blockIndicator note">
-<p><strong>Note</strong>: <code>.then()</code>/<code>.catch()</code> blocks in promises are basically the async equivalent of a <code><a href="/en-US/docs/Web/JavaScript/Reference/Statements/try...catch">try...catch</a></code> block in sync code. Bear in mind that synchronous <code>try...catch</code> won't work in async code.</p>
-</div>
-
-<h2 id="Promise_terminology_recap">Promise terminology recap</h2>
-
-<p>There was a lot to cover in the above section, so let's go back over it quickly to give you a <a href="/en-US/docs/Learn/JavaScript/Asynchronous/Promises#Promise_terminology_recap">short guide that you can bookmark</a> and use to refresh your memory in the future. You should also go over the above section again a few more time to make sure these concepts stick.</p>
-
-<ol>
- <li>When a promise is created, it is neither in a success or failure state. It is said to be <strong>pending</strong>.</li>
- <li>When a promise returns, it is said to be <strong>resolved</strong>.
- <ol>
- <li>A successfully resolved promise is said to be <strong>fulfilled</strong>. It returns a value, which can be accessed by chaining a <code>.then()</code> block onto the end of the promise chain. The executor function inside the <code>.then()</code> block will contain the promise's return value.</li>
- <li>An unsuccessful resolved promise is said to be <strong>rejected</strong>. It returns a <strong>reason</strong>, an error message stating why the promise was rejected. This reason can be accessed by chaining a <code>.catch()</code> block onto the end of the promise chain.</li>
- </ol>
- </li>
-</ol>
-
-<h2 id="Running_code_in_response_to_multiple_promises_fulfilling">Running code in response to multiple promises fulfilling</h2>
-
-<p>The above example showed us some of the real basics of using promises. Now let's look at some more advanced features. For a start, chaining processes to occur one after the other is all fine, but what if you want to run some code only after a whole bunch of promises have <em>all</em> fulfilled?</p>
-
-<p>You can do this with the ingeniously named <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/all">Promise.all()</a></code> static method. This takes an array of promises as an input parameter and returns a new <code>Promise</code> object that will fulfill only if and when <em>all</em> promises in the array fulfill. It looks something like this:</p>
-
-<pre class="brush: js">Promise.all([a, b, c]).then(values =&gt; {
- ...
-});</pre>
-
-<p>If they all fulfill, then chained <code>.then()</code> block's executor function will be passed an array containing all those results as a parameter. If any of the promises passed to <code>Promise.all()</code> reject, the whole block will reject.</p>
-
-<p>This can be very useful. Imagine that we’re fetching information to dynamically populate a UI feature on our page with content. In many cases, it makes sense to receive all the data and only then show the complete content, rather than displaying partial information.</p>
-
-<p>Let's build another example to show this in action.</p>
-
-<ol>
- <li>
- <p>Download a fresh copy of our <a href="https://github.com/mdn/learning-area/blob/master/html/introduction-to-html/getting-started/index.html">page template</a>, and again put a <code>&lt;script&gt;</code> element just before the closing <code>&lt;/body&gt;</code> tag.</p>
- </li>
- <li>
- <p>Download our source files (<a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/promises/coffee.jpg">coffee.jpg</a>, <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/promises/tea.jpg">tea.jpg</a>, and <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/promises/description.txt">description.txt</a>), or feel free to substitute your own.</p>
- </li>
- <li>
- <p>In our script we'll first define a function that returns the promises we want to send to <code>Promise.all()</code>. This would be easy if we just wanted to run the <code>Promise.all()</code> block in response to three <code>fetch()</code> operations completing. We could just do something like:</p>
-
- <pre class="brush: js">let a = fetch(url1);
-let b = fetch(url2);
-let c = fetch(url3);
-
-Promise.all([a, b, c]).then(values =&gt; {
- ...
-});</pre>
-
- <p>When the promise is fulfilled, the <code>values</code> passed into the fullfillment handler would contain three <code>Response</code> objects, one for each of the <code>fetch()</code> operations that have completed.</p>
-
- <p>However, we don't want to do this. Our code doesn't care when the <code>fetch()</code> operations are done. Instead, what we want is the loaded data. That means we want to run the <code>Promise.all()</code> block when we get back usable blobs representing the images, and a usable text string. We can write a function that does this; add the following inside your <code>&lt;script&gt;</code> element:</p>
-
- <pre class="brush: js">function fetchAndDecode(url, type) {
- return fetch(url).then(response =&gt; {
- if (type === 'blob') {
- return response.blob();
- } else if (type === 'text') {
- return response.text();
- }
- })
- .catch(e =&gt; {
- console.log('There has been a problem with your fetch operation: ' + e.message);
- });
-}</pre>
-
- <p>This looks a bit complex, so let's run through it step by step:</p>
-
- <ol>
- <li>First of all we define the function, passing it a URL and a string representing the type of resource it is fetching.</li>
- <li>Inside the function body, we have a similar structure to what we saw in the first example — we call the <code>fetch()</code> function to fetch the resource at the specified URL, then chain it onto another promise that returns the decoded (or "read") response body. This was always the <code>blob()</code> method in the previous example.</li>
- <li>However, two things are different here:
- <ul>
- <li>First of all, the second promise we return is different depending on what the <code>type</code> value is. Inside the executor function we include a simple <code>if ... else if</code> statement to return a different promise depending on what type of file we need to decode (in this case we've got a choice of <code>blob</code> or <code>text</code>, but it would be easy to extend this to deal with other types as well).</li>
- <li>Second, we have added the <code>return</code> keyword before the <code>fetch()</code> call. The effect this has is to run the entire chain and then run the final result (i.e. the promise returned by <code>blob()</code> or <code>text()</code>) as the return value of the function we've just defined. In effect, the <code>return</code> statements pass the results back up the chain to the top.</li>
- </ul>
- </li>
- <li>
- <p>At the end of the block, we chain on a <code>.catch()</code> call, to handle any error cases that may come up with any of the promises passed in the array to <code>.all()</code>. If any of the promises reject, the catch block will let you know which one had a problem. The <code>.all()</code> block (see below) will still fulfill, but just won't display the resources that had problems. If you wanted the <code>.all</code> to reject, you'd have to chain the <code>.catch()</code> block on to the end of there instead.</p>
- </li>
- </ol>
-
- <p>The code inside the function body is async and promise-based, therefore in effect the entire function acts like a promise — convenient.</p>
- </li>
- <li>
- <p>Next, we call our function three times to begin the process of fetching and decoding the images and text, and store each of the returned promises in a variable. Add the following below your previous code:</p>
-
- <pre class="brush: js">let coffee = fetchAndDecode('coffee.jpg', 'blob');
-let tea = fetchAndDecode('tea.jpg', 'blob');
-let description = fetchAndDecode('description.txt', 'text');</pre>
- </li>
- <li>
- <p>Next, we will define a <code>Promise.all()</code> block to run some code only when all three of the promises stored above have successfully fulfilled. To begin with, add a block with an empty executor inside the <code>.then()</code> call, like so:</p>
-
- <pre class="brush: js">Promise.all([coffee, tea, description]).then(values =&gt; {
-
-});</pre>
-
- <p>You can see that it takes an array containing the promises as a parameter. The executor will only run when all three promises resolve; when that happens, it will be passed an array containing the results from the individual promises (i.e. the decoded response bodies), kind of like [coffee-results, tea-results, description-results].</p>
- </li>
- <li>
- <p>Last of all, add the following inside the executor. Here we use some fairly simple sync code to store the results in separate variables (creating object URLs from the blobs), then display the images and text on the page.</p>
-
- <pre class="brush: js">console.log(values);
-// Store each value returned from the promises in separate variables; create object URLs from the blobs
-let objectURL1 = URL.createObjectURL(values[0]);
-let objectURL2 = URL.createObjectURL(values[1]);
-let descText = values[2];
-
-// Display the images in &lt;img&gt; elements
-let image1 = document.createElement('img');
-let image2 = document.createElement('img');
-image1.src = objectURL1;
-image2.src = objectURL2;
-document.body.appendChild(image1);
-document.body.appendChild(image2);
-
-// Display the text in a paragraph
-let para = document.createElement('p');
-para.textContent = descText;
-document.body.appendChild(para);</pre>
- </li>
- <li>
- <p>Save and refresh and you should see your UI components all loaded, albeit in a not particularly attractive way!</p>
- </li>
-</ol>
-
-<p>The code we provided here for displaying the items is fairly rudimentary, but works as an explainer for now.</p>
-
-<div class="blockIndicator note">
-<p><strong>Note</strong>: If you get stuck, you can compare your version of the code to ours, to see what it is meant to look like — <a href="https://mdn.github.io/learning-area/javascript/asynchronous/promises/promise-all.html">see it live</a>, and see the <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/promises/promise-all.html">source code</a>.</p>
-</div>
-
-<div class="blockIndicator note">
-<p><strong>Note</strong>: If you were improving this code, you might want to loop through a list of items to display, fetching and decoding each one, and then loop through the results inside <code>Promise.all()</code>, running a different function to display each one depending on what the type of code was. This would make it work for any number of items, not just three.</p>
-
-<p>In addition, you could determine what the type of file is being fetched without needing an explicit <code>type</code> property. You could for example check the {{HTTPHeader("Content-Type")}} HTTP header of the response in each case using <code><a href="/en-US/docs/Web/API/Headers/get">response.headers.get("content-type")</a></code>, and then react accordingly.</p>
-</div>
-
-<h2 id="Running_some_final_code_after_a_promise_fulfillsrejects">Running some final code after a promise fulfills/rejects</h2>
-
-<p>There will be cases where you want to run a final block of code after a promise completes, regardless of whether it fulfilled or rejected. Previously you'd have to include the same code in both the <code>.then()</code> and <code>.catch()</code> callbacks, for example:</p>
-
-<pre class="brush: js">myPromise
-.then(response =&gt; {
- doSomething(response);
- runFinalCode();
-})
-.catch(e =&gt; {
- returnError(e);
- runFinalCode();
-});</pre>
-
-<p>In more recent modern browsers, the <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/finally">.finally()</a></code> method is available, which can be chained onto the end of your regular promise chain allowing you to cut down on code repetition and do things more elegantly. The above code can now be written as follows:</p>
-
-<pre class="brush: js">myPromise
-.then(response =&gt; {
- doSomething(response);
-})
-.catch(e =&gt; {
- returnError(e);
-})
-.finally(() =&gt; {
- runFinalCode();
-});</pre>
-
-<p>For a real example, take a look at our <a href="https://mdn.github.io/learning-area/javascript/asynchronous/promises/promise-finally.html">promise-finally.html demo</a> (see the <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/promises/promise-finally.html">source code</a> also). This works exactly the same as the <code>Promise.all()</code> demo we looked at in the above section, except that in the <code>fetchAndDecode()</code> function we chain a <code>finally()</code> call on to the end of the chain:</p>
-
-<pre class="brush: js">function fetchAndDecode(url, type) {
- return fetch(url).then(response =&gt; {
- if(type === 'blob') {
- return response.blob();
- } else if(type === 'text') {
- return response.text();
- }
- })
- .catch(e =&gt; {
- console.log(`There has been a problem with your fetch operation for resource "${url}": ` + e.message);
- })
- .finally(() =&gt; {
- console.log(`fetch attempt for "${url}" finished.`);
- });
-}</pre>
-
-<p>This logs a simple message to the console to tell us when each fetch attempt has finished.</p>
-
-<div class="blockIndicator note">
-<p><strong>Note</strong>: <code>finally()</code> allows you to write async equivalents to try/catch/finally in async code.</p>
-</div>
-
-<h2 id="Building_your_own_custom_promises">Building your own custom promises</h2>
-
-<p>The good news is that, in a way, you've already built your own promises. When you've chained multiple promises together with <code>.then()</code> blocks, or otherwise combined them to create custom functionality, you are already making your own custom async promise-based functions. Take our <code>fetchAndDecode()</code> function from the previous examples, for example.</p>
-
-<p>Combining different promise-based APIs together to create custom functionality is by far the most common way you'll do custom things with promises, and shows the flexibility and power of basing most modern APIs around the same principle. There is another way, however.</p>
-
-<h3 id="Using_the_Promise()_constructor">Using the Promise() constructor</h3>
-
-<p>It is possible to build your own promises using the <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise">Promise()</a></code> constructor. The main situation in which you'll want to do this is when you've got code based on an an old-school asynchronous API that is not promise-based, which you want to promis-ify. This comes in handy when you need to use existing, older project code, libraries, or frameworks along with modern promise-based code.</p>
-
-<p>Let's have a look at a simple example to get you started — here we wrap a <code><a href="/en-US/docs/Web/API/WindowOrWorkerGlobalScope/setTimeout">setTimeout()</a></code> call with a promise — this runs a function after two seconds that resolves the promise (using the passed <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/resolve">resolve()</a></code> call) with a string of "Success!".</p>
-
-<pre class="brush: js">let timeoutPromise = new Promise((resolve, reject) =&gt; {
- setTimeout(function(){
- resolve('Success!');
- }, 2000);
-});</pre>
-
-<p><code>resolve()</code> and <code>reject()</code> are functions that you call to fulfill or reject the newly-created promise. In this case, the promise fulfills with a string of "Success!".</p>
-
-<p>So when you call this promise, you can chain a <code>.then()</code> block onto the end of it and it will be passed a string of "Success!". In the below code we simply alert that message:</p>
-
-<pre class="brush: js">timeoutPromise
-.then((message) =&gt; {
- alert(message);
-})</pre>
-
-<p>or even just</p>
-
-<pre class="brush: js">timeoutPromise.then(alert);
-</pre>
-
-<p>Try <a href="https://mdn.github.io/learning-area/javascript/asynchronous/promises/custom-promise.html">running this live</a> to see the result (also see the <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/promises/custom-promise.html">source code</a>).</p>
-
-<p>The above example is not very flexible — the promise can only ever fulfill with a single string, and it doesn't have any kind of <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/reject">reject()</a></code> condition specified (admittedly, <code>setTimeout()</code> doesn't really have a fail condition, so it doesn't matter for this simple example).</p>
-
-<div class="blockIndicator note">
-<p><strong>Note</strong>: Why <code>resolve()</code>, and not <code>fulfill()</code>? The answer we'll give you for now is <em>it's complicated</em>.</p>
-</div>
-
-<h3 id="Rejecting_a_custom_promise">Rejecting a custom promise</h3>
-
-<p>We can create a promise that rejects using the <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/reject">reject()</a></code> method — just like <code>resolve()</code>, this takes a single value, but in this case it is the reason to reject with, i.e., the error that will be passed into the <code>.catch()</code> block.</p>
-
-<p>Let's extend the previous example to have some <code>reject()</code> conditions as well as allowing different messages to be passed upon success.</p>
-
-<p>Take a copy of the <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/promises/custom-promise.html">previous example</a>, and replace the existing <code>timeoutPromise()</code> definition with this:</p>
-
-<pre class="brush: js">function timeoutPromise(message, interval) {
- return new Promise((resolve, reject) =&gt; {
- if (message === '' || typeof message !== 'string') {
- reject('Message is empty or not a string');
- } else if (interval &lt; 0 || typeof interval !== 'number') {
- reject('Interval is negative or not a number');
- } else {
- setTimeout(function(){
- resolve(message);
- }, interval);
- }
- });
-};</pre>
-
-<p>Here we are passing two arguments into a custom function — a message to do something with, and the time interval to pass before doing the thing. Inside the function we then return a new <code>Promise</code> object — invoking the function will return the promise we want to use.</p>
-
-<p>Inside the Promise constructor, we do a number of checks inside <code>if ... else</code> structures:</p>
-
-<ol>
- <li>First of all we check to see if the message is appropriate for being alerted. If it is an empty string or not a string at all, we reject the promise with a suitable error message.</li>
- <li>Next, we check to see if the interval is an appropriate interval value. If it is negative or not a number, we reject the promise with a suitable error message.</li>
- <li>Finally, if the parameters both look OK, we resolve the promise with the specified message after the specified interval has passed using <code>setTimeout()</code>.</li>
-</ol>
-
-<p>Since the <code>timeoutPromise()</code> function returns a <code>Promise</code>, we can chain <code>.then()</code>, <code>.catch()</code>, etc. onto it to make use of its functionality. Let's use it now — replace the previous <code>timeoutPromise</code> usage with this one:</p>
-
-<pre class="brush: js">timeoutPromise('Hello there!', 1000)
-.then(message =&gt; {
- alert(message);
-})
-.catch(e =&gt; {
- console.log('Error: ' + e);
-});</pre>
-
-<p>When you save and run the code as is, after one second you'll get the message alerted. Now try setting the message to an empty string or the interval to a negative number, for example, and you'll be able to see the promise reject with the appropriate error messages! You could also try doing something else with the resolved message rather than just alerting it.</p>
-
-<div class="blockIndicator note">
-<p><strong>Note</strong>: You can find our version of this example on GitHub as <a href="https://mdn.github.io/learning-area/javascript/asynchronous/promises/custom-promise2.html">custom-promise2.html</a> (see also the <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/promises/custom-promise2.html">source code</a>).</p>
-</div>
-
-<h3 id="A_more_real-world_example">A more real-world example</h3>
-
-<p>The above example was kept deliberately simple to make the concepts easy to understand, but it is not really very async. The asynchronous nature is basically faked using <code>setTimeout()</code>, although it does still show that promises are useful for creating a custom function with sensible flow of operations, good error handling, etc.</p>
-
-<p>One example we'd like to invite you to study, which does show a useful async application of the <code>Promise()</code> constructor, is <a href="https://github.com/jakearchibald/idb/">Jake Archibald's idb library</a>. This takes the <a href="/en-US/docs/Web/API/IndexedDB_API">IndexedDB API</a>, which is an old-style callback-based API for storing and retrieving data on the client-side, and allows you to use it with promises. If you look at the <a href="https://github.com/jakearchibald/idb/blob/master/lib/idb.js">main library file</a> you'll see the same kind of techniques we discussed above being used there. The following block converts the basic request model used by many IndexedDB methods to use promises:</p>
-
-<pre class="brush: js">function promisifyRequest(request) {
- return new Promise(function(resolve, reject) {
- request.onsuccess = function() {
- resolve(request.result);
- };
-
- request.onerror = function() {
- reject(request.error);
- };
- });
-}</pre>
-
-<p>This works by adding a couple of event handlers that fulfill and reject the promise at appropriate times:</p>
-
-<ul>
- <li>When the <code><a href="/en-US/docs/Web/API/IDBRequest">request</a></code>'s <a href="/en-US/docs/Web/API/IDBRequest/success_event"><code>success</code> event</a> fires, the <code><a href="/en-US/docs/Web/API/IDBRequest/onsuccess">onsuccess</a></code> handler fulfills the promise with the request <code><a href="/en-US/docs/Web/API/IDBRequest/result">result</a></code>.</li>
- <li>When the <code><a href="/en-US/docs/Web/API/IDBRequest">request</a></code>'s <a href="/en-US/docs/Web/API/IDBRequest/error_event"><code>error</code> event</a> fires, the <code><a href="/en-US/docs/Web/API/IDBRequest/onerror">onerror</a></code> handler rejects the promise with the request <code><a href="/en-US/docs/Web/API/IDBRequest/error">error</a></code>.</li>
-</ul>
-
-<h2 id="Conclusion">Conclusion</h2>
-
-<p>Promises are a good way to build asynchronous applications when we don’t know the return value of a function or how long it will take to return. They make it easier to express and reason about sequences of asynchronous operations without deeply nested callbacks, and they support a style of error handling that is similar to the synchronous <code>try...catch</code> statement.</p>
-
-<p>Promises work in the latest versions of all modern browsers; the only place where promise support will be a problem is in Opera Mini and IE11 and earlier versions.</p>
-
-<p>We didn't touch on all promise features in this article, just the most interesting and useful ones. As you start to learn more about promises, you'll come across further features and techniques.</p>
-
-<p>Most modern Web APIs are promise-based, so you'll need to understand promises to get the most out of them. Among those APIs are <a href="/en-US/docs/Web/API/WebRTC_API">WebRTC</a>, <a href="/en-US/docs/Web/API/Web_Audio_API">Web Audio API</a>, <a href="/en-US/docs/Web/API/Media_Streams_API">Media Capture and Streams</a>, and many more. Promises will be more and more important as time goes on, so learning to use and understand them is an important step in learning modern JavaScript.</p>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li><code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise">Promise()</a></code></li>
- <li><a href="/en-US/docs/Web/JavaScript/Guide/Using_promises">Using promises</a></li>
- <li><a href="https://pouchdb.com/2015/05/18/we-have-a-problem-with-promises.html">We have a problem with promises</a> by Nolan Lawson</li>
-</ul>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/Asynchronous/Timeouts_and_intervals", "Learn/JavaScript/Asynchronous/Async_await", "Learn/JavaScript/Asynchronous")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Concepts">עקרונות תכנות א-סינכרוני כלליים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Introducing">הצגת asynchronous JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Timeouts_and_intervals">Asynchronous JavaScript: שימוש ב-Intervals ו-Timeouts</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Promises">טיפול בפעולות א-סינכרוניות באמצעות Promises</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Async_await">הפיכת Asynchronous Programming לקל יותר עם async ועם await</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Choosing_the_right_approach">בחירת האפשרות המתאימה</a></li>
-</ul>
diff --git a/files/he/learn/javascript/asynchronous/timeouts_and_intervals/index.html b/files/he/learn/javascript/asynchronous/timeouts_and_intervals/index.html
deleted file mode 100644
index 2d97d2827d..0000000000
--- a/files/he/learn/javascript/asynchronous/timeouts_and_intervals/index.html
+++ /dev/null
@@ -1,651 +0,0 @@
----
-title: 'Cooperative asynchronous JavaScript: Timeouts and intervals'
-slug: Learn/JavaScript/Asynchronous/Timeouts_and_intervals
-translation_of: Learn/JavaScript/Asynchronous/Timeouts_and_intervals
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/Asynchronous/Introducing", "Learn/JavaScript/Asynchronous/Promises", "Learn/JavaScript/Asynchronous")}}</div>
-
-<p class="summary">
- במאמר זה אנחנו נסתכל על מתודות מסורתיות שיש ב-JavaScript, בעבור הרצה של קוד באופן א-סינכרוני לאחר שזמן מסויים עבר או באינטרוול מסויים (כלומר לקבוע מספר פעמים שירוץ בכל פרק זמן מסויים), נדון בשימושים שלהם ומה הסוגיות הטבועות בהם.
-
- </p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>Basic computer literacy, a reasonable understanding of JavaScript fundamentals.</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>
- הבנה של לולאות א-סינכרוניות ואינטרוולים ולמה הם משמים. </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="הקדמה">הקדמה</h2>
-
-<p>
- במשך זמן רב, פלטפורמת ה-web העניקה למפתחי JavaScript מספר של פונקציות שאפשרו לה להריץ קוד באופן א-סינכרוני, כך שהקוד ירוץ לאחר זמן מסויים שעבר או להריץ קוד מסויים באופן א-סינכרוני,ע ם הפרש זמן מסויים בין כל ריצה שלו, עד שאנחנו נגיד לו לעצור. אלו הם :</p>
-
-<dl>
- <dt><code><a href="/en-US/docs/Web/API/WindowOrWorkerGlobalScope/setTimeout">setTimeout()</a></code></dt>
- <dd>
- מריץ בלוק קוד מסויים פעם אחת לאחר שזמן מסויים עבר. </dd>
- <dt><code><a href="/en-US/docs/Web/API/WindowOrWorkerGlobalScope/setInterval">setInterval()</a></code></dt>
- <dd>
- מריץ בלוק קוד מסויים באופן חוזר, עם הפרש של זמן מסויים בין כל ריצה. </dd>
- <dt><code><a href="/en-US/docs/Web/API/window/requestAnimationFrame">requestAnimationFrame()</a></code></dt>
- <dd>
- זוהי גרסה מודרנית ל-<code>setInterval()</code>. היא מריצה בלוק קוד מסויים לפני שהדפדפן צובע מחדש את התצוגה, כך שמתאפשרת לאניממציה לרוץ במסגרת מתאימה ללא קשר לסביבה בה היא פועלת.
- </dd>
-</dl>
-
-<p>
- הקוד הא-סינכרוני שנכתב באמצעות פונקציות אלו בעצם ירוץ על ה-00000, אבל כן התאפשר לנו להריץ קוד אחר בין כל ריצה שלהם במידה מסוייתמ, תלוי כמה הפונקציות שנכתוב יעשו שימוש רב במעבד. בכל מקרה, הפונקציות הללו משמשות אנימציות קבועות ועוד תהליכי רקע על אתר אינטרנט או יישום אינטרנטר. בחלקים הבאים של המאמר אנחנו נגע בכל אחת מהן ולמה הן משמשות. .</p>
-
-<h2 id="setTimeout()">setTimeout()</h2>
-
-<p>
- כפי שאמרנו למעלה, <code><a href="/en-US/docs/Web/API/WindowOrWorkerGlobalScope/setTimeout">setTimeout()</a></code> מריצה בלוק קוד מסויים פעם אחת, לאחר שזמן מסויים שהגדרנו לה חלף. היא מקבלת את הפרמטרים הבאים: </p>
-
-<ul>
- <li>פונקציה שתרוץ או הפנייה לפונקציה שהוגדרה במקום אחר.
-
- </li>
- <li>
-
- מספר שמייצג את משך הזמן (אינטרוול הזמן) במילשניות (כך 1000 מילישניות שווה לשנייה אחת). המספר הזה מייצג את משך הזמן שיעבור לפני שהקוד יורץ - הפונקציה תורץ. אנחנו יכולים לרשום את הערך של 0 או להשמיט את המספר הזה לחלוטין ואז הפונקציה תרוץ באופן מיידע. עוד על מדוע נרצה לעשות זאת אנחנו נראה בהמשך. </li>
- <li>
- פרמטרים נוספים, ככל ונדרשים על ידי הפונקציה שנתנו כפרמטר ל--<code><a href="/en-US/docs/Web/API/WindowOrWorkerGlobalScope/setTimeout">setTimeout()</a></code>. כלומר, פרמטרים שנרצה להעביר לפונקציה שתרוץ.
-</li>
-</ul>
-
-<div class="blockIndicator note">
-<p><strong>לתשומת לב:</strong>
- מכיוון ש-0000000 מורצות ביחד, אין כל הבטחה שהן יופעלו <em>במדוייק</em> לאחר הזמן שהגדרנו. במקום, הם ייקראו לאחר שהזמן שהגדרנו חלף, <em>לפחות</em>.
-
- Because timeout callbacks are executed cooperatively, there's no guarantee that they will be called after <em>exactly</em> the specified amount of time. Instead, they will be called after <em>at least</em> that much time has elapsed.
-
-
- Timeout handlers לא יכולים לרוץ עד אשר ה-main thread מגיע לנקודה בריצה שלו שם הוא עובר על מטפלים אלו למצוא את אלו שהוא צריך להריץ אותם. שה-00000
-</p>
-</div>
-
-<p>
- בדוגמא הבאה, הדפדפן יחכה שתי שניות לפני שיריץ את הפונקציה האנונימית, ואז יציג את הודעת ה-alert.
-e (<a href="https://mdn.github.io/learning-area/javascript/asynchronous/loops-and-intervals/simple-settimeout.html">ראו כדף אינטרנט</a>, וכן <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/loops-and-intervals/simple-settimeout.html">את קוד המקור</a>):</p>
-
-<pre class="brush: js">let myGreeting = setTimeout(function() {
- alert('Hello, Mr. Universe!');
-}, 2000)</pre>
-
-<p>
- הפונקציות שאנחנו מציינים לא חייבות להיות אנונימיות. אנחנו יכולים לתת לפונקציה שלנו שם ואפילו להגדיר אותה במקום אחר, ואז להעביר הפנייה לפונקציה בתוך ה- <code>setTimeout()</code> . הגרסאות הבאות של הקוד שלנו הם שוות לראשונה:
-
- he functions we specify don't have to be anonymous. We can give our function a name, and can even define it somewhere else and pass a function reference to the <code>setTimeout()</code>. The following two versions of our code snippet are equivalent to the first one:</p>
-
-<pre class="brush: js">// With a named function
-let myGreeting = setTimeout(function sayHi() {
- alert('Hello, Mr. Universe!');
-}, 2000)
-
-// With a function defined separately
-function sayHi() {
- alert('Hello Mr. Universe!');
-}
-
-let myGreeting = setTimeout(sayHi, 2000);</pre>
-
-<p>
- זה יכול להיות שימושי כאשר יש לנו פונקציה שצריכה להיקרא/להיות מופעלת גם מתוך -timeout וגם בתגובה לאירוע, לדוגמא. אבל, זה גם יכול לעזור לנו להשאיר את הקוד שלנו מסודר, במיוחד אם אחרי ה-timeout callback יש לנו יותר מכמה שורות קוד.
-</p>
-
-<p><code>setTimeout()</code>
- מחזירה ערך מזהה שיכול לשמש לשם הפנייה לאותו timeout לאחר מכן, אם נרצה לדוגמא לעצור את ה-timeout. ראו {{anch("Clearing timeouts")}} בהמשך על מנת ללמוד כיצד לעשות זאת.
-
-
- </p>
-
-<h3 id="העברת_פרמטרים_לפונקציית_setTimeout()">העברת פרמטרים לפונקציית setTimeout() </h3>
-
-<p>
- כל פרמטר שנרצה להעביר לפונקציה שתרוף בתוך ה-<code>setTimeout()</code>, יהיו חייבים להיות מועברים כפרמטרים נוספוים לפונקציית ה-<code>setTimeout()</code>, וזאת בסוף הרשימת פרמטרים. לדוגמא, אנחנו יכולים כתוב מחדש את הפונקציה הקודמת שלנו כך שהיא תגיד hi לכל שם שיועבר אליה
-:</p>
-
-<pre class="brush: js">function sayHi(who) {
- alert('Hello ' + who + '!');
-}</pre>
-
-<p>
- השם של ה-person יכול להיות מועבר כפרמטר שלישי לתוך ה-<code>setTimeout()</code>
-
-:</p>
-
-<pre class="brush: js">let myGreeting = setTimeout(sayHi, 2000, 'Mr. Universe');</pre>
-
-<h3 id="מחיקת_Timeouts">מחיקת Timeouts</h3>
-
-<p>
- לבסוף, אם timeout נוצר, אנחנו יכולים לבטל אותו לפני שהזמן שהגדרנו לו הסתיים באמצעשות שימוש ב-<code><a href="/en-US/docs/Web/API/WindowOrWorkerGlobalScope/clearTimeout">clearTimeout()</a></code> והעברה של אותו ערך מזהה של ה-<code>setTimeout()</code> כפרמטר. כך, על מנת לבטל את ה-<code>setTimeout()</code> בדוגמא למעלה, אנחנו צריכים לרשום משהו כזה:
-</p>
-
-<pre class="brush: js">clearTimeout(myGreeting);</pre>
-
-<div class="blockIndicator note">
-<p><strong>לתשומת לב</strong>: ראו <a href="https://mdn.github.io/learning-area/javascript/asynchronous/loops-and-intervals/greeter-app.html">greeter-app.html</a>
- לדוגמא יותר מעניינת אשר מאפשרת לכן לקבוע את השם של האדם שנגיד לו שלום בטופס, ואז לבטל את הברכה באמצעו תכפתור אחג. (<a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/loops-and-intervals/greeter-app.html">קוד המקור</a>).</p>
-</div>
-
-<h2 id="setInterval()">setInterval()</h2>
-
-<p><code>setTimeout()</code> עובדת מצוים כאשר אנחנו צריכים להריץ בלוק קוד מסויים פעם אחת לאחר אינטרוול זמן שעבר. אבל מה קורה כאשר אנחנו רוצים להריץ קוד מסויים שוב ושוב, כמו במקרה של אנימציות?</p>
-
-<p>כאן נכנס לתמונה <code><a href="/en-US/docs/Web/API/WindowOrWorkerGlobalScope/setInterval">setInterval()</a></code> .
- פונקציה זו עובדת בצורה דומה ל-<code>setTimeout()</code>, למעט העובדה שהפונקציה שאנחנו מעבירים כפרמטר ראשון, תרוץ באופן חוזר ונשנה לכל הפחות בכל משך הזמן שהוגדר לה (גם כן במילישניות), ולא רק פעם אחת. אנחנו גם יכולים להעביר לה את הפרמטרים הדרושים לפונקציה שתרוץ.
-.</p>
-
-<p>
- נראה דוגמא על מנת להמחיש את העניין. הפונקציה הבא יוצרת אובייקט <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date">Date()</a></code> חדש, מחלצת חרוזת זמן מתוכו באמצעות שימוש ב- <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toLocaleTimeString">toLocaleTimeString()</a></code> ציגה את זה לממשק המתשמש. לאחר מכן אנחנו מריצים פונקציה אחת לשנייה באמצעות שימוש ב-<code>setInterval()</code>
- על מנת ליצור את האפשר של שעון דיגיטלי שמעדכן את עצמו כל שנייה.
- (<a href="https://mdn.github.io/learning-area/javascript/asynchronous/loops-and-intervals/setinterval-clock.html">ראו כדף אינטרנט</a>, ואת also <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/loops-and-intervals/setinterval-clock.html">קוד המקור</a>):</p>
-
-<pre class="brush: js">function displayTime() {
- let date = new Date();
- let time = date.toLocaleTimeString();
- document.getElementById('demo').textContent = time;
-}
-
-const createClock = setInterval(displayTime, 1000);</pre>
-
-<p>בדיוק כמו <code>setTimeout()</code>, <code>setInterval()</code> מחזירה ערך מזהה כך שאנחנו יכולים להשתמש בו בהמשך על מנת למחוק את ה-interval.</p>
-
-<h3 id="מחיקת_intervals">מחיקת intervals</h3>
-
-<p><code>setInterval()</code> תמשיך לרוץ באופן מתמשך וקבוע, אלא אם אנחנו נעשה איתה משהו -
- אנחנו נרצה אולי דרך לעצור משימות כאלו, אחרת אנחנו נקבל שגיאות השהדפדפן לא מצליח להשלים גרסאות נוספות של המשימה הזו, או שהאניממציה שמטופלת על ידי המשימה הזו הסתיימה. אנחנו יכולים לעשות זאת באותה דרך שבה אנחנו מסיימים <code>setInterval()</code> - באמצעות העבר הערך המזהה שהוחזר לנו בהפעלה של <code>setInterval()</code> לפונקציה <code><a href="/en-US/docs/Web/API/WindowOrWorkerGlobalScope/clearInterval">clearInterval()</a></code>:
-
- </p>
-
-<pre class="brush: js">const myInterval = setInterval(myFunction, 2000);
-
-clearInterval(myInterval);</pre>
-
-<h4 id="למידה_עצמאית_יצירה_של_שעון_עצר">למידה עצמאית: יצירה של שעון עצר</h4>
-
-<p>לאחר שעברנו על פונקציות אלו, נסו לאתגר את עצמכם במשימה זו. עשו עותקשל הדוגמא שלנו שנמצא ב- <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/loops-and-intervals/setinterval-clock.html">setInterval-clock.html</a> ושנו אותה כך שתהיה שעון סטופר.</p>
-
-<p>
- אתם צריכים להציג את הזמן כמו בדוגמא הקודמת, רק שבתרגיל זה אתם תצטרכו:</p>
-
-<ul>
- <li>כפתור "Start" על מנת שהשעון יתחיל לרוץ.</li>
- <li>כפתור "Stop" להשהות את השעון.</li>
- <li>כפתור "Reset" לאפס את השעון ל- 0.</li>
- <li>תצוגת זמן על מנת להציג כמה שניות עברו ולא מה השעה הנוכחית </li>
-</ul>
-
-<p>רמזים:</p>
-
-<ul>
- <li>You can structure and style the button markup however you like; just make sure you use semantic HTML, with hooks to allow you to grab the button references using JavaScript.</li>
- <li>You probably want to create a variable that starts at 0, then increments by one every second using a constant loop.</li>
- <li>It is easier to create this example without using a <code>Date()</code> object, like we've done in our version, but less accurate — you can't guarantee that the callback will fire after exactly 1000ms. A more accurate way would be to run <code>startTime = Date.now()</code> to get a timestamp of exactly when the user clicked the start button, and then do <code>Date.now() - startTime</code> to get the number of milliseconds after the start button was clicked.</li>
- <li>You also want to calculate the number of hours, minutes, and seconds as separate values, and then show them together in a string after each loop iteration. From the second counter, you can work out each of these.</li>
- <li>How would you calculate them? Have a think about it:
- <ul>
- <li>The number of seconds in an hour is 3600.</li>
- <li>The number of minutes will be the amount of seconds left over when all of the hours have been removed, divided by 60.</li>
- <li>The number of seconds will be the amount of seconds left over when all of the minutes have been removed.</li>
- </ul>
- </li>
- <li>You'll want to include a leading zero on your display values if the amount is less than 10, so it looks more like a traditional clock/watch.</li>
- <li>To pause the stopwatch, you'll want to clear the interval. To reset it, you'll want to set the counter back to 0 and then immediately update the display.</li>
- <li>You probably ought to disable the start button after pressing it once, and enable it again after you've stopped it. Otherwise multiple presses of the start button will apply multiple <code>setInterval()</code>s to the clock, leading to wrong behavior.</li>
-</ul>
-
-<div class="blockIndicator note">
-<p><strong>Note</strong>: If you get stuck, you can <a href="https://mdn.github.io/learning-area/javascript/asynchronous/loops-and-intervals/setinterval-stopwatch.html">find our version here</a> (see the <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/loops-and-intervals/setinterval-stopwatch.html">source code</a> also).</p>
-</div>
-
-<h2 id="Things_to_keep_in_mind_about_setTimeout()_and_setInterval()">Things to keep in mind about setTimeout() and setInterval()</h2>
-
-<p>There are a few things to keep in mind when working with <code>setTimeout()</code> and <code>setInterval()</code>. Let's review these now.</p>
-
-<h3 id="Recursive_timeouts">Recursive timeouts</h3>
-
-<p>There is another way we can use <code>setTimeout()</code>: We can call it recursively to run the same code repeatedly, instead of using <code>setInterval()</code>.</p>
-
-<p>The below example uses a recursive <code>setTimeout()</code> to run the passed function every 100 milliseconds:</p>
-
-<pre class="brush: js">let i = 1;
-
-setTimeout(function run() {
- console.log(i);
- i++;
- setTimeout(run, 100);
-}, 100);</pre>
-
-<p>Compare the above example to the following one — this uses <code>setInterval()</code> to accomplish the same effect:</p>
-
-<pre class="brush: js">let i = 1;
-
-setInterval(function run() {
- console.log(i);
- i++
-}, 100);</pre>
-
-<h4 id="How_do_recursive_setTimeout()_and_setInterval()_differ">How do recursive <code>setTimeout()</code> and <code>setInterval()</code> differ?</h4>
-
-<p>The difference between the two versions of the above code is a subtle one.</p>
-
-<ul>
- <li>Recursive <code>setTimeout()</code> guarantees the same delay between the executions, so for example 100ms in the above case. The code will run and then wait 100 milliseconds before it runs again, so the interval will be the same regardless of how long the code takes to run.</li>
- <li>The example using <code>setInterval()</code> does things somewhat differently. The interval we choose <em>includes</em> the time taken to execute the code we want to run in. Let's say that the code takes 40 milliseconds to run — the interval then ends up being only 60 milliseconds.</li>
- <li>When using <code>setTimeout()</code> recursively, each iteration can calculate a different delay before running the next iteration. In other words, the value of the second parameter can specify a different time in milliseconds to wait before running the code again.</li>
-</ul>
-
-<p>When your code has the potential to take longer to run than the time interval you’ve assigned, it’s better to use recursive <code>setTimeout()</code> — this will keep the time interval constant between executions regardless of how long the code takes to execute, and you won't get errors.</p>
-
-<h3 id="Immediate_timeouts">Immediate timeouts</h3>
-
-<p>Using 0 as the value for <code>setTimeout()</code> schedules the execution of the specified callback function as soon as possible but only after the main code thread has been run.</p>
-
-<p>For instance, the code below (<a href="https://mdn.github.io/learning-area/javascript/asynchronous/loops-and-intervals/zero-settimeout.html">see it live</a>) outputs an alert containing "Hello", then an alert containing "World" as soon as you click OK on the first alert.</p>
-
-<pre class="brush: js">setTimeout(function() {
- alert('World');
-}, 0);
-
-alert('Hello');</pre>
-
-<p>This can be useful in cases where you want to set a block of code to run as soon as all of the main thread has finished running — put it on the async event loop, so it will run straight afterwards.</p>
-
-<h3 id="Clearing_with_clearTimeout()_or_clearInterval()">Clearing with clearTimeout() or clearInterval()</h3>
-
-<p><code>clearTimeout()</code> and <code>clearInterval()</code> both use the same list of entries to clear from. Interestingly enough, this means that you can use either method to clear a <code>setTimeout()</code> or <code>setInterval()</code>.</p>
-
-<p>For consistency, you should use <code>clearTimeout()</code> to clear <code>setTimeout()</code> entries and <code>clearInterval()</code> to clear <code>setInterval()</code> entries. This will help to avoid confusion.</p>
-
-<h2 id="requestAnimationFrame()">requestAnimationFrame()</h2>
-
-<p><code><a href="/en-US/docs/Web/API/window/requestAnimationFrame">requestAnimationFrame()</a></code> is a specialized looping function created for running animations efficiently in the browser. It is basically the modern version of <code>setInterval()</code> — it executes a specified block of code before the browser next repaints the display, allowing an animation to be run at a suitable frame rate regardless of the environment it is being run in.</p>
-
-<p>It was created in response to perceived problems with <code>setInterval()</code>, which for example doesn't run at a frame rate optimized for the device, sometimes drops frames, continues to run even if the tab is not the active tab or the animation is scrolled off the page, etc. <a href="http://creativejs.com/resources/requestanimationframe/index.html">Read more about this on CreativeJS</a>.</p>
-
-<div class="blockIndicator note">
-<p><strong>Note</strong>: You can find examples of using <code>requestAnimationFrame()</code> elsewhere in the course — see for example <a href="/en-US/docs/Learn/JavaScript/Client-side_web_APIs/Drawing_graphics">Drawing graphics</a>, and <a href="/en-US/docs/Learn/JavaScript/Objects/Object_building_practice">Object building practice</a>.</p>
-</div>
-
-<p>The method takes as an argument a callback to be invoked before the repaint. This is the general pattern you'll see it used in:</p>
-
-<pre class="brush: js">function draw() {
- // Drawing code goes here
- requestAnimationFrame(draw);
-}
-
-draw();</pre>
-
-<p>The idea is that you define a function in which your animation is updated (e.g. your sprites are moved, score is updated, data is refreshed, or whatever), then you call it to start the process off. At the end of the function block you call <code>requestAnimationFrame()</code> with the function reference passed as the parameter, and this instructs the browser to call the function again on the next display repaint. This is then run continuously, as we are calling <code>requestAnimationFrame()</code> recursively.</p>
-
-<div class="blockIndicator note">
-<p><strong>Note</strong>: If you want to perform some kind of simple constant DOM animation, <a href="/en-US/docs/Web/CSS/CSS_Animations">CSS Animations</a> are probably faster as they are calculated directly by the browser's internal code rather than JavaScript. If however you are doing something more complex and involving objects that are not directly accessible inside the DOM (such as <a href="/en-US/docs/Web/API/Canvas_API">2D Canvas API</a> or <a href="/en-US/docs/Web/API/WebGL_API">WebGL</a> objects), <code>requestAnimationFrame()</code> is the better option in most cases.</p>
-</div>
-
-<h3 id="How_fast_does_your_animation_run">How fast does your animation run?</h3>
-
-<p>The smoothness of your animation is directly dependent on your animation's frame rate and it is measured in frames per second (fps). The higher this number is, the smoother your animation will look, to a point.</p>
-
-<p>Since most screens have a refresh rate of 60Hz, the fastest frame rate you can aim for is 60 frames per second (FPS) when working with web browsers. However, more frames means more processing, which can often cause stuttering and skipping — also known as <em>dropping frames</em>, or <em>jank</em>.</p>
-
-<p>If you have a monitor with a 60Hz refresh rate and you want to achieve 60 FPS you have about 16.7 milliseconds (1000 / 60) to execute your animation code to render each frame. This is a reminder that we need to be mindful of the amount of code that we try to run for each pass through the animation loop.</p>
-
-<p><code>requestAnimationFrame()</code> always tries to get as close to this magic 60 FPS value as possible, although sometimes it isn't possible — if you have a really complex animation and you are running it on a slow computer, your frame rate will be less. <code>requestAnimationFrame()</code> will always do the best it can with what it has available.</p>
-
-<h3 id="How_does_requestAnimationFrame()_differ_from_setInterval()_and_setTimeout()">How does requestAnimationFrame() differ from setInterval() and setTimeout()?</h3>
-
-<p>Let's talk a little bit more about how the <code>requestAnimationFrame()</code> method differs from the other methods we looked at earlier. Looking at our code from above:</p>
-
-<pre class="brush: js">function draw() {
- // Drawing code goes here
- requestAnimationFrame(draw);
-}
-
-draw();</pre>
-
-<p>Let's now see how we'd do the same thing using <code>setInterval()</code>:</p>
-
-<pre class="brush: js">function draw() {
- // Drawing code goes here
-}
-
-setInterval(draw, 17);</pre>
-
-<p>As we said before, we don't specify a time interval for <code>requestAnimationFrame()</code>; it just runs it as quickly and smoothly as possible in the current conditions. The browser also doesn't waste time running it if the animation is offscreen for some reason, etc.</p>
-
-<p><code>setInterval()</code> on the other hand requires an interval to be specified. We arrived at our final value of 17 via the formula <em>1000 milliseconds / 60Hz</em>, and then rounded it up. Rounding up is a good idea, as if you rounded down the browser might try to run the animation faster than 60fps, and it wouldn't make any difference to the smoothness of the animation anyway. As we said before, 60Hz is the standard refresh rate.</p>
-
-<h3 id="Including_a_timestamp">Including a timestamp</h3>
-
-<p>The actual callback passed to the <code>requestAnimationFrame()</code> function can be given a parameter too — a timestamp value that represents the time since the <code>requestAnimationFrame()</code> started running. This is useful as it allows you to run things at specific times and at a constant pace, regardless of how fast or slow your device might be. The general pattern you'd use looks something like this:</p>
-
-<pre class="brush: js">let startTime = null;
-
-function draw(timestamp) {
- if(!startTime) {
- startTime = timestamp;
- }
-
- currentTime = timestamp - startTime;
-
- // Do something based on current time
-
- requestAnimationFrame(draw);
-}
-
-draw();</pre>
-
-<h3 id="Browser_support">Browser support</h3>
-
-<p><code>requestAnimationFrame()</code> is supported in slightly more recent browsers than <code>setInterval()</code>/<code>setTimeout()</code> — most interestingly it is available in Internet Explorer 10 and above. So unless you need to support older versions of IE with your code, there is little reason to not use <code>requestAnimationFrame()</code>.</p>
-
-<h3 id="A_simple_example">A simple example</h3>
-
-<p>Enough with the theory; let's go through and build our own <code>requestAnimationFrame()</code> example. We're going to create a simple "spinner animation", the kind you might see displayed in an app when it is busy connecting to the server, etc.</p>
-
-<div class="blockIndicator note">
-<p><strong>Note</strong>: In a real world example, you should probably use CSS animations to run this kind of simple animation. However, this kind of example is very useful to demonstrate <code>requestAnimationFrame()</code> usage, and you'd be more like to use this kind of technique when doing something more complex such as updating the display of a game on each frame.</p>
-</div>
-
-<ol>
- <li>
- <p>First of all, grab a basic HTML template <a href="https://github.com/mdn/learning-area/blob/master/html/introduction-to-html/getting-started/index.html">such as this one</a>.</p>
- </li>
- <li>
- <p>Put an empty {{htmlelement("div")}} element inside the {{htmlelement("body")}}, then add a ↻ character inside it. This is a circular arrow character that will act as our spinner for this simple example.</p>
- </li>
- <li>
- <p>Apply the following CSS to the HTML template in whatever way you prefer. This sets a red background on the page, sets the <code>&lt;body&gt;</code> height to <code>100%</code> of the {{htmlelement("html")}} height, and centers the <code>&lt;div&gt;</code> inside the <code>&lt;body&gt;</code>, horizontally and vertically.</p>
-
- <pre class="brush: css">html {
- background-color: white;
- height: 100%;
-}
-
-body {
- height: inherit;
- background-color: red;
- margin: 0;
- display: flex;
- justify-content: center;
- align-items: center;
-}
-
-div {
- display: inline-block;
- font-size: 10rem;
-}</pre>
- </li>
- <li>
- <p>Insert a {{htmlelement("script")}} element just above the <code>&lt;/body&gt;</code> tag.</p>
- </li>
- <li>
- <p>Insert the following JavaScript inside your <code>&lt;script&gt;</code> element. Here we're storing a reference to the <code>&lt;div&gt;</code> inside a constant, setting a <code>rotateCount</code> variable to 0, setting an uninitialized variable that will later be used to contain a reference to the <code>requestAnimationFrame()</code> call, and setting a <code>startTime</code> variable to <code>null</code>, which will later be used to store the start time of the <code>requestAnimationFrame()</code>.</p>
-
- <pre class="brush: js">const spinner = document.querySelector('div');
-let rotateCount = 0;
-let startTime = null;
-let rAF;
-</pre>
- </li>
- <li>
- <p>Below the previous code, insert a <code>draw()</code> function that will be used to contain our animation code, which includes the <code>timestamp</code> parameter:</p>
-
- <pre class="brush: js">function draw(timestamp) {
-
-}</pre>
- </li>
- <li>
- <p>Inside <code>draw()</code>, add the following lines. Here we define the start time if it is not defined already (this will only happen on the first loop iteration), and set the <code>rotateCount</code> to a value to rotate the spinner by (the current timestamp, take the starting timestamp, divided by three so it doesn't go too fast):</p>
-
- <pre class="brush: js"> if (!startTime) {
- startTime = timestamp;
- }
-
- rotateCount = (timestamp - startTime) / 3;
-</pre>
- </li>
- <li>
- <p>Below the previous line inside <code>draw()</code>, add the following block — this checks to see if the value of <code>rotateCount</code> is above <code>359</code> (e.g. <code>360</code>, a full circle). If so, it sets the value to its modulo of 360 (i.e. the remainder left over when the value is divided by 360) so the circle animation can continue uninterrupted, at a sensible, low value. Note that this isn't strictly necessary, but it is easier to work with values of 0-359 degrees than values like "128000 degrees".</p>
-
- <pre class="brush: js">if (rotateCount &gt; 359) {
- rotateCount %= 360;
-}</pre>
- </li>
- <li>Next, below the previous block add the following line to actually rotate the spinner:
- <pre class="brush: js">spinner.style.transform = 'rotate(' + rotateCount + 'deg)';</pre>
- </li>
- <li>
- <p>At the very bottom inside the <code>draw()</code> function, insert the following line. This is the key to the whole operation — we are setting the variable we defined earlier to an active <code>requestAnimation()</code> call that takes the <code>draw()</code> function as its parameter. This starts the animation off, constantly running the <code>draw()</code> function at a rate of as close to 60 FPS as possible.</p>
-
- <pre class="brush: js">rAF = requestAnimationFrame(draw);</pre>
- </li>
-</ol>
-
-<div class="blockIndicator note">
-<p><strong>Note</strong>: You can find this <a href="https://mdn.github.io/learning-area/javascript/asynchronous/loops-and-intervals/simple-raf-spinner.html">example live on GitHub</a> (see the <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/loops-and-intervals/simple-raf-spinner.html">source code</a> also).</p>
-</div>
-
-<h3 id="Clearing_a_requestAnimationFrame()_call">Clearing a requestAnimationFrame() call</h3>
-
-<p>Clearing a <code>requestAnimationFrame()</code> call can be done by calling the corresponding <code>cancelAnimationFrame()</code> method (note, "cancel" not "clear" as with the "set..." methods), passing it the value returned by the <code>requestAnimationFrame()</code> call to cancel, which we stored in a variable called <code>rAF</code>:</p>
-
-<pre class="brush: js">cancelAnimationFrame(rAF);</pre>
-
-<h3 id="Active_learning_Starting_and_stopping_our_spinner">Active learning: Starting and stopping our spinner</h3>
-
-<p>In this exercise, we'd like you to test out the <code>cancelAnimationFrame()</code> method by taking our previous example and updating it, adding an event listener to start and stop the spinner when the mouse is clicked anywhere on the page.</p>
-
-<p>Some hints:</p>
-
-<ul>
- <li>A <code>click</code> event handler can be added to most elements, including the document <code>&lt;body&gt;</code>. It makes more sense to put it on the <code>&lt;body&gt;</code> element if you want to maximize the clickable area — the event bubbles up to its child elements.</li>
- <li>You'll want to add a tracking variable to check whether the spinner is spinning or not, clearing the animation frame if it is, and calling it again if it isn't.</li>
-</ul>
-
-<div class="blockIndicator note">
-<p><strong>Note</strong>: Try this yourself first; if you get really stuck, check out of our <a href="https://mdn.github.io/learning-area/javascript/asynchronous/loops-and-intervals/start-and-stop-spinner.html">live example</a> and <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/loops-and-intervals/start-and-stop-spinner.html">source code</a>.</p>
-</div>
-
-<h3 id="Throttling_a_requestAnimationFrame()_animation">Throttling a requestAnimationFrame() animation</h3>
-
-<p>One limitation of <code>requestAnimationFrame()</code> is that you can't choose your frame rate. This isn't a problem most of the time, as generally you want your animation to run as smoothly as possible, but what about when you want to create an old school, 8-bit-style animation?</p>
-
-<p>This was a problem for example in the Monkey Island-inspired walking animation from our <a href="/en-US/docs/Learn/JavaScript/Client-side_web_APIs/Drawing_graphics">Drawing Graphics</a> article:</p>
-
-<p>{{EmbedGHLiveSample("learning-area/javascript/apis/drawing-graphics/loops_animation/7_canvas_walking_animation.html", '100%', 260)}}</p>
-
-<p>In this example we have to animate both the position of the character on the screen, and the sprite being shown. There are only 6 frames in the sprite's animation; if we showed a different sprite frame for every frame displayed on the screen by <code>requestAnimationFrame()</code>, Guybrush would move his limbs too fast and the animation would look ridiculous. We therefore throttled the rate at which the sprite cycles its frames using the following code:</p>
-
-<pre class="brush: js">if (posX % 13 === 0) {
- if (sprite === 5) {
- sprite = 0;
- } else {
- sprite++;
- }
-}</pre>
-
-<p>So we are only cycling a sprite once every 13 animation frames. OK, so it's actually about every 6.5 frames, as we update <code>posX</code> (character's position on the screen) by two each frame:</p>
-
-<pre class="brush: js">if(posX &gt; width/2) {
- newStartPos = -((width/2) + 102);
- posX = Math.ceil(newStartPos / 13) * 13;
- console.log(posX);
-} else {
- posX += 2;
-}</pre>
-
-<p>This is the code that works out how to update the position in each animation frame.</p>
-
-<p>The method you use to throttle your animation will depend on your particular code. For example, in our spinner example we could make it appear to move slower by only increasing our <code>rotateCount</code> by one on each frame instead of two.</p>
-
-<h2 id="Active_learning_a_reaction_game">Active learning: a reaction game</h2>
-
-<p>For our final section of this article, we'll create a 2-player reaction game. Here we have two players, one of whom controls the game using the <kbd>A</kbd> key, and the other with the <kbd>L</kbd> key.</p>
-
-<p>When the <em>Start</em> button is pressed, a spinner like the one we saw earlier is displayed for a random amount of time between 5 and 10 seconds. After that time, a message will appear saying "PLAYERS GO!!" — once this happens, the first player to press their control button will win the game.</p>
-
-<p>{{EmbedGHLiveSample("learning-area/javascript/asynchronous/loops-and-intervals/reaction-game.html", '100%', 500)}}</p>
-
-<p>Let's work through this.</p>
-
-<ol>
- <li>
- <p>First of all, download the <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/loops-and-intervals/reaction-game-starter.html">starter file for the app</a> — this contains the finished HTML structure and CSS styling, giving us a game board that shows the two players' information (as seen above), but with the spinner and results paragraph displayed on top of one another. We just have to write the JavaScript code.</p>
- </li>
- <li>
- <p>Inside the empty {{htmlelement("script")}} element on your page, start by adding the following lines of code that define some constants and variables we'll need in the rest of the code:</p>
-
- <pre class="brush: js">const spinner = document.querySelector('.spinner p');
-const spinnerContainer = document.querySelector('.spinner');
-let rotateCount = 0;
-let startTime = null;
-let rAF;
-const btn = document.querySelector('button');
-const result = document.querySelector('.result');</pre>
-
- <p>In order, these are:</p>
-
- <ol>
- <li>A reference to our spinner, so we can animate it.</li>
- <li>A reference to the {{htmlelement("div")}} element that contains the spinner, used for showing and hiding it.</li>
- <li>A rotate count — how much we want to show the spinner rotated on each frame of the animation.</li>
- <li>A null start time — will be populated with a start time when the spinner starts spinning.</li>
- <li>An uninitialized variable to later store the {{domxref("Window.requestAnimationFrame", "requestAnimationFrame()")}} call that animates the spinner.</li>
- <li>A reference to the Start button.</li>
- <li>A reference to the results paragraph.</li>
- </ol>
- </li>
- <li>
- <p>Next, below the previous lines of code, add the following function. This simply takes two numerical inputs and returns a random number between the two. We'll need this to generate a random timeout interval later on.</p>
-
- <pre class="brush: js">function random(min,max) {
- var num = Math.floor(Math.random()*(max-min)) + min;
- return num;
-}</pre>
- </li>
- <li>
- <p>Next add in the <code>draw()</code> function, which animates the spinner. This is exactly the same as the version seen in the simple spinner example we looked at earlier:</p>
-
- <pre class="brush: js"> function draw(timestamp) {
- if(!startTime) {
- startTime = timestamp;
- }
-
- let rotateCount = (timestamp - startTime) / 3;
- spinner.style.transform = 'rotate(' + rotateCount + 'deg)';
-
- if(rotateCount &gt; 359) {
- rotateCount -= 360;
- }
-
- rAF = requestAnimationFrame(draw);
- }</pre>
- </li>
- <li>
- <p>Now it is time to set up the initial state of the app when the page first loads. Add the following two lines, which simply hide the results paragraph and spinner container using <code>display: none;</code>.</p>
-
- <pre class="brush: js">result.style.display = 'none';
-spinnerContainer.style.display = 'none';</pre>
- </li>
- <li>
- <p>We'll also define a <code>reset()</code> function, which sets the app back to the original state required to start the game again after it has been played. Add the following at the bottom of your code:</p>
-
- <pre class="brush: js">function reset() {
- btn.style.display = 'block';
- result.textContent = '';
- result.style.display = 'none';
-}</pre>
- </li>
- <li>
- <p>OK, enough preparation.  Let's make the game playable! Add the following block to your code. The <code>start()</code> function calls <code>draw()</code> to start the spinner spinning and display it in the UI, hides the <em>Start</em> button so we can't mess up the game by starting it multiple times concurrently, and runs a <code>setTimeout()</code> call that runs a <code>setEndgame()</code> function after a random interval between 5 and 10 seconds has passed. We also add an event listener to our button to run the <code>start()</code> function when it is clicked.</p>
-
- <pre class="brush: js">btn.addEventListener('click', start);
-
-function start() {
- draw();
- spinnerContainer.style.display = 'block';
- btn.style.display = 'none';
- setTimeout(setEndgame, random(5000,10000));
-}</pre>
-
- <div class="blockIndicator note">
- <p><strong>Note</strong>: You'll see that in this example we are calling <code>setTimeout()</code> without storing the return value (so not <code>let myTimeout = setTimeout(functionName, interval)</code>). This works and is fine, as long as you don't need to clear your interval/timeout at any point. If you do, you'll need to save the returned identifier.</p>
- </div>
-
- <p>The net result of the previous code is that when the <em>Start</em> button is pressed, the spinner is shown and the players are made to wait a random amount of time before they are then asked to press their button. This last part is handled by the <code>setEndgame()</code> function, which we should define next.</p>
- </li>
- <li>
- <p>So add the following function to your code next:</p>
-
- <pre class="brush: js">function setEndgame() {
- cancelAnimationFrame(rAF);
- spinnerContainer.style.display = 'none';
- result.style.display = 'block';
- result.textContent = 'PLAYERS GO!!';
-
- document.addEventListener('keydown', keyHandler);
-
- function keyHandler(e) {
- console.log(e.key);
- if(e.key === 'a') {
- result.textContent = 'Player 1 won!!';
- } else if(e.key === 'l') {
- result.textContent = 'Player 2 won!!';
- }
-
- document.removeEventListener('keydown', keyHandler);
- setTimeout(reset, 5000);
- };
-}</pre>
-
- <p>Stepping through this:</p>
-
- <ol>
- <li>First we cancel the spinner animation with {{domxref("window.cancelAnimationFrame", "cancelAnimationFrame()")}} (it is always good to clean up unneeded processes), and hide the spinner container.</li>
- <li>Next we display the results paragraph and set its text content to "PLAYERS GO!!" to signal to the players that they can now press their button to win.</li>
- <li>We then attach a <code><a href="/en-US/docs/Web/API/Document/keydown_event">keydown</a></code> event listener to our document — when any button is pressed down, the <code>keyHandler()</code> function is run.</li>
- <li>Inside <code>keyHandler()</code>, we include the event object as a parameter (represented by <code>e</code>) — its {{domxref("KeyboardEvent.key", "key")}} property contains the key that was just pressed, and we can use this to respond to specific key presses with specific actions.</li>
- <li>We first log <code>e.key</code> to the console, which is a useful way of finding out the <code>key</code> value of different keys you are pressing.</li>
- <li>When <code>e.key</code> is "a", we display a message to say that Player 1 won, and when <code>e.key</code> is "l", we display a message to say Player 2 won. Note that this will only work with lowercase a and l — if an uppercase A or L is submitted (the key plus <kbd>Shift</kbd>), it is counted as a different key.</li>
- <li>Regardless of which one of the player control keys was pressed, we remove the <code>keydown</code> event listener using {{domxref("EventTarget.removeEventListener", "removeEventListener()")}} so that once the winning press has happened, no more keyboard input is possible to mess up the final game result. We also use <code>setTimeout()</code> to call <code>reset()</code> after 5 seconds — as we explained earlier, this function resets the game back to its original state so that a new game can be started.</li>
- </ol>
- </li>
-</ol>
-
-<p>That's it, you're all done.</p>
-
-<div class="blockIndicator note">
-<p><strong>Note</strong>: If you get stuck, check out <a href="https://mdn.github.io/learning-area/javascript/asynchronous/loops-and-intervals/reaction-game.html">our version of the reaction game</a> (see the <a href="https://github.com/mdn/learning-area/blob/master/javascript/asynchronous/loops-and-intervals/reaction-game.html">source code</a> also).</p>
-</div>
-
-<h2 id="Conclusion">Conclusion</h2>
-
-<p>So that's it — all the essentials of async loops and intervals covered in one article. You'll find these methods useful in a lot of situations, but take care not to overuse them — since these still run on the main thread, heavy and intensive callbacks (especially those that manipulate the DOM) can really slow down a page if you're not careful.</p>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/Asynchronous/Introducing", "Learn/JavaScript/Asynchronous/Promises", "Learn/JavaScript/Asynchronous")}}</p>
-
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Concepts">עקרונות תכנות א-סינכרוני כלליים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Introducing">הצגת asynchronous JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Timeouts_and_intervals">Asynchronous JavaScript: שימוש ב-Intervals ו-Timeouts</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Promises">טיפול בפעולות א-סינכרוניות באמצעות Promises</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Async_await">הפיכת Asynchronous Programming לקל יותר עם async ועם await</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Asynchronous/Choosing_the_right_approach">בחירת האפשרות המתאימה</a></li>
-</ul>
diff --git a/files/he/learn/javascript/building_blocks/build_your_own_function/index.html b/files/he/learn/javascript/building_blocks/build_your_own_function/index.html
deleted file mode 100644
index 47df4e6b3a..0000000000
--- a/files/he/learn/javascript/building_blocks/build_your_own_function/index.html
+++ /dev/null
@@ -1,247 +0,0 @@
----
-title: בניית פונקציה משלנו
-slug: Learn/JavaScript/Building_blocks/Build_your_own_function
-translation_of: Learn/JavaScript/Building_blocks/Build_your_own_function
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/Building_blocks/Functions","Learn/JavaScript/Building_blocks/Return_values", "Learn/JavaScript/Building_blocks")}}</div>
-
-<p class="summary">לאחר שסיימנו את רוב התיאוריה במאמר הקודם, מאמר זה נועד להעניק לכם ניסיון מעשי. אנחנו ננסה להעניק לכם כלים לבנות את הפונקציה שלכם. במהלך הדרך, אנחנו נסביר כמה פרטים שימושיים בקשר לשימוש בפונקציות.</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>הכרות בסיסית עם המחשב ועם הבסיס של HTML ו- CSS, וכן סיום במלאו של <a href="/en-US/docs/Learn/JavaScript/First_steps">מודול צעדים ראשונים ב-JavaScript</a>., <a href="/en-US/docs/Learn/JavaScript/Building_blocks/Functions">Functions — פונקציות - חלקי קוד לשימוש חוזר</a>.</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>לספק לכם כלים לבניית פונקציות ולהסביר פרטים שימושיים בהקשר של בניית פונקציות.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="למידה_עצמאית_בניית_פונקציה">למידה עצמאית: בניית פונקציה</h2>
-
-<p>הפונקציה שנראה לבנות תיקרא <code>displayMessage()</code>. היא תציג הודעה על גבי דף אינטרנט, אשר תחליף את הפונקציה המובנית של הדפדפן <a href="/en-US/docs/Web/API/Window/alert">alert()</a>. ראינו משהו דומה לפני כן,על מנת לרענן את הזכרון, הדפיסו את הקוד הבא בקונסולה</p>
-
-<pre class="brush: js notranslate">alert('This is a message');</pre>
-
-<p>הפונקציה <code>alert</code> מקבל פרמטר אחד כארגומנט - המחרוזת ששתוצג על גבי תיבת ההודעה. נא לשנות המחרוזת על מנת לשנות את ההודעהf</p>
-
-<p>הפונקציה <code>alert</code> היא מוגבלת: אנחנו יכולים לשנות את הטקסט, אבל אנחנו לא ממש יכולים לשנות בקלות את כל היתר כמו צבעים, אייקון, או כל דבר אחר. אנו נבנבה פונקציה שתאפשר לנו את הדברים הללו.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong> דוגמא זו אמורה לעבוד בכל הדפדפדנים המודרניים, אבל העיצוב עלול להיראות קצת מוזר בדפדפנים ישנים. אנחנו ממליצים ללכם להתשמשמ בדפדפן מודרני כגון פיירפוקס, כרום או אופרה לשם תרגול זה.</p>
-</div>
-
-<h2 id="הפונקציה_הבסיסית">הפונקציה הבסיסית</h2>
-
-<p>על מנת להתחיל, בואו נבנה פונקציה בסיסית</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: הכללים בנושא מתן שמות לפונקציה הם דומים לכללים בנושא <a href="/en-US/Learn/JavaScript/First_steps/Variables#An_aside_on_variable_naming_rules">מתן שמות למשתנים</a>. יחד עם זאת, בפונקציות, לאחר השם יבואו סוגריים רגילות () ואילו במשתנים לא.</p>
-</div>
-
-<ol>
- <li>התחילו בכך שתיצרו עותק מקומי של הקובץ <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/functions/function-start.html">function-start.html</a>. בקובץ אתם תיראו שה-body כולל כפתור אחד. בנוסף הוספנו גם כמה כללי css פשוטים על מנת לעצב את תיבת ההודעה שלנו וכן אלממנט {{htmlelement("script")}} ריקה שבה נוסיף את קוד ה-JavaScriipt שלנו.</li>
- <li>לאחר מכן, הוסיפו הקוד הבא בתוך האלמנט <code>&lt;script&gt;</code>:
- <pre class="brush: js notranslate">function displayMessage() {
-
-}</pre>
- אנחנו מתחילים עם המילה השמורה <code>function</code>, אשר משמעותה היא שאנחנו מגדירים פונקציה. לאחר מכן, אנחנו רושמים את שם הפונקציה שנרצה לתת לה, ולאחר מכן סוגריים רגילות () ולאחריהן סוגריים מסולסלות {....}. הפרמטרים שנרצה לתת לפונקציה שלנו - הארגומנטים, ייכנסו בתוך הסוגריים הרגילות (ובמידה שיש לנו כמה ארגומנטים, נפריד ביניהם באמצעות פסיק , ורווח.) את הקוד שנרצה שהפונקציה תריץ בכל פעם שנקרא לה אנחנו נשים בתוך הסוגריים המסולסות {....}.</li>
- <li>לבסוף, הוסיפו את התקוד הבא בתוך הסוגריים המסולסלות
- <pre class="brush: js notranslate">var html = document.querySelector('html');
-
-var panel = document.createElement('div');
-panel.setAttribute('class', 'msgBox');
-html.appendChild(panel);
-
-var msg = document.createElement('p');
-msg.textContent = 'This is a message box';
-panel.appendChild(msg);
-
-var closeBtn = document.createElement('button');
-closeBtn.textContent = 'x';
-panel.appendChild(closeBtn);
-
-closeBtn.onclick = function() {
- panel.parentNode.removeChild(panel);
-}</pre>
- </li>
-</ol>
-
-<p>נעבור על הקוד שהוספנו שורה אחר שורה</p>
-
-<p>השורה הראשונה משתמשת בפונקציה של DOM API הנקראת {{domxref("document.querySelector()")}}, על מנת לבחור אלמנט מסוג {{htmlelement("html")}} ולאחסן הפנייה אליו בתוך משתנה שנקרא <code>html</code>, כדי שנוכל לבצע איתו דברים מאוחר יותר:</p>
-
-<pre class="brush: js notranslate">var html = document.querySelector('html');</pre>
-
-<p>החלק הבא בקוד שלנו משתמש בפונקציה נוספת של DOM API הנקראת {{domxref("document.createElement()")}} על מנת ליצור אלמנט מסוג {{htmlelement("div")}} ואנו מאחסנים הפניה אליו בתוך המשתנה שנקרא <code>panel</code>. האלמנט הזה יהיה הקונטיינר החיצוני של תיבת ההודעה שלנו.</p>
-
-<p>לאחר מכן אנחנו משתמשים בפונקציה נוספת של DOM API שנקראת <code>class</code> על מנת לקבוע {{domxref("Element.setAttribute()")}} למשתנה <code>msgBox</code> שלנו עם הערך <code>msgBox</code>. זה אמור להקל עלינו לעצב את האלמנט - אם תסתכלו ב-CSS שבדךף, אתם תראו שאנחנו משתשמים בסלקטור של CSS <code>.msgBox</code> על מנת לעצב את תיבת ההודעה והתוכן שלה.</p>
-
-<p>לבסוף - אנחנו קוראים לפונקציית DOM נוספת שנקראת {{domxref("Node.appendChild()")}} על גבי המשתנה <code>html</code> , אשר משרשרת את האלמנט שהיא מקבלת כארגומנט לאלמנט שהיא הופעלה עליו. כאן אנחנו מציינים שאנחנו רוצים שהאלמנט <code>&lt;div&gt;</code> יהיה אלמנט ילד של האלמנט <code>&lt;html&gt;</code>. אחנו צריכים להוסיף פונקציה זו בכל פעם שאנחנו משתמשים בפונקציה {{domxref("document.createElement()")}}, מכיוון שהאלמנט שיצרנו לא יופיע בעצמו ולא יתחבר בעצמו לאלמנט אחר - אנחנו צריכים לציין איפה אנחנו רוצים לשים אותו ולמי הוא יהיה קשור.</p>
-
-<pre class="brush: js notranslate">var panel = document.createElement('div');
-panel.setAttribute('class', 'msgBox');
-html.appendChild(panel);</pre>
-
-<p>ב-2 החלקים הבאים אנחנו עושים שימוש באותן פונקציות <code>createElement()</code> ן- <code>appendChild()</code> שהשתמשנו בהן על מנת ליצור שני אלמנטים חדשים: {{htmlelement("p")}} ו- {{htmlelement("button")}} — ומכניסים אותם בתוך הדף כאלמנטים ילדים של <code>&lt;div&gt;</code> panel. לאחר מכן אנחנו משתמשים בפרופ׳ {{domxref("Node.textContent")}} - אשר מייצג בעצם את תוכן הטקסט של אלמנט - על מנת להכניס הודעה בתוך הפסקה וכן אנחנו מוסיפים את התו 'x' בתוך הכפתור. הכפתור הזה צריך להיות לחוץ/מופעל כשהמשתמש רוצה לסגור את תיבת ההודעה.</p>
-
-<pre class="brush: js notranslate">var msg = document.createElement('p');
-msg.textContent = 'This is a message box';
-panel.appendChild(msg);
-
-var closeBtn = document.createElement('button');
-closeBtn.textContent = 'x';
-panel.appendChild(closeBtn);</pre>
-
-<p>לבסוף, אנחנו משתמשים במאזין אירוע ומטפל אירוע - {{domxref("GlobalEventHandlers.onclick")}} - על מנת להוסיף האזנה להתרחשות אירוע של לחיצה (במקרה הזה לחיצה על ) closeBtn וטיפול באותו אירוע על ידי הפונקציה האנונימית המכילה קוד שמוחק את כל ה-panel מהדף - כלומר מוחק את תיבת ההודעה.</p>
-
-<p>בקצרה, מאזין האירוע <code>onclick</code> הוא פרופ׳ שזמין עבור כפתור (ובעצם זמין עבור כל אלמנט בדף) שיכול להיות מוגדר לפונקציה שתבצע קוד מסויים כאשר הכפתור/האלמנט נלחץ. אנחנו נלמד על כך לעומק במאמר שלנו בנושא אירועים. שימו לב שוב שמטפל האירוע של מאזין האירוע <code>onclick</code> שווה לפונקציה אנונימית, אשר מכילה קוד שירוץ כאשר הכפתור נלחץ. שורת הקוד שבתוך הפונקציה האנונימית משתמש בפונקציה של ה- DOM API בשם {{domxref("Node.removeChild()")}} על מנת להסיר אלמנט בן של אלמנט - במקרה זה של אלמנט <code>&lt;div&gt;</code>.</p>
-
-<pre class="brush: js notranslate">closeBtn.onclick = function() {
- panel.parentNode.removeChild(panel);
-}</pre>
-
-<p>בעיקרון - כל הקוד הזה פשוט יוצר בלוק של HTML שנראה כך ומכניס את זה לתוך הדף:</p>
-
-<pre class="brush: html notranslate">&lt;div class="msgBox"&gt;
- &lt;p&gt;This is a message box&lt;/p&gt;
- &lt;button&gt;x&lt;/button&gt;
-&lt;/div&gt;</pre>
-
-<p>זה היה הרבה קוד לעבור עליו - אל תדאגו אם אתם לא זוכרים במדויק איך הוא עובד כרגע. הרעיון המרכזי שאנחנו רוצים לשים עליו דגש כאן הוא הפונקציה, המבנה שלה והשימוש שלה.</p>
-
-<h2 id="קריאה_לפונקציההפעלת_הפונקציה">קריאה לפונקציה/הפעלת הפונקציה</h2>
-
-<p>כעת יש לנו את הגדרת הפונקציה בתוך האלמנט 555555, אבל היא לא תבצע כלום אם לא נקרא לה.</p>
-
-<ol>
- <li>נסו לכלול את הקוד הבא מחת לפונקציה על מנת לקרוא לה:
- <pre class="brush: js notranslate">displayMessage();</pre>
- שורה זו בעצם קוראת פונקציה (Invoking the function) וגורמת לה לרוץ מיד. כאשר תשמרו את הקוד ותעלו מחדש את הדף בדפדפן, אתם תראו שתיבת ההודעה הופיע מיד, פעם אחת. אחרי הכל, קראנו לפונקציה רק פעם אחת.</li>
- <li>
- <p>כעת, פתחו את הקונסולה והדפיסו את השורה למעלה שוב, ואתם תראו את ההודעה שוב. כלומר בנינו פונקציה שאנחנו יכולים להשתמש בה שוב ושוב.</p>
-
- <p>רוב הסיכויים שנרצה שתיבת ההודעה תופיע כתגובה לאירועים מסויימים של המערכת או של המשתמש. ביישומים אמיתיים, תיבת הודעה שכזו תיקרא בתגובה למידע חדש שזמין או לשגיאה שנוצרה, או כאשר המשתמש מוחק את הפרופיל שלו (״האם אתה בטוח רוצה למחוק את הפרופיל? וכד׳).</p>
-
- <p>בתרגול זה, אנחנו נגרום לתיבת ההודעה להופיע כאשר המשתמש לוחץ על כפתור.</p>
- </li>
- <li>מחקו את השורה שהוספתם.</li>
- <li>כעת, אנחנו נבחר את הכפתור ונאחסן הפניה אליו בתוך משתנה. הוסיפו את הקוד הבא לקוד שלהם, מעל הגדרת הפונקציה :
- <pre class="brush: js notranslate">var btn = document.querySelector('button');</pre>
- </li>
- <li>לבסו, הוסיפו את הקוד הבא, מתחת לקוד שהוספתם בסעיף הקודם:
- <pre class="brush: js notranslate">btn.onclick = displayMessage;</pre>
- בדרך דומה ל<code> ...closeBtn.onclick</code> בתוך הפונקציה, כאן אנחנו קוראים קוד מסויים בתגובה כך שהכפתור נלחץ. אבל במקרה הזה במקום לקרוא לפונקציה אנונימית המכילה את אותו קוד, אנחנו קוראים לפונקציה שלנו בשמה באופן מפורש.</li>
- <li>נסו לשמור ולרענן את הדף - אתם אמורים לראות את תיבת ההודעה כאשר הכפתור נלחץ.</li>
-</ol>
-
-<p>אתם בטח תוהים מדוע לא כללנו סוגריים () אחרי שם הפונקציה. הסיבה היא שאנחנו לא רוצים לקרוא לפונקציה ישר - אלא רק אחרי שהכפתור נלחץ. אם תשנו את השורה הבא כך:</p>
-
-<pre class="brush: js notranslate">btn.onclick = displayMessage();</pre>
-
-<p>ותרעננו את הדף, אתם תיראו שהתיבת ההודעה הופיע מבלי שלחצנו על הכפתור. הסוגריים () בהקשר זה לפעמים נקראים "function invocation operator". אנחנו משתמשים בהם כאשר אנחנו רוצים להריץ את הפונקציה באופן מיידי בתוך הסקופ הנוכחי. באותו דרך, הקוד שבתוך הפונקציה האנונימית לא ירוץ ישר, שכן הוא נמצא בתוך הסקופ של הפונקציה בלבד - שכאמור תופעל רק כאשר כפתור יילחץ.</p>
-
-<p>אם ניסיתם את התרגול הקודם של הוספת (), אנא וודאו שמחקתם אותם לפני שאתם ממשיכים</p>
-
-<h2 id="שדרוג_הפונקציה_שלנו_באמצעות_פרמטריםארגומנטים">שדרוג הפונקציה שלנו באמצעות פרמטרים/ארגומנטים</h2>
-
-<p>כרגע, הפונקציה שלנו לא ממש שימושית - אנחנו לא רוצים סתם להציג הודעה זהה בכל פעם. ננסה לשדרג אוהת על ידי כך שנוסיף מספר פרמטרים, אשר יאפשרו לנו לקרוא לה, אך עם אפשרויות שונות בכל קריאה.</p>
-
-<ol>
- <li>תחילה, עדכנו את השורה הראשונה של הפונקציה:
- <pre class="brush: js notranslate">function displayMessage() {</pre>
-
- <div>לקוד הבא:</div>
-
- <pre class="brush: js notranslate">function displayMessage(msgText, msgType) {</pre>
- כעת, כאשר אנחנו קוראים לפונקציה, אנחנו מספקים לה שני ערכים של משתנים בתוך הסוגריים () על מנת לציין את תוכן ההודעה שתוצג ואת סוג ההודעה.</li>
- <li>על מנת לעשות שימוש בפרמטר הראשון, עדכנו את הקוד שבתוך הפונקציה :
- <pre class="brush: js notranslate">msg.textContent = 'This is a message box';</pre>
-
- <div>לקוד הבא</div>
-
- <pre class="brush: js notranslate">msg.textContent = msgText;</pre>
- </li>
- <li>לבסוף, אנחנו נרצה לעדכן כעת את הפונקציה כך שתכלול הודעה מעודכנת . שנה את השורה הבאה:
- <pre class="brush: js notranslate">btn.onclick = displayMessage;</pre>
-
- <div>לקוד הבא :</div>
-
- <pre class="brush: js notranslate">btn.onclick = function() {
- displayMessage('Woo, this is a different message!');
-};</pre>
- If we want to specify parameters inside parentheses for the function we are calling, then we can't call it directly — we need to put it inside an anonymous function so that it isn't in the immediate scope and therefore isn't called immediately. Now it will not be called until the button is clicked.</li>
- <li>עכשיו טען מחדש ונסה שוב את הקוד ותראה שהוא עדיין עובד כמו מקודם ,רק שעכשיו גם התווסף אפשרות לשנות את ההודעה שבתוך הפרמטר כדי להציג הודעות שונות בתיבה! </li>
-</ol>
-
-<h3 id="פרמטר_מורכב_יותר">פרמטר מורכב יותר</h3>
-
-<p>הלאה לפרמטר הבא. זו תכלול עבודה מעט יותר - אנו מתכוונים להגדיר אותה כך שלפי הפרמטר msgType, הפונקציה תציג אייקון אחר וצבע רקע שונה.</p>
-
-<ol>
- <li>First of all, download the icons needed for this exercise (<a href="https://raw.githubusercontent.com/mdn/learning-area/master/javascript/building-blocks/functions/icons/warning.png">warning</a> and <a href="https://raw.githubusercontent.com/mdn/learning-area/master/javascript/building-blocks/functions/icons/chat.png">chat</a>) from GitHub. Save them in a new folder called <code>icons</code> in the same location as your HTML file.
-
- <div class="note"><strong>Note</strong>: The warning and chat icons were originally found on <a href="https://www.iconfinder.com/">iconfinder.com</a>, and designed by <a href="https://www.iconfinder.com/nazarr">Nazarrudin Ansyari</a> — Thanks! (The actual icon pages were since moved or removed.)</div>
- </li>
- <li>Next, find the CSS inside your HTML file. We'll make a few changes to make way for the icons. First, update the <code>.msgBox</code> width from:
- <pre class="brush: css notranslate">width: 200px;</pre>
-
- <div>ל</div>
-
- <pre class="brush: css notranslate">width: 242px;</pre>
- </li>
- <li>Next, add the following lines inside the <code>.msgBox p { ... }</code> rule:
- <pre class="brush: css notranslate">padding-left: 82px;
-background-position: 25px center;
-background-repeat: no-repeat;</pre>
- </li>
- <li>Now we need to add code to our <code>displayMessage()</code> function to handle displaying the icons. Add the following block just above the closing curly brace (<code>}</code>) of your function:
- <pre class="brush: js notranslate">if (msgType === 'warning') {
- msg.style.backgroundImage = 'url(icons/warning.png)';
- panel.style.backgroundColor = 'red';
-} else if (msgType === 'chat') {
- msg.style.backgroundImage = 'url(icons/chat.png)';
- panel.style.backgroundColor = 'aqua';
-} else {
- msg.style.paddingLeft = '20px';
-}</pre>
- Here, if the <code>msgType</code> parameter is set as <code>'warning'</code>, the warning icon is displayed and the panel's background color is set to red. If it is set to <code>'chat'</code>, the chat icon is displayed and the panel's background color is set to aqua blue. If the <code>msgType</code> parameter is not set at all (or to something different), then the <code>else { ... }</code> part of the code comes into play, and the paragraph is simply given default padding and no icon, with no background panel color set either. This provides a default state if no <code>msgType</code> parameter is provided, meaning that it is an optional parameter!</li>
- <li>Let's test out our updated function, try updating the <code>displayMessage()</code> call from this:
- <pre class="brush: js notranslate">displayMessage('Woo, this is a different message!');</pre>
-
- <div>to one of these:</div>
-
- <pre class="brush: js notranslate">displayMessage('Your inbox is almost full — delete some mails', 'warning');
-displayMessage('Brian: Hi there, how are you today?','chat');</pre>
- You can see how useful our (now not so) little function is becoming.</li>
-</ol>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אם אתם נתקלים בבעיות או הדוגמא אינה עובדת לכם, אנא בדקו את הקוד שלכם אל מול <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/functions/function-stage-4.html">הקוד הסופי שלנו ב- GitHub</a> (<a href="http://mdn.github.io/learning-area/javascript/building-blocks/functions/function-stage-4.html">או בדף האינטרנט</a> או שאלו אותנו</p>
-</div>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>במאמר זה ניסינו להסביר לכם את התהליך של בניית פונקציה בעצמנו, כאשר עם עט עבודה נוספת, יכול להפוך לפרוייקט אמיתי. במאמר הבא אנחנו נסיים לעבור על נושא פונקציות ונסביר עקרון חשוב נוסף בנושא זה - ערכי החזרה — return values.</p>
-
-<ul>
-</ul>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/Building_blocks/Functions","Learn/JavaScript/Building_blocks/Return_values", "Learn/JavaScript/Building_blocks")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/conditionals">קבלת החלטות בקוד - משפטי תנאי - Conditionals</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Looping_code">לולאות - Loops</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Functions">פונקציות - בלוקי קוד לשימוש חוזר - Functions</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Build_your_own_function">בניית פונקציות משלנו</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Return_values">ערכים מוחזרים מהפונקציה - Function return values </a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Events">היכרות ראשונית עם אירועים -Introduction to events</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Image_gallery">תרגול: בניית גלריית תמונות</a></li>
-</ul>
diff --git a/files/he/learn/javascript/building_blocks/conditionals/index.html b/files/he/learn/javascript/building_blocks/conditionals/index.html
deleted file mode 100644
index e76c9c16cb..0000000000
--- a/files/he/learn/javascript/building_blocks/conditionals/index.html
+++ /dev/null
@@ -1,790 +0,0 @@
----
-title: משפטי תנאי - קבלת החלטות בקוד שלנו
-slug: Learn/JavaScript/Building_blocks/conditionals
-tags:
- - Conditionals
- - Switch
- - else if
- - if ... else
- - ternary
- - אופרטור טרנארי
- - משפטי אם...אחר
- - משפטי תנאי
- - תנאים
-translation_of: Learn/JavaScript/Building_blocks/conditionals
-original_slug: Learn/JavaScript/Building_blocks/תנאים
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{NextMenu("Learn/JavaScript/Building_blocks/Looping_code", "Learn/JavaScript/Building_blocks")}}</div>
-
-<p class="summary">כמו בכל שפת תכנות, הקוד שלנו צריך ״לקבל החלטות״ בעצמו ולבצע פעולות מסויימות בהתאם למקרים שונים. לדוגמא - במשחק, אם מספר הנסיונות המותרים של השחקן עבר את מספר הנסיונות המקסימלי שהוגדר, המשמעות היא שהמשחק הסתיים. דוגמא נוספת היא יישום אינטרנט של מזג אוויר אשר יציג למשתמש עיצוב מסויים של מזג האוויר בהתאם לשעה הנוכחית ביום, כך שבשעות היום יוצג עיצוב בהיר ובשעות הערב יוצג עיצוב כהה. במאמר זה אנחנו נחקור את המבנה של משפטי תנאי ב-JavaScript וכיצד הם עובדים.</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>הכרות בסיסית עם המחשב ועם הבסיס של HTML ו- CSS, וכן סיום במלאו של <a href="/en-US/docs/Learn/JavaScript/First_steps">מודול צעדים ראשונים ב-JavaScript</a>.</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>להבין כיצד להשתמש במשפטי תנאי ב-JavaScript.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תנאים_והתניות_בחיים_האמיתיים">תנאים והתניות בחיים האמיתיים</h2>
-
-<p>בני האדם מקבלים החלטות שמשפיעות על החיים שלהם באופן קבוע, מהחלטה קטנה האם לאכול שתי עוגיות או אחת עד להחלטות מורכבות האם לעזוב את העבודה או האם ללכת ללמוד אסטרונומיה במקום סוציולוגיה.</p>
-
-<p>משפטי תנאי ב-JavaScript אפשרים לנו לייצג בקוד שלנו את התהליך של קבלת ההחלטה, החל מהחלטות שנהיה חייבים לקבל ועד החלטות שנקבל רק אם ניתקל במקרה מסויים.</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/13703/cookie-choice-small.png" style="display: block; margin: 0 auto;"></p>
-
-<h2 id="if_..._else_-_משפטי_אם_..._אחרת">if ... else - משפטי אם ... אחרת</h2>
-
-<p>נסתכל על הסוג הנפוץ ביותר של משפטי תנאי ב-JavaScript - משפט התנאי <a href="/en-US/docs/Web/JavaScript/Reference/Statements/if...else">if ... else</a>.</p>
-
-<h3 id="הסינטקס_הבסיסי_של_משפטי_if_..._else">הסינטקס הבסיסי של משפטי if ... else</h3>
-
-<p>אם ננסה להמחיש את הסינטקס הבסיסי של <code>if...else</code> בצורה מופשטת של {{glossary("pseudocode")}}, הוא ייראה כך:</p>
-
-<pre>if (condition - תנאי) {
- code to run if condition is true - הקוד שירוץ אם התנאי נכון
-} else {
- run some other code instead - הקוד שירוץ אם התנאי לא נכון
-}</pre>
-
-<p>מה שיש לנו כאן זה:</p>
-
-<ol>
- <li>המילה השמורה <code>if</code> ולאחרי סוגריים רגילות <code>()</code>.</li>
- <li>לאחר מכן - התנאי שנבדוק האם הוא מתקיים נמצא בתוך ה- <code>()</code> (כמו: ״האם הערך הזה גדול מערך אחר״ או ״הערך הזה קיים״). תנאי זה יעשה שימוש באופרטורים שדבירנו עליהם במודול הקודם - <a href="/en-US/Learn/JavaScript/First_steps/Math#Comparison_operators">comparison operators אופרטורים להשוואה </a> ויחזיר לנו ערך של אמת - <code>true</code> או ערך של שקר - <code>false</code>.</li>
- <li>לאחר מכן  - סוגריים מסולסלות - <code>{}</code> - שבתוכן נכניס כל קוד שנרצה, אשר יתבצע אך ורק אם התנאי התקיים, כלומר החזיר תוצאת אמת - <code>true</code>.</li>
- <li>לאחר מכן - מילה שמורה נוספת שהיא <code>else</code>. אשר באה לבטא מה יקרה, אם בכלל, כאשר התנאי לא יחזיר תוצאת <code>true</code>. </li>
- <li>ולבסוף - סוגריים מסולסלות נוספות<code>{}</code>- שבתוכן נכניס כל קוד שנרצה, אשר יתבצע אך ורק אם התנאי עצמו לא התקיים, כלומר החזיר תוצאת שקר - <code>false</code>.</li>
-</ol>
-
-<p>קוד זה דיי קריא ומובן על ידי בני אדם - הוא אומר בעצם ש-"<strong>אם</strong> ה- <strong>condition (התנאי)</strong> מתקיים - כלומר מחזיר ערך של אמת - <code>true</code>, תריץ את קוד A, <strong>אחרת -</strong> תריץ את קוד B"</p>
-
-<p>שימו לב שאנחנו לא חייבים את לכלול את ה- <code>else</code> ואת הסוגריים המסולסלות השניות. כך לדוגמא, התנאי הבא הוא חוקי לחלוטין:</p>
-
-<pre>if (condition) {
- code to run if condition is true
-}
-
-run some other code</pre>
-
-<p>יחד עם זאת, אנחנו צריכים לזכור שבמקרה כזה, הקוד השני שאינו חלק ממשפט התנאי, לא נשלט על ידיו ולא כפוף למשפט התנאי - מה שאומר שהוא ירוץ <strong>תמיד</strong> לא משנה אם התנאי החזיר ערך <code>true</code> או <code>false</code>. זה לאו דווקא משהו רע, אבל חשוב לדעת זאת.</p>
-
-<p>לפעמים אנחנו גם נראה משפטי- <code>if...else</code> ללא סוגריים מסולסלות כלל, בקיצור אשר נראה כך:</p>
-
-<pre>if (condition) code to run if condition is true
-else run some other code instead</pre>
-
-<p>זהו קוד תקין לחלוטין, אך <strong>אינו מומלץ לשימוש</strong> -  הרבה יותר קל לקרוא קוד ולהבין מה קורה, אם אנחנו משתמשים בסוגריים מסולסולת לתחום את הקוד, וכן משתמשים במס׳ שורות ורווחים על מנת להפוך את הקוד לקריא ומובן יותר.</p>
-
-<h3 id="דוגמא_לתרגול">דוגמא לתרגול</h3>
-
-<p>על מנת להבין את הסינטקס טוב יותר, בוא ננסה דוגמא קטנה לתרגול. דמיינו ילד אשר התבקש לעזור לאימו בביצוע הקניות. אם הוא ישלים את המשימה, הוא יקבל דמי כיס גבוהים יותר מהרגיל:</p>
-
-<pre class="brush: js">var shoppingDone = false;
-
-if (shoppingDone === true) {
- var childsAllowance = 10;
-} else {
- var childsAllowance = 5;
-}</pre>
-
-<p>עם זאת, קוד זה תמיד יגרום לכך שהילד יקבל דמי כיס מופחתים שכן בתחילת הקוד המשתנה <code>shoppingDone</code> קיבל את הערך של <code>false</code>. אנחנו צריכים למצוא דרך להפוך את הערך של המשתנה <code>shoppingDone</code> - <code>true</code> אם הילד השלים את הקניות.</p>
-
-<div class="note">
-<p><strong>תשומת לב</strong>: ניתן לראות את <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/allowance-updater.html">הפתרון לתרגול זה ב- GitHub</a> (וכן ניתן לראות אותו <a href="http://mdn.github.io/learning-area/javascript/building-blocks/allowance-updater.html">כדף אינטרנט</a>.)</p>
-</div>
-
-<h3 id="else_if_-_משפטי_התניה_משורשרים">else if - משפטי התניה משורשרים</h3>
-
-<p>הדוגמא הקודמת נתנה לנו שתי אפשרויות אך מה אם נצטרך יותר משתי אפשרויות?</p>
-
-<p>ישנה דרך לשרשר אפשרויות נוספות לתוך משפט <code>if...else</code> שלנו באמצעות שימוש ב- <code>else if</code>. כל בחירה נוספות דורשת בלוק נוסף של קוד שייכנס בין<code>{ ... }() if</code> לבין <code>{ ... }else</code> — ראו את הדוגמאות הבאות, שהן בעצם חלק מיישום פשוט לתחזית מזג אוויר:</p>
-
-<pre class="brush: html">&lt;label for="weather"&gt;Select the weather type today: &lt;/label&gt;
-&lt;select id="weather"&gt;
- &lt;option value=""&gt;--Make a choice--&lt;/option&gt;
- &lt;option value="sunny"&gt;Sunny&lt;/option&gt;
- &lt;option value="rainy"&gt;Rainy&lt;/option&gt;
- &lt;option value="snowing"&gt;Snowing&lt;/option&gt;
- &lt;option value="overcast"&gt;Overcast&lt;/option&gt;
-&lt;/select&gt;
-
-&lt;p&gt;&lt;/p&gt;</pre>
-
-<pre class="brush: js">var select = document.querySelector('select');
-var para = document.querySelector('p');
-
-select.addEventListener('change', setWeather);
-
-function setWeather() {
- var choice = select.value;
-
- if (choice === 'sunny') {
- para.textContent = 'It is nice and sunny outside today. Wear shorts! Go to the beach, or the park, and get an ice cream.';
- } else if (choice === 'rainy') {
- para.textContent = 'Rain is falling outside; take a rain coat and a brolly, and don\'t stay out for too long.';
- } else if (choice === 'snowing') {
- para.textContent = 'The snow is coming down — it is freezing! Best to stay in with a cup of hot chocolate, or go build a snowman.';
- } else if (choice === 'overcast') {
- para.textContent = 'It isn\'t raining, but the sky is grey and gloomy; it could turn any minute, so take a rain coat just in case.';
- } else {
- para.textContent = '';
- }
-}
-
-</pre>
-
-<p>{{ EmbedLiveSample('else_if', '100%', 100, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<ol>
- <li>כאן יש לנו אלמנט {{htmlelement("select")}} המאפשר לנו לבחור אפשרויות שונות, וכן פסקה פשוטה.</li>
- <li>ב-JavaScript, אנחו מאחסנים הפניות לאלמנט {{htmlelement("select")}} ולאלמנט- {{htmlelement("p")}} על ידי שמירתם במשתנים ומוסיפים ל-{{htmlelement("select")}} ״מאזין אירוע״ - event listener לאלמנט {{htmlelement("select")}} כך שכאשר הערך שלו ישתנה, הפונקציה <code>()setWeather</code>תופעל.</li>
- <li>כאשר הפונקציה הזו רצה, אנחנו מגדירים תחילה משתנה בשם <code>choice</code> ומשימים לו את הערך הרלוונטי שהמשתמש בחר באלמנט <code>&lt;select&gt;</code>. לאחר מכן, אנחנו משתמשים במשפטי תנאי על מנת לתת כיתוב שונה בטקסט של הפסקאות, בהתאם לערך שיקבל <code>&lt;select&gt;</code> בכל פעם. שימו לב שכל התנאים נבדקים בבלוקי קוד של משפט תנאי <code>{...}()else if</code>, למעט האפשרות הראשונה, אשר נבדק בבלוק של המשפט התנאי <code> {...}()if</code>.</li>
- <li>האפשרות האחרונה הנמצאת בבלוק של <code>{...}else</code> היא בעצם ברירת המחדל, או האופציה האחרונה. הקוד בבלוק שלה ירוץ רק אם אף אחד מהתנאים לא החזירו <code>true</code>. במקרה הזה, זה ישמש לרוקן את הטקסט מהפסקה ומידה ושום אופציה לא נבחרה.</li>
-</ol>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אתם גם יכולים <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/simple-else-if.html">למצוא את הדוגמא הזו ב- GitHub</a> או <a href="http://mdn.github.io/learning-area/javascript/building-blocks/simple-else-if.html">להריץ אותה</a>.</p>
-</div>
-
-<h3 id="תשומת_לב_לאופרטורים_להשוואה">תשומת לב לאופרטורים להשוואה</h3>
-
-<p>אופרטורים להשוואה משמשים לבדוק את התנאים בתוך משפטי התנאי שלנו. עברנו עליהם במאמר <a href="/he/Learn/JavaScript/First_steps/Math#Comparison_operators">מתמטיקה בסיסית ב-JavaScript — מספרים ואופרטורים</a> שלנו. האפשרויות שלנו הן:</p>
-
-<ul>
- <li><code>===</code> ו- <code>!==</code> — בודקים האם ערך אחד זהה או שונה באופן מוחלט מערך אחר.</li>
- <li><code>&lt;</code> ו- <code>&gt;</code> — בודקים האם ערך אחד קטן או גדול מערך אחר.</li>
- <li><code>&lt;=</code> ו- <code>&gt;=</code> — בודקים האם ערך אחד קטן/שווה או גדול/שווה לערך אחר .</li>
-</ul>
-
-<div class="note">
-<p><strong>לתשומת לבכם</strong>: חיזרו על החומר אם אינכם זוכרים אותם. </p>
-</div>
-
-<p>כאשנו מדברים על תוצאות ההשוואה, אנחנו רוצים לשים תשומת לב לערכים הבוליאנים שנקבל - הלא הם (<code>true</code>/<code>false</code>) ומהו המקור שלהם וכן לשים לב להתנהגות מסויימת שאנחנו ניתקל בה שוב ושוב.</p>
-
-<p>כל ערך שהוא לא <code>false</code>, <code>undefined</code>, <code>null</code>, <code>0</code>, <code>NaN</code>, או מחרוזת ריקה - (<code>''</code>), יחזיר לנו אמת - <code>true</code> כאשר הוא נבדק כתנאי במשפט תנאי. ולכן, אנחנו יכולים להשתמש רק בשם של המשתנה בלבד על מנת לבדוק האם הוא אמת או אפילו לבדוק האם הוא קיים - כלומר הוא לא <code>undefined</code> לדוגמא:</p>
-
-<pre class="brush: js">var cheese = 'Cheddar';
-
-if (cheese) {
- console.log('Yay! Cheese available for making cheese on toast.');
-} else {
- console.log('No cheese on toast for you today.');
-}</pre>
-
-<p>ואם נחזור לדוגמא הקודמת שלנו עם הילד והמטלה, נוכל לרשום זאת כך:</p>
-
-<pre class="brush: js">var shoppingDone = false;
-
-if (shoppingDone) { // don't need to explicitly specify '=== true'
- var childsAllowance = 10;
-} else {
- var childsAllowance = 5;
-}</pre>
-
-<h3 id="שרשור_של_if_..._else">שרשור של if ... else</h3>
-
-<p>זה בסדר גמור לשים משפט <code>if...else</code> אחד בתוך השני - כלומר לשרשר אותם. לדוגמא, אנחנו יכולים לעדכן את היישום מזג אוויר שלנו להראות רשימה נוספת של אפשרויות בהתבסס על הטמפרטורה:</p>
-
-<pre class="brush: js">if (choice === 'sunny') {
- if (temperature &lt; 86) {
- para.textContent = 'It is ' + temperature + ' degrees outside — nice and sunny. Let\'s go out to the beach, or the park, and get an ice cream.';
- } else if (temperature &gt;= 86) {
- para.textContent = 'It is ' + temperature + ' degrees outside — REALLY HOT! If you want to go outside, make sure to put some suncream on.';
- }
-}</pre>
-
-<p>למרות שכל הקוד עובד יחד, כל משפט <code>if...else</code> עובד לחלוטין באופן עצמאי מהאחר.</p>
-
-<h3 id="AND_OR_או_NOT_אופרטוריים_לוגיים_-_Logical_operators">AND, OR או NOT :אופרטוריים לוגיים - Logical operators</h3>
-
-<p>אם נרצה לבדוק מספר תנאים מבלי לשרשר משפטי <code>if...else</code> שונים, <a href="/en-US/docs/Web/JavaScript/Reference/Operators/Logical_Operators">logical operators אופרטוריים לוגיים -</a> יכולים לעזור לנו. כשנעשה בהם שימוש בתנאים, השניים ראשונים עושים את הדברים הבאים:</p>
-
-<ul>
- <li><code>&amp;&amp;</code> — AND; מאפשר לנו לשרשר ביחד מס׳ תנאים אשר כולם חייבים להתקיים ועל כולם להחזיר <code>true</code> על מנת שכל הביטוי יהיה <code>true</code>.</li>
- <li><code>||</code> — OR; מאפשר לנו לשרשר מס׳ תנאים אשר מספיק שאחד מהם יתקיים ויחזיר ערך של <code>true</code>, על מנת שכל הביטוי יהיה <code>true</code>.</li>
-</ul>
-
-<p> ניתן היה לרשום את הקוד הקודם באמצעות שימוש באופרטור הלוגי AND בצורה הבאה:</p>
-
-<pre class="brush: js">if (choice === 'sunny' &amp;&amp; temperature &lt; 86) {
- para.textContent = 'It is ' + temperature + ' degrees outside — nice and sunny. Let\'s go out to the beach, or the park, and get an ice cream.';
-} else if (choice === 'sunny' &amp;&amp; temperature &gt;= 86) {
- para.textContent = 'It is ' + temperature + ' degrees outside — REALLY HOT! If you want to go outside, make sure to put some suncream on.';
-}</pre>
-
-<p>בדוגמא זו, הבלוק קוד הראשון ירוץ רק אם <code>'choice === 'sunny</code> <em>וגם</em> <code>temperature &lt; 86</code> יחזיר <code>true</code>.</p>
-
-<p>דוגמא לשימוש באופרטור הלוגי OR:</p>
-
-<pre class="brush: js">if (iceCreamVanOutside || houseStatus === 'on fire') {
- console.log('You should leave the house quickly.');
-} else {
- console.log('Probably should just stay in then.');
-}</pre>
-
-<p>הסוג האחרון של אופרטור לוגי - NOT, מבוטא על ידי האופרטור <code>!</code> וניתן לשימוש על מנת לשלול ביטוי מסויים. נראה אותו בדוגמא הבאה:</p>
-
-<pre class="brush: js">if (!(iceCreamVanOutside || houseStatus === 'on fire')) {
- console.log('Probably should just stay in then.');
-} else {
- console.log('You should leave the house quickly.');
-}</pre>
-
-<p>בקוד זה אם ביטוי של OR מסויים מחזיר <code>true</code>, אז האופרטור NOT יהפוך אותו לשלילי על מנת שכל הביטוי יחזור <code>false</code>.</p>
-
-<p>אנחנו יכולים לאחד כמה משפטי התנייה ואופרטורים לוגיים כמה שנרצה, בכל מבנה שנרצה. הדוגמאות הבאות מריצות קוד בפנים רק אם שני משפטי ה-OR מחזירים ערך של אמת. </p>
-
-<pre class="brush: js">if ((x === 5 || y &gt; 3 || z &lt;= 10) &amp;&amp; (loggedIn || userName === 'Steve')) {
- // run the code
-}</pre>
-
-<p>טעות נפוצה שעושים כאשר משתמשים באופרטור הלוגי OR במשפט תנאי היא לציין את המשתנה שאנחנו נרצה לבדוק את הערך שלו ואז לתת מס׳ ערכים לבדיקה מופרדים על ידי האופרטור<code>||</code> (OR) , זה עלול להחזיר לנו ערך של אמת. לדוגמא:</p>
-
-<pre class="example-bad brush: js">if (x === 5 || 7 || 10 || 20) {
- // run my code
-}</pre>
-
-<p>במקרה זה, התנאי בתוך הסוגריים <code>()</code> יחזיר לנו תמיד <code>true</code>, כי המספר 7 או כל מספר שאינו 0, תמיד יחזיר ערך של <code>true</code> כי כל ערך שהוא לא <code>false</code>, <code>undefined</code>, <code>null</code>, <code>0</code>, <code>NaN</code>, או מחרוזת ריקה - (<code>''</code>), יחזיר לנו אמת - <code>true</code> כאשר הוא נבדק כתנאי במשפט תנאי. </p>
-
-<p>על מנת שקוד זה יעבוד לוגית כפי שרצינו, אנחנו צריכים להשתמש<span style="font-size: 1rem; letter-spacing: -0.00278rem;"> אופרטור </span><span style="font-size: 1rem; letter-spacing: -0.00278rem;">OR </span><span style="font-size: 1rem; letter-spacing: -0.00278rem;">על כל אחד מהם:</span></p>
-
-<pre class="brush: js">if (x === 5 || x === 7 || x === 10 ||x === 20) {
- // run my code
-}</pre>
-
-<h2 id="משפטי_switch">משפטי switch</h2>
-
-<p>משפטי <code>if...else</code> עוזרים לנו לממש קוד מותנה שירוץ בהתאם לתנאים שנגדיר לו, אבל לא בלי החסרונות שלהם. הם לרוב יהיו טובים כאשר יש לנו שתי אפשרויות וכל מהן דורשת כמויות הגיונית של קוד, או כאשר התנאים שלנו מורכבים יחסית. למקרים שבה אנחנו נרצה הרבה מקרים לבדיקה, הקוד עלול להיות קצת מעצבן וארוך. </p>
-
-<p>בשביל זה נועדו משפטי <code><a href="/en-US/docs/Web/JavaScript/Reference/Statements/switch">switch</a></code>. משפטים אלו מקבלים ביטוי/ערך בתוך פרמטר ואז בודקים התקיימותו בין מספר אפשרויות שמוגדרות להם. אם הם מוצאים אחת מהאפשרויות שמתאימה לביטוי/ערך שהם קיבלו כפרמטר, הן יריצו את הקוד המתאים. כך זה קורה מבחינה רעיונית<span style="font-size: 1rem; letter-spacing: -0.00278rem;">:</span></p>
-
-<pre>switch (expression) {
- case choice1:
- run this code
- break;
-
- case choice2:
- run this code instead
- break;
-
- // include as many cases as you like
-
- default:
- actually, just run this code
-}</pre>
-
-<p>הסבר:</p>
-
-<ol>
- <li>המילה השמורה <code>switch</code>, ולאחריה סט של סוגריים רגילות <code>()</code>.</li>
- <li>ביטוי או ערך בתוך הסוגריים.</li>
- <li>המילה השמורה <code>case</code>, ולאחריה מקרה אפשרי שהביטוי או הערך יכול להיות, לאחריו <code>:</code>.</li>
- <li>קוד שירוץ אם המקרה מתאים לביטוי/ערך.</li>
- <li>המילי השמורה <code>break</code>, ולאחריה <code>;</code> אם האפשרות הקודמת תואמת לערך/ביטוי, הדפדפן יפסיק להריץ את הקוד במשפט ה-<code>switch</code> וימשיך לקוד שמתחת למשפט ה-<code>switch</code>.</li>
- <li>ניתן להוסיף <code>case</code> כמה שרק נרצה. </li>
- <li>לבסוף, המילה השמורה <code>default</code>, ולאחריה <code>:</code> וקוד שירוץ. <code>default</code> תרוץ אם הערך/ביטוי שהוכנס לא תואם לאף אחד מאפשרויות ה-<code>case</code> שרשמנו. במקרה של <code>default</code> - אין צורך להתשמש במילה השמורה <code>break</code>, מכיוון שאין מה להפסיק/לעצור לאחר התקיימותו של מקרה זה. </li>
-</ol>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>:  החלק של <code>default</code> הוא אופציונלי - אנחנו יכולים להשמיט אותו אם אין סיכוי כשהביטוי יחזיר לנו ערך לא ידוע או לא תואם לאף אחד מהמקרים. אם יש סיכוי  כזה - אנחנו צריכים לכלול <code>default</code> במשפט ה-<code>switch</code> על מנת להתמודד עם אותם מקרים לא ידועים. </p>
-</div>
-
-<h3 id="דוגמא_למשפט_switch">דוגמא למשפט switch</h3>
-
-<p>נסתכל על דוגמא אמיתית - נכתוב את יישום מזג האוויר שלנו מחדש באמצעות שימוש במשפט <code>switch</code>:</p>
-
-<pre class="brush: html">&lt;label for="weather"&gt;Select the weather type today: &lt;/label&gt;
-&lt;select id="weather"&gt;
- &lt;option value=""&gt;--Make a choice--&lt;/option&gt;
- &lt;option value="sunny"&gt;Sunny&lt;/option&gt;
- &lt;option value="rainy"&gt;Rainy&lt;/option&gt;
- &lt;option value="snowing"&gt;Snowing&lt;/option&gt;
- &lt;option value="overcast"&gt;Overcast&lt;/option&gt;
-&lt;/select&gt;
-
-&lt;p&gt;&lt;/p&gt;</pre>
-
-<pre class="brush: js">var select = document.querySelector('select');
-var para = document.querySelector('p');
-
-select.addEventListener('change', setWeather);
-
-
-function setWeather() {
- var choice = select.value;
-
- switch (choice) {
- case 'sunny':
- para.textContent = 'It is nice and sunny outside today. Wear shorts! Go to the beach, or the park, and get an ice cream.';
- break;
- case 'rainy':
- para.textContent = 'Rain is falling outside; take a rain coat and a brolly, and don\'t stay out for too long.';
- break;
- case 'snowing':
- para.textContent = 'The snow is coming down — it is freezing! Best to stay in with a cup of hot chocolate, or go build a snowman.';
- break;
- case 'overcast':
- para.textContent = 'It isn\'t raining, but the sky is grey and gloomy; it could turn any minute, so take a rain coat just in case.';
- break;
- default:
- para.textContent = '';
- }
-}</pre>
-
-<p>{{ EmbedLiveSample('A_switch_example', '100%', 100, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<div class="note">
-<p><strong>לתשומת לבכם</strong>: אפשר למצוא את הדוגמא ב-​​​​​<a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/simple-switch.html">GitHub</a> או להריץ אותה <a href="http://mdn.github.io/learning-area/javascript/building-blocks/simple-switch.html">פה</a>.</p>
-</div>
-
-<h2 id="Ternary_operator_-_אופרטור_טרנארי"> Ternary operator - אופרטור טרנארי</h2>
-
-<p>סינטקס נוסף שנרצה להציג בפניכם לפני שנמשיך הוא <a href="/en-US/docs/Web/JavaScript/Reference/Operators/Conditional_Operator">אופרטור טרנארי</a>. </p>
-
-<p>אופרטור טרנארי הוא סינטקס קצר אשר בודק התקיימותו של תנאי מסויים ומבצע פעולה מסויימת אם התנאי מתקיים - <code>true</code>, ופעולה אחרת אם התנאי לא מתקיים - <code>false</code>. אופרטור זה שימושי בסיטואציות מסוימות ויכול לקחת הרבה פחות קוד מאשר <code>if...else</code>, במידה ויש שתי אפשרויות, אשר נבחרות לפי מבחן/תנאי <code>true</code>/<code>false</code>.</p>
-
-<p>על מנת להפשיט את הנושא, הקוד בצורה רעיונית נראה כך:</p>
-
-<pre>( condition ) ? run this code : run this code instead</pre>
-
-<p>נסתכל על דוגמא פשוטה:</p>
-
-<pre class="brush: js">var greeting = ( isBirthday ) ? 'Happy birthday Mrs. Smith — we hope you have a great day!' : 'Good morning Mrs. Smith.';</pre>
-
-<p>יש לנו פה משתנה בשם <code>isBirthday</code> - אם הוא <code>true</code>, אנחנו נתן הודעת יומולדת שמח, ואם הוא <code>false</code>, אנחנו נתן ברכה רגילה.</p>
-
-<h3 id="דוגמא_לאופרטור_טרנארי">דוגמא לאופרטור טרנארי</h3>
-
-<p>שימו לב כי אנחנו לא חייבים לקבוע ערכים בפרמטרים של האופרטור הטרנארי - אנחנו יכולים גם לתת לו כפרמטרים שורות קוד או פונקציות - כל דבר שנרצה. הדוגמא הבאה מראה לנו אפשרות לבחירת עיצוב לאתר על בסיס אופרטור טרנארי.</p>
-
-<pre class="brush: html">&lt;label for="theme"&gt;Select theme: &lt;/label&gt;
-&lt;select id="theme"&gt;
- &lt;option value="white"&gt;White&lt;/option&gt;
- &lt;option value="black"&gt;Black&lt;/option&gt;
-&lt;/select&gt;
-
-&lt;h1&gt;This is my website&lt;/h1&gt;</pre>
-
-<pre class="brush: js">var select = document.querySelector('select');
-var html = document.querySelector('html');
-document.body.style.padding = '10px';
-
-function update(bgColor, textColor) {
- html.style.backgroundColor = bgColor;
- html.style.color = textColor;
-}
-
-select.onchange = function() {
- ( select.value === 'black' ) ? update('black','white') : update('white','black');
-}
-</pre>
-
-<p>{{ EmbedLiveSample('Ternary_operator_example', '100%', 300, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<p>כאן יש לנו אלמנט {{htmlelement('select')}} המאפשר לנו לבחור את הסגנון (שחור או לבן) ובנוסף כותרת פשוטה של {{htmlelement('h1')}} על מנת להציג את הכותרת של האתר. לאחר מכן יש לנו פונקציה שנקראת <code>()update</code> שמקבלת שני צבעים כארגומנטים. הרקע של האתר נקבע על ידי הצבע הראשון שאנחנו בוחרים, והצבע של הטקסט ניתן כפרמטר השני.</p>
-
-<p>לבסוף ישלנו ״מאזין אירוע״ - event listener בשם <a href="/en-US/docs/Web/API/GlobalEventHandlers/onchange">onchange</a>. מאזין אירוע זה מכיל ״מטפל אירוע״ - event handler מסוג מסוג אופרטור טרנארי. הוא מתחיל עם מבחן התנאי - <code>select.value === 'black'</code>. אם התנאי מחזיר <code>true</code>, אנחנו נריץ את פונקציית <code>true</code> עם האפרמטרי ׳black׳ ו-׳white׳ - כלומר אנחנו נקבל רקע שחור עם כיתוב טקסט לבן. אם זה תוצאת התקיימות התנאי היא <code>false</code> - פונקציית <code>()update</code> תרוץ עם פרמטרים לבן ושחור, כלומר הצבעים יהיו הפוכים.</p>
-
-<div class="note">
-<p><strong>לתשומת לבכם</strong>:  אירועים אלו בעצם פעולות או התרחשויות אשר קורים במערכת, אשר אנחנו יכולים ״להאזין״ להם באמצעות ״מאזין אירוע״ - <strong>event listener</strong> כך שנוכל להגיב בדרך מסויימת, ברגע שהם יתרחשו באמצעות ״מטפל אירוע״ - <strong>event handler</strong>. אנו נגע בהם בהמשך.</p>
-</div>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: ראו גם <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/simple-ternary.html">דוגמא זו ב- GitHub</a> או בדוגמא <a href="http://mdn.github.io/learning-area/javascript/building-blocks/simple-ternary.html">כדף אינטרנט</a>. </p>
-</div>
-
-<h2 id="למידה_עצמאית_לוח_שנה_פשוט">למידה עצמאית: לוח שנה פשוט</h2>
-
-<p>בדוגמא הבאה, אנחנו הולכים לכתוב דוגמא ללוח שנה. בקוד שלנו יש:</p>
-
-<ul>
- <li>אלמנט {{htmlelement("select")}} המאפשר לנו לתת למשתמש לבחור בין חודשים שונים בשנה.</li>
- <li>מאזין אירוע מסוג <code>onchange</code> על מנת ״להאזין״ להתרחשות של שינוי ערך בתפריט ה- <code>&lt;select&gt;</code>.</li>
- <li>פונקציה שנקאת <code>()createCalendar</code> יוצרת לנו ללוח שנה ומציגה את החודש הנכון באלמנט {{htmlelement("h1")}}.</li>
-</ul>
-
-<p>אנחנו צריכים משפט תנאי בתוך ה-event handler שלנו - כלומר בתוך פונקציית <code>onchange</code> שלנו, מתחת להערה <code>ADD CONDITIONAL HERE //</code>. משפט תנאי זה אמור:</p>
-
-<ol>
- <li>להסתכל על החודש שנבחר ואוכסן במשתנה <code>choice</code>. זה יהיה הערך של האלמנט <code>&lt;select&gt;</code> לאחר שהערך שלו השתנה. בדוגמא שלנו זה יהיה January.</li>
- <li>להגדיר משתנה בשם <code>days</code> שיהיה שווה למספר הימים בחודש הנבחר. על מנת לעשות זאת אנחנו נצטרך להסתכל על מספר הימים בכל חודש בשנה. אנחנו יכולים להתעלם משנים מעוברות לצרכי דוגמא זו.</li>
-</ol>
-
-<p><u>רמזים</u>:</p>
-
-<ul>
- <li>אנו ממליצים להשתמש באופרטור הלוגי OR (<code>||</code>) על מנת לאחד מספר חודשים ביחד לתנאי אחד. מרביתם הרי חולקים את אותו מספר הימים.</li>
- <li>חשבו מהו מספר הימים הנפוץ ביותר בחודשים השונים והשתמשו בו כערך ברירת מחדל.</li>
-</ul>
-
-<p>אם אתם עושים טעות - תמיד ניתן לאתחל את הקוד למצבו הראשוני באמצעות כפתור ה-״Reset״. אם ממש נתקעתם - הסתכלו על הפתרון.</p>
-
-<div class="hidden">
-<h6 id="Playable_code">Playable code</h6>
-
-<pre class="brush: html">&lt;h2&gt;Live output&lt;/h2&gt;
-&lt;div class="output" style="height: 500px;overflow: auto;"&gt;
- &lt;label for="month"&gt;Select month: &lt;/label&gt;
- &lt;select id="month"&gt;
- &lt;option value="January"&gt;January&lt;/option&gt;
- &lt;option value="February"&gt;February&lt;/option&gt;
- &lt;option value="March"&gt;March&lt;/option&gt;
- &lt;option value="April"&gt;April&lt;/option&gt;
- &lt;option value="May"&gt;May&lt;/option&gt;
- &lt;option value="June"&gt;June&lt;/option&gt;
- &lt;option value="July"&gt;July&lt;/option&gt;
- &lt;option value="August"&gt;August&lt;/option&gt;
- &lt;option value="September"&gt;September&lt;/option&gt;
- &lt;option value="October"&gt;October&lt;/option&gt;
- &lt;option value="November"&gt;November&lt;/option&gt;
- &lt;option value="December"&gt;December&lt;/option&gt;
- &lt;/select&gt;
-
- &lt;h1&gt;&lt;/h1&gt;
-
- &lt;ul&gt;&lt;/ul&gt;
-&lt;/div&gt;
-
-&lt;h2&gt;Editable code&lt;/h2&gt;
-&lt;p class="a11y-label"&gt;Press Esc to move focus away from the code area (Tab inserts a tab character).&lt;/p&gt;
-
-&lt;textarea id="code" class="playable-code" style="height: 400px;width: 95%"&gt;
-var select = document.querySelector('select');
-var list = document.querySelector('ul');
-var h1 = document.querySelector('h1');
-
-select.onchange = function() {
- var choice = select.value;
-
- // ADD CONDITIONAL HERE
-
- createCalendar(days, choice);
-}
-
-function createCalendar(days, choice) {
- list.innerHTML = '';
- h1.textContent = choice;
- for (var i = 1; i &lt;= days; i++) {
- var listItem = document.createElement('li');
- listItem.textContent = i;
- list.appendChild(listItem);
- }
-}
-
-createCalendar(31,'January');
-&lt;/textarea&gt;
-
-&lt;div class="playable-buttons"&gt;
- &lt;input id="reset" type="button" value="Reset"&gt;
- &lt;input id="solution" type="button" value="Show solution"&gt;
-&lt;/div&gt;
-</pre>
-
-<pre class="brush: css">.output * {
- box-sizing: border-box;
-}
-
-.output ul {
- padding-left: 0;
-}
-
-.output li {
- display: block;
- float: left;
- width: 25%;
- border: 2px solid white;
- padding: 5px;
- height: 40px;
- background-color: #4A2DB6;
- color: white;
-}
-
-html {
- font-family: sans-serif;
-}
-
-h2 {
- font-size: 16px;
-}
-
-.a11y-label {
- margin: 0;
- text-align: right;
- font-size: 0.7rem;
- width: 98%;
-}
-
-body {
- margin: 10px;
- background: #f5f9fa;
-}</pre>
-
-<pre class="brush: js">var textarea = document.getElementById('code');
-var reset = document.getElementById('reset');
-var solution = document.getElementById('solution');
-var code = textarea.value;
-var userEntry = textarea.value;
-
-function updateCode() {
- eval(textarea.value);
-}
-
-reset.addEventListener('click', function() {
- textarea.value = code;
- userEntry = textarea.value;
- solutionEntry = jsSolution;
- solution.value = 'Show solution';
- updateCode();
-});
-
-solution.addEventListener('click', function() {
- if(solution.value === 'Show solution') {
- textarea.value = solutionEntry;
- solution.value = 'Hide solution';
- } else {
- textarea.value = userEntry;
- solution.value = 'Show solution';
- }
- updateCode();
-});
-
-var jsSolution = 'var select = document.querySelector(\'select\');\nvar list = document.querySelector(\'ul\');\nvar h1 = document.querySelector(\'h1\');\n\nselect.onchange = function() {\n var choice = select.value;\n var days = 31;\n if(choice === \'February\') {\n days = 28;\n } else if(choice === \'April\' || choice === \'June\' || choice === \'September\'|| choice === \'November\') {\n days = 30;\n }\n\n createCalendar(days, choice);\n}\n\nfunction createCalendar(days, choice) {\n list.innerHTML = \'\';\n h1.textContent = choice;\n for(var i = 1; i &lt;= days; i++) {\n var listItem = document.createElement(\'li\');\n listItem.textContent = i;\n list.appendChild(listItem);\n }\n }\n\ncreateCalendar(31,\'January\');';
-var solutionEntry = jsSolution;
-
-textarea.addEventListener('input', updateCode);
-window.addEventListener('load', updateCode);
-
-// stop tab key tabbing out of textarea and
-// make it write a tab at the caret position instead
-
-textarea.onkeydown = function(e){
- if (e.keyCode === 9) {
- e.preventDefault();
- insertAtCaret('\t');
- }
-
- if (e.keyCode === 27) {
- textarea.blur();
- }
-};
-
-function insertAtCaret(text) {
- var scrollPos = textarea.scrollTop;
- var caretPos = textarea.selectionStart;
-
- var front = (textarea.value).substring(0, caretPos);
- var back = (textarea.value).substring(textarea.selectionEnd, textarea.value.length);
- textarea.value = front + text + back;
- caretPos = caretPos + text.length;
- textarea.selectionStart = caretPos;
- textarea.selectionEnd = caretPos;
- textarea.focus();
- textarea.scrollTop = scrollPos;
-}
-
-// Update the saved userCode every time the user updates the text area code
-
-textarea.onkeyup = function(){
- // We only want to save the state when the user code is being shown,
- // not the solution, so that solution is not saved over the user code
- if(solution.value === 'Show solution') {
- userEntry = textarea.value;
- } else {
- solutionEntry = textarea.value;
- }
-
- updateCode();
-};</pre>
-</div>
-
-<p>{{ EmbedLiveSample('Playable_code', '100%', 1110, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<h2 id="למידה_עצמאית_יותר_אפשרויות_צבעים!">למידה עצמאית: יותר אפשרויות צבעים!</h2>
-
-<p>בתרגול זה, אנחנו הולכים לקחת את האופרטור הטרנארי שראינו קודם, ולהפוך אותו למשפט <code>switch</code> שיאפשר לנו לבחור מבין אפשרות אחת מבין אפשרויות רבות יותר עבור האתר הפשוט שלנו. הסתכלו על {{htmlelement("select")}} - הפעם אתם תראו שיש לו חמש אופציות ולא שתיים. אתם נדרשים להוסיף משפט <code>switch</code> ישר מתחת להערת <code>ADD SWITCH STATEMENT //</code>אשר יבצע את הפעולות הבאות:</p>
-
-<ul>
- <li>הוא אמור לקבל את המשתנה <code>choice</code> כפרמטר שלו.</li>
- <li>עבור כל מקרה, <code>choice</code> אמור להיות שווה לאחד מהערכים היכולים להיבחר - לדוגמא, לבן, שחור, סגול, צהוב או פסיכודלי. שימו לב שערכים אלו הם case sensitive וזה צריך להיות שווה לערכים של האלמנט <code>&lt;option&gt;</code>.</li>
- <li>עבור כל מקרה, הפונקציה <code>()update</code> אמורה לרוץ ולקבל אליה כארגומנטים 2 ערכים של צבעים - הראשון עבור הרקע והשני עבור הטקסט. זכרו שערכי הצבעים אלו מחרוזות, אז צריך לעטוף אותם במרכאות. </li>
-</ul>
-
-<p>אם אתם עושים טעות - תמיד ניתן לאתחל את הקוד למצבו הראשוני באמצעות כפתור ה-״Reset״. אם ממש נתקעתם - הסתכלו על הפתרון.</p>
-
-<div class="hidden">
-<h6 id="Playable_code_2">Playable code 2</h6>
-
-<pre class="brush: html">&lt;h2&gt;Live output&lt;/h2&gt;
-&lt;div class="output" style="height: 300px;"&gt;
- &lt;label for="theme"&gt;Select theme: &lt;/label&gt;
- &lt;select id="theme"&gt;
- &lt;option value="white"&gt;White&lt;/option&gt;
- &lt;option value="black"&gt;Black&lt;/option&gt;
- &lt;option value="purple"&gt;Purple&lt;/option&gt;
- &lt;option value="yellow"&gt;Yellow&lt;/option&gt;
- &lt;option value="psychedelic"&gt;Psychedelic&lt;/option&gt;
- &lt;/select&gt;
-
- &lt;h1&gt;This is my website&lt;/h1&gt;
-&lt;/div&gt;
-
-&lt;h2&gt;Editable code&lt;/h2&gt;
-&lt;p class="a11y-label"&gt;Press Esc to move focus away from the code area (Tab inserts a tab character).&lt;/p&gt;
-
-&lt;textarea id="code" class="playable-code" style="height: 450px;width: 95%"&gt;
-var select = document.querySelector('select');
-var html = document.querySelector('.output');
-
-select.onchange = function() {
- var choice = select.value;
-
- // ADD SWITCH STATEMENT
-}
-
-function update(bgColor, textColor) {
- html.style.backgroundColor = bgColor;
- html.style.color = textColor;
-}&lt;/textarea&gt;
-
-&lt;div class="playable-buttons"&gt;
- &lt;input id="reset" type="button" value="Reset"&gt;
- &lt;input id="solution" type="button" value="Show solution"&gt;
-&lt;/div&gt;
-</pre>
-
-<pre class="brush: css">html {
- font-family: sans-serif;
-}
-
-h2 {
- font-size: 16px;
-}
-
-.a11y-label {
- margin: 0;
- text-align: right;
- font-size: 0.7rem;
- width: 98%;
-}
-
-body {
- margin: 10px;
- background: #f5f9fa;
-}</pre>
-
-<pre class="brush: js">var textarea = document.getElementById('code');
-var reset = document.getElementById('reset');
-var solution = document.getElementById('solution');
-var code = textarea.value;
-var userEntry = textarea.value;
-
-function updateCode() {
- eval(textarea.value);
-}
-
-reset.addEventListener('click', function() {
- textarea.value = code;
- userEntry = textarea.value;
- solutionEntry = jsSolution;
- solution.value = 'Show solution';
- updateCode();
-});
-
-solution.addEventListener('click', function() {
- if(solution.value === 'Show solution') {
- textarea.value = solutionEntry;
- solution.value = 'Hide solution';
- } else {
- textarea.value = userEntry;
- solution.value = 'Show solution';
- }
- updateCode();
-});
-
-var jsSolution = 'var select = document.querySelector(\'select\');\nvar html = document.querySelector(\'.output\');\n\nselect.onchange = function() {\n var choice = select.value;\n\n switch(choice) {\n case \'black\':\n update(\'black\',\'white\');\n break;\n case \'white\':\n update(\'white\',\'black\');\n break;\n case \'purple\':\n update(\'purple\',\'white\');\n break;\n case \'yellow\':\n update(\'yellow\',\'darkgray\');\n break;\n case \'psychedelic\':\n update(\'lime\',\'purple\');\n break;\n }\n}\n\nfunction update(bgColor, textColor) {\n html.style.backgroundColor = bgColor;\n html.style.color = textColor;\n}';
-var solutionEntry = jsSolution;
-
-textarea.addEventListener('input', updateCode);
-window.addEventListener('load', updateCode);
-
-// stop tab key tabbing out of textarea and
-// make it write a tab at the caret position instead
-
-textarea.onkeydown = function(e){
- if (e.keyCode === 9) {
- e.preventDefault();
- insertAtCaret('\t');
- }
-
- if (e.keyCode === 27) {
- textarea.blur();
- }
-};
-
-function insertAtCaret(text) {
- var scrollPos = textarea.scrollTop;
- var caretPos = textarea.selectionStart;
-
- var front = (textarea.value).substring(0, caretPos);
- var back = (textarea.value).substring(textarea.selectionEnd, textarea.value.length);
- textarea.value = front + text + back;
- caretPos = caretPos + text.length;
- textarea.selectionStart = caretPos;
- textarea.selectionEnd = caretPos;
- textarea.focus();
- textarea.scrollTop = scrollPos;
-}
-
-// Update the saved userCode every time the user updates the text area code
-
-textarea.onkeyup = function(){
- // We only want to save the state when the user code is being shown,
- // not the solution, so that solution is not saved over the user code
- if(solution.value === 'Show solution') {
- userEntry = textarea.value;
- } else {
- solutionEntry = textarea.value;
- }
-
- updateCode();
-};</pre>
-</div>
-
-<p>{{ EmbedLiveSample('Playable_code_2', '100%', 950, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>אלו הדברם העיקריים והמרכזיים שאנחנו צריכים לדעת על משפטי תנאי ומבניהם ב-JavaScript. אם לא הבנתם את הרעיונות שעברנו עליהם בתרגולים למעלה, חזרו על השיעור שוב. ואם משהו לא ברור, <a href="/en-US/Learn#Contact_us">צרו עמנו קשר</a> לשם קבלת עזרה.</p>
-
-<h2 id="ראו_גם">ראו גם</h2>
-
-<ul>
- <li><a href="/he/Learn/JavaScript/First_steps/Math#Comparison_operators">Comparison operators - אופרטורים להשוואה</a></li>
- <li><a href="/he/docs/Web/JavaScript/Guide/Control_flow_and_error_handling#Conditional_statements">משפטי תנאי בהרחבה</a></li>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Statements/if...else">if...else reference</a></li>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Conditional_Operator">Conditional (ternary) operator reference</a></li>
-</ul>
-
-<p>{{NextMenu("Learn/JavaScript/Building_blocks/Looping_code", "Learn/JavaScript/Building_blocks")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/conditionals">קבלת החלטות בקוד - משפטי תנאי - Conditionals</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Looping_code">לולאות - Loops</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Functions">פונקציות - בלוקי קוד לשימוש חוזר - Functions</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Build_your_own_function">בניית פונקציות משלנו</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Return_values">ערכים מוחזרים מהפונקציה - Function return values </a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Events">היכרות ראשונית עם אירועים -Introduction to events</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Image_gallery">תרגול: בניית גלריית תמונות</a></li>
-</ul>
diff --git a/files/he/learn/javascript/building_blocks/events/index.html b/files/he/learn/javascript/building_blocks/events/index.html
deleted file mode 100644
index 9fc4363939..0000000000
--- a/files/he/learn/javascript/building_blocks/events/index.html
+++ /dev/null
@@ -1,588 +0,0 @@
----
-title: היכרות ראשונית עם אירועים - Events
-slug: Learn/JavaScript/Building_blocks/Events
-translation_of: Learn/JavaScript/Building_blocks/Events
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/Building_blocks/Return_values","Learn/JavaScript/Building_blocks/Image_gallery", "Learn/JavaScript/Building_blocks")}}</div>
-
-<p class="summary">אירועים (Evants) אלו פעולות או התרחשויות אשר קורות במערכת שאנחנו מתכנתים בה, והמערכת אומרת לנו  בדרך מסויימת על ההתרחשות שלהם, כך שאנחנו יכולים להגיב להתרחשות של האירוע המסויים בדרך מסויימת שנרצה. לדוגמא אם משתמש לחץ על כפתור באתר, אולי נרצה בתגובה לטפל באירוע הלחיצה הזה על ידי הצגת הודעה כלשהי. במאמר זה אנחנו נדון בעקרונות החשובים של events ונסתכל כיצד הם עובדים בדפדפדנים. אנחנו לא נרחיב יותר מדי, אלא רק מה שתצטרכו לדעת בשלב זה.</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>הכרות בסיסית עם המחשב ועם הבסיס של HTML ו- CSS, וכן סיום במלאו של <a href="/en-US/docs/Learn/JavaScript/First_steps">מודול צעדים ראשונים ב-JavaScript</a>.</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>להבין את התיאוריה הבסיסית של אירועים וכיצד הם עובדים בדפדפנים וכיצד אירועים יכולים להיות שונים בסביבות פיתוח שונות.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="מה_הם_אירועים">מה הם אירועים? </h2>
-
-<p>כפי שרשמנו למעלה, אירועים, <strong>events,</strong> הם פעולות או התרחשויות שקורות במערכת שאנחחנו מתכנתים עליה - המערכת שולחת סימן מסויים שהאירוע מתרחש וגם מספקת לנו מכניזם מסויים שעל פיו כלומר, קוד מסויים ירוץ בתגובה להתרחשות אירוע מסויים. כמו בדוגמא עם לחיצת הכפתור שפירטנו למעלה. כאשר האירוע של ״לחיצת כפתור״ התרחש, הדפדפן שלח לנו סימן מסויים שהתרחש אירוע וטיפלנו בו באמצעות הקפצת חלונית.</p>
-
-<p>במקרה שלנו, אירועים מתרחשים בתוך חלון הדפדפן, ונוטים להיות מחוברים לפריט מסויים שבו הם התרחשו או עליו הם קרו - זה יכול להית אלמנט אחד, מספר אלמנטים, אירוע של טעינה דף HTML בלשונית מסויימת או טעינתו של חלון הדפדפן כולו.</p>
-
-<p>יש הרבה סוגים של אירועים שיכולים להתרחש. הנה דוגמא קטנה שלהם:</p>
-
-<ul>
- <li>המשתמש לחץ על אלמנט מסויים או עבר עם העכבר על אלמנט מסויים.</li>
- <li>המשתמש לחץ על כפתור במקלדת.</li>
- <li>המשתמש הגדיל או הקטין את חלון הדפדפן.</li>
- <li>דף אינטרנט סיים להיטען במלואו.</li>
- <li>טופס נשלח.</li>
- <li>וידאו החל להתנגן או הושהה או סיים לנגן.</li>
- <li>התרחשה שגיאה.</li>
-</ul>
-
-<p>תוכלו לראות בדף MDN בנושא <a href="/en-US/docs/Web/Events">Event reference</a> שיש <strong>לא מעט</strong> סוגי אירועים שניתן לטפל בהם - כלומר להגיב להתרחשותם.</p>
-
-<p>לכל אירוע זמין יש ״<strong>מטפל אירוע</strong>״ - <strong>event handler</strong>, שזה בעצם בלוק של קוד שבדרך כלל זו פונקציה שאנחנו נגדיר בעצמנו ושירוצו כאשר האירוע החל להתרחש. שימו לב שלפעמים <strong>event handlers</strong> נקראים <strong>event listeners</strong> - ״<strong>מאזיני אירוע</strong>״ בעיקרון, הם כמעט אותו דבר מבחינתנו כרגע, אבל יש הבדלים ביניהם, הם עובדים יחד: מאזין אירוע - <strong>event listeners</strong> - מאזין להתרחשות האירוע, ואילו מטפל האירוע - <strong>event handlers</strong>, מטפל באותו אירוע שהתרחש - (הקוד שמורץ בתגובה להתרחשות של אותו אירוע).</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: חשוב לדעת כי אירועי web אינם חלק מהבסיס של JavaScript - הם מוגדרים כחלק מה-API של JavaScript המובנים בתוך הדפדפן.</p>
-</div>
-
-<h3 id="דוגמא">דוגמא</h3>
-
-<p>נסתכל על דוגמא פשוטה על מנת להסביר את הנושא. ראינו כבר אירועים ו-event handlers בהרבה מהדוגמאות במהלך הקורס אבל בואו נרענן את הזיכרון.</p>
-
-<p>הסתכלו בדוגמא הבאה, יש לנו אלמנט {{htmlelement("button")}} אחד, אשר כאשר הוא נלחץ, הוא שנה את הצבע של הרקע לצבע אקראי:</p>
-
-<pre class="brush: html">&lt;button&gt;Change color&lt;/button&gt;</pre>
-
-<div class="hidden">
-<pre class="brush: css">button { margin: 10px };</pre>
-</div>
-
-<p>קוד ה-JavaScript שלנו נראה כך:</p>
-
-<pre class="brush: js">var btn = document.querySelector('button');
-
-function random(number) {
- return Math.floor(Math.random()*(number+1));
-}
-
-btn.onclick = function() {
- var rndCol = 'rgb(' + random(255) + ',' + random(255) + ',' + random(255) + ')';
- document.body.style.backgroundColor = rndCol;
-}</pre>
-
-<p>בדוגמא למעלה, אחסנו הפניה לאלמנט <code>&lt;button&gt;</code> בתוך משתנה שנקרא <code>btn</code>, באמצעות פונקציית {{domxref("Document.querySelector()")}}. בנוסף ,הגדרנו פונקציה שמחזירה לנו מספר אקראי. החלק השלישי של הקוד הוא מטפל האירוע - event handler. המשתנה <code>btn</code> מצביע על אלמנט  <code>&lt;button&gt;</code> ולסוג הזה של האובייקט יש מספר מסוים של אירועים שיכולים להתרחש עליו, ולכן יש מספר מטפלי אירוע זמינים עבורו.</p>
-
-<p>בדוגמא זו אנחנו מקשיבים בעצם לאירוע/התרחשות של לחיצת עכבר באמצעות השמת ערך לתכונה (property) של event handler השווה לפונקציה אנונימית. פונקציה אנונימית זו מכילה קוד שמייצר צבע רנדומלי בפורמט rgb וקובעת את ה-<code>background-color</code> לצבע זה.</p>
-
-<p>הקוד שבפונקציה האנונימית ירוץ בכל פעם שאירוע הלחיצה על האלמנט <code>&lt;button&gt;</code> יתרחש, כלומר בכל פעם שהמשתמש לחץ על האלמנט הזה.</p>
-
-<p>התוצאה של הדוגמא תהא כך:</p>
-
-<p>{{ EmbedLiveSample('A_simple_example', '100%', 200, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<h3 id="זה_לא_רק_בדפי_האינטרנט">זה לא רק בדפי האינטרנט</h3>
-
-<p>דבר נוסף שנרצה להזכיר בנקודה זו הוא שאירועים הם לא מיוחדים ל-JavaScript - רוב שפות התכנות מכילות מודל כלשהו של אירועים, והדרך שבה מודל זה עובד בהם, יהיה לרוב שונה מהדרך שבה מודל זה עובד ב-JavaScript. האמת, מודל האירועים ב-JavaScript עבור דפי אינטרנט, שונה ממודל האירועים עבור JavaScript כאשר היא בסביבות אחרות.</p>
-
-<p>לדוגמא, <a href="/en-US/docs/Learn/Server-side/Express_Nodejs">Node.js</a> היא סביבה המאפשרת לנו הרצה ושימוש ב-JavaScript בצד השרת. <a href="https://nodejs.org/docs/latest-v5.x/api/events.html">מודל האירועים של Node.js </a>מתבסס על מאזינים (listeners) אשר מאזינים לאירועים ועל פולטים (emitters) אשר פולטים אירועים בתדירות מסויימת - זה לא נשמע שונה, אבל הקוד הוא שונה, ושם מתבצע שימוש בפונקציות כמו <code>()on</code> על מנת לרשום מאזין אירוע ו-<code>()once</code> על מנת לרשום מאזין אירוע שיאזין באופן חד פעמי ויתבטל לאחר שהורץ פעם אחת. דוגמא לכך ניתן לראות ב-<a href="https://nodejs.org/docs/latest-v8.x/api/http.html#http_event_connect">HTTP connect event docs</a>.</p>
-
-<p>דוגמא נוספת למודל אירועים שונים אנחנו יכולים לראות כאשר משתמשים ב-JavaScript על מנת לבנות תוספים לדפדפנים (מעין שיפורים לדפדפנים) - באמצעות טכנולוגיה שנקראת <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions">WebExtensions</a>. מודל האירועים שם הוא דומה למודל האירועים של ה-Web, אבל שונה מעט - מאזיני האירועים הם camel-cased - כלומר, <code>on<strong>M</strong>essage</code> ולא <code>on<strong>m</strong>essage</code>, והם צריכים להיות ביחד עם פונקצית <code>addListener</code>. לדוגמאות ראו <a href="/en-US/Add-ons/WebExtensions/API/runtime/onMessage#Examples">runtime.onMessage page</a>.</p>
-
-<p>אינכם צריכים להבין עכשיו שום דבר על הסביבות הללו, רק רצינו להסביר לכם שאירועים ומודל האירועים יכול להיות בסביבות פיתוח שונות.</p>
-
-<h2 id="דרכים_לשימוש_ב-web_events">דרכים לשימוש ב-web events</h2>
-
-<p>יש מספר דרכים שונות שבהם אנחנו יכולים להוסיף מאזין אירוע -event listener לדפי הרשת על מנת שהוא יריץ את ה-event handler כאשר יתרחש האירוע הרלוונטי (event registration). בחלק זה, אנחנו נסקור את הדרכים השונות ונדון באילו מהן אנו צריכים להשתמש.</p>
-
-<h3 id="דרך_I_הוספת_תכונה_של_מטפל_אירוע_-_Event_handler_properties">דרך I: הוספת תכונה של מטפל אירוע - Event handler properties</h3>
-
-<p>דרך אחת היא בעצם לתת לאלמנט מסויים תכונה של מאזין אירוע והערך שלה יהיה מטפל אירוע. אנו נקרא לה ״<strong>תכונת מטפל אירוע</strong>״. נתקלנו בזה במהלך הקורס לא מעט. אם נחזור לדוגמא למעלה:</p>
-
-<pre class="brush: js">var btn = document.querySelector('button');
-
-btn.onclick = function() {
- var rndCol = 'rgb(' + random(255) + ',' + random(255) + ',' + random(255) + ')';
- document.body.style.backgroundColor = rndCol;
-}</pre>
-
-<p>התכונה <code><a href="/en-US/docs/Web/API/GlobalEventHandlers/onclick">onclick</a></code> היא תכונת מטפל האירוע (מאזין האירוע) הרלוונטית כרגע לדוגמא זו. היא תכונה בדיוק כמו שיש ל-<font face="consolas, Liberation Mono, courier, monospace"><span style="background-color: rgba(220, 220, 220, 0.498039);">btn</span></font> תכונות נוספות שזמינו תעבורו כמו <code><a href="/en-US/docs/Web/API/Node/textContent">btn.textContent</a></code>, או <code><a href="/en-US/docs/Web/API/HTMLElement/style">btn.style</a></code>, אבל היא תכונה מסוג מיוחד - כאשר אנחנו משימים בה ערך ששווה לקוד מסויים, הקוד הזה ירוץ בכל פעם שהאירוע יתרחש על הכפתור (או על האלמנט אשר נתנו לו את התכונה הזו).</p>
-
-<p>אנחנו גם יכולים לתת למטפל אירוע שכזה שיהיה שווה לשם של פונקציה מסויימת, כמו שראינו במאמר <a href="he/docs/Learn/JavaScript/Building_blocks/Build_your_own_function">בניית פונקציות משלנו</a>. הקוד הבא יעבוד בצורה מצויינת:</p>
-
-<pre class="brush: js">var btn = document.querySelector('button');
-
-function bgChange() {
- var rndCol = 'rgb(' + random(255) + ',' + random(255) + ',' + random(255) + ')';
- document.body.style.backgroundColor = rndCol;
-}
-
-btn.onclick = bgChange;</pre>
-
-<p>יש הרבה סוגים של תכונות מטפלות אירוע שזמינות. ננסה כמה מהם:</p>
-
-<p>ראשית, שמרו לכם עותק מקומי של <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/events/random-color-eventhandlerproperty.html">random-color-eventhandlerproperty.html</a>, ופיתחו אותו בדפדפן. זהו עותק של הדוגמא הפשוטה של בחירת הצבע שראינו בעבר. עכשיו שנו את ה- <code>btn.onclick</code> לערכים הבאים, כל אחד בתור, וראו מה קורה :</p>
-
-<ul>
- <li><code><a href="/en-US/docs/Web/API/GlobalEventHandlers/onfocus">btn.onfocus</a></code> ו- <code><a href="/en-US/docs/Web/API/GlobalEventHandlers/onblur">btn.onblur</a></code> — הצבע ישתנה כאשר הפוקוס יהיה על הכפתור וכאשר הוא יוצא ממנו - באמצעות מקש <kbd>tab</kbd>. אלו משמשים אותנו להצגת מידע כיצד למלא שדות בטופס שלנו או על מנת להציג הודעת שגיאה כאשר הכניסו בשדה ערך שגוי.</li>
- <li><code><a href="/en-US/docs/Web/API/GlobalEventHandlers/ondblclick">btn.ondblclick</a></code> — כאן הצבע ישתנה רק כאשר נלחץ עליו פעמיים - דאבל קליק.</li>
- <li><code><a href="/en-US/docs/Web/API/GlobalEventHandlers/onkeypress">window.onkeypress</a></code>, <code><a href="/en-US/docs/Web/API/GlobalEventHandlers/onkeydown">window.onkeydown</a></code>, <code><a href="/en-US/docs/Web/API/GlobalEventHandlers/onkeyup">window.onkeyup</a></code> — כאן הצבע ישתנה כאשר המשתמש לחץ על כפתור במקלדת אשר יכול להפיק תו ושחרר אותו. <code>keypress</code> הוסר מהסטנדרטים המקובלים ולא מומלץ להשתמש באירוע מסוג זה מכיוון שהתמיכה בו נעלמת. <code>keydown</code> and <code>keyup</code> לא מדובר באירוע של לחיצה על לחצני החצים - אלא מדובר באירוע שמתרחש ברגע שהכפתור נלחץ ואירוע אחר שמתרחש ברגע שהפסיק ללחוץ על הכפתור. שימו לב שזה לא עובד אם נרשום את המטפל אירוע הזה על הכפתור צמו - אנחנו צריכים לרשום אותו על אובייקט <a href="/en-US/docs/Web/API/Window">window</a> שמייצג את החלון הדפדפן כולו. </li>
- <li><code><a href="/en-US/docs/Web/API/GlobalEventHandlers/onmouseover">btn.onmouseover</a></code> ו- <code><a href="/en-US/docs/Web/API/GlobalEventHandlers/onmouseout">btn.onmouseout</a></code> — כאן הצבע ישתנה כאשר סמן העכבר עובר מעל הכפתור וכאשר הוא יוצא ממנו, בהתאמה.</li>
-</ul>
-
-<p>ישנם אירועים שהם מאד כלליים והם זמינים כמעט בכל מקום או עבור כל אלמנט - לדוגמא - אפשר להאזין לאירוע <code>onclick</code> כמעט על כל אלמנט, בעוד יש כאלו שהם יותר ספציפיים ושימושיים בסיטואציות מסויימת. לדוגמא, הגיוני לנו ש-<a href="/en-US/docs/Web/API/GlobalEventHandlers/GlobalEventHandlers.onplay">onplay</a> יהיה זמין רק לאלמנטים מסוג מסויים כמו {{htmlelement("video")}}.</p>
-
-<h3 id="דרך_II_לידיעה_בלבד_-_לא_להשתמש_בהם_-_Inline_event_handlers">דרך II: לידיעה בלבד - לא להשתמש בהם - Inline event handlers</h3>
-
-<p>יכול להיות שראיתם קוד שנראה כך:</p>
-
-<pre class="brush: html">&lt;button onclick="bgChange()"&gt;Press me&lt;/button&gt;
-</pre>
-
-<pre class="brush: js">function bgChange() {
- var rndCol = 'rgb(' + random(255) + ',' + random(255) + ',' + random(255) + ')';
- document.body.style.backgroundColor = rndCol;
-}</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אתם יכולים לראות את <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/events/random-color-eventhandlerattributes.html">קוד המקור</a> לדוגמא זו ב- GitHub או <a href="http://mdn.github.io/learning-area/javascript/building-blocks/events/random-color-eventhandlerattributes.html">בדף אינטרנט</a>.</p>
-</div>
-
-<p>בעבר, הדרך לרשום (register) מטפלי אירוע הייתה באמצעות <strong>event handler HTML attributes</strong> הידועים גם כ- <strong>inline event handlers,</strong> כמו שרשום בדוגמא למעלה. הערך של אותו attribute הוא ממש קוד JavaScript שאנחנו רוצים שירוץ כאשר האירוע מתרחש. הדוגמא למעלה מפעילה פונקציה שמוגדרת בתוך האלמנט {{htmlelement("script")}} אבל באותה הדרך אנחנו יכולים להכניס פונקציה שלמה לתוך אותו attribute:</p>
-
-<pre class="brush: html">&lt;button onclick="alert('Hello, this is my old-fashioned event handler!');"&gt;Press me&lt;/button&gt;</pre>
-
-<p>אל תשתמשו בדרך שכזו על מנת לטפל באירוע, זה נחשב כ- bad practice (פרקטיקה שאינה מקובלת בתעשייה). זה אולי נשמע יותר פשוט, אבל מהר מאוד זה הופך למשהו שלא ניתן לעקוב אחריו ולא יעיל.</p>
-
-<p>בנוסף, זה לא רעיון טוב לערבב בין HTML לבין JavaScript מאחר שזה נהיה קשה לעיבוד - היצמדו לכך שכל ה-JavaScript נמצא במקום אחד.</p>
-
-<p>אפילו כאשר מדובר בקובץ אחד, inline event handlers הם לא רעיון טוב. כאשר יש כפתור אחד זה עוד סביר, אבל מה אם היו לנו 100 כפתורים? היינו צריכים להוסיף 100 attributes לתוך הקובץ. מהר מאוד זה הופך לסיוט מבחינת תחזוקה של הקוד. עם JavaScript, אנחנו יכולים בקלות להוסיף מטפל אירוע לכל הכפתורים, לא משנה כמה יש כאלו, באמצעות קוד כזה:</p>
-
-<pre class="brush: js">var buttons = document.querySelectorAll('button');
-
-for (var i = 0; i &lt; buttons.length; i++) {
- buttons[i].onclick = bgChange;
-}</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: הפרדה בין הקוד שלנו לבין התוכן גם הופך את האתר שלנו ליותר ידידותי למנועי החיפוש.</p>
-</div>
-
-<h3 id="דרך_addEventListener()_III_ו-_()removeEventListener">דרך addEventListener() : III  ו- ()removeEventListener</h3>
-
-<p>הסוג החדש ביותר של מנגנון אירועים הוגדר ב- <a href="https://www.w3.org/TR/DOM-Level-2-Events/">Document Object Model (DOM) Level 2 Events</a> של ארגון W3C. מסמך זה הגדיר דרך טובה יותר לנהל אירועים, בין היתר באמצעות אובייקט מיוחד בשם  <code>EvantTarget</code> אשר נוצר בדפדפן כאשר אירוע מתרחש. לאובייקט זה יש שלוש מתודות ואחת מהן היא <code><a href="/en-US/docs/Web/API/EventTarget/addEventListener">()addEventListener</a></code>. מתודה זו דומה לדרך הראשונה של event handler properties, אבל הסינטקס שונה. אנחנו יכולים לכתוב את הדוגמא שלנו עם הצבעים האקראיים בצורה הזו:</p>
-
-<pre class="brush: js">var btn = document.querySelector('button');
-
-function bgChange() {
- var rndCol = 'rgb(' + random(255) + ',' + random(255) + ',' + random(255) + ')';
- document.body.style.backgroundColor = rndCol;
-}
-
-btn.addEventListener('click', bgChange);</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>:תוכלו למצוא את <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/events/random-color-addeventlistener.html">קוד המקור </a> של דוגמא זו ב- GitHub או ראו כ- <a href="http://mdn.github.io/learning-area/javascript/building-blocks/events/random-color-addeventlistener.html">דף אינטרנט</a>).</p>
-</div>
-
-<p>בתוך מתודת <code>()addEventListener</code>, אנחנו מציינים שני פרמטרים - אחד בעבור אותו האירוע, אותו ה-event אשר אנחנו רוצים שיאזינו והפרמטר השני זה פונקציה של הקוד שאנחנו רוצים שירוץ כמטפל באותו אירוע. שימו לב שזה בסדר גמור לשים את כל הקוד שיטפל באירוע כפונקציה אנונימית, בשונה מהדוגמא למעלה:</p>
-
-<pre class="brush: js">btn.addEventListener('click', function() {
- var rndCol = 'rgb(' + random(255) + ',' + random(255) + ',' + random(255) + ')';
- document.body.style.backgroundColor = rndCol;
-});</pre>
-
-<p>לשיטה הזו יש יתרונות ברורים על השיטות הישנות שדנו בהם למעלה. ראשית, יש מתודה נוספת בשם <code><a href="/en-US/docs/Web/API/EventTarget/removeEventListener">()removeEventListener</a></code> אשר מאפשרת לנו להסיר מאזיני אירוע. לצורך העניין, הקוד הבא יסיר את מאזין האירוע שקבענו למעלה:</p>
-
-<pre class="brush: js">btn.removeEventListener('click', bgChange);</pre>
-
-<p>זה אמנם לא כזה משמעותי עבור תוכניות קטנות או פשוטות, אבל בעבור תוכניות גדולות או מורכבות, זה יכול להגביר את היעילות ומאפשר לנקות מטפלי אירוע שאינם בשימוש עוד. בנוסף, זה מאפשר לנו שלאותו אלמנט - לאותו הכפתור - יהיו מספר מטפלי אירועים אשר יפעלו בצורה אחרת באירועים שונים - כל מה שאנחנו צריכים לעשות זה להוסיף/להסיר מטפלי אירוע בהתאם.</p>
-
-<p>בנוסף, אנחנו גם יכולים לרשום מספר מטפלי אירוע לאותו אירוע - הקוד הבא לדוגמא לא יכול להחיל שני מטפלי אירוע:</p>
-
-<pre class="brush: js">myElement.onclick = functionA;
-myElement.onclick = functionB;</pre>
-
-<p>זאת מכיוון שהשורה השנייה דורסת את הערך שנקבע ל-<code>onclick</code> של השורה הראשנה. על מנת להוסיף מטפל אירוע נוסף מבלי לדרוס את מטפל את האירוע הקיים, אנחנו יכולים לעשות משהו כזה:</p>
-
-<pre class="brush: js">myElement.addEventListener('click', functionA);
-myElement.addEventListener('click', functionB);</pre>
-
-<p>במקרה זה, שתי הפונקציות ירוצו כאשר ילחצו על האלמנט.</p>
-
-<p>כמו כן, יש מספר אפשרויות משמעותיות ותכונות זמינות עבור מנגנון ירועים בדרך הזו. אנחנו לא נרחיב עליהם, אך אם תרצו להרחיב את ידיעתכם בנושא, היכנסו לדפי ההסבר של MDN בנושא <code><a href="/en-US/docs/Web/API/EventTarget/addEventListener">()addEventListener</a></code> ובנושא <code><a href="/en-US/docs/Web/API/EventTarget/removeEventListener">()removeEventListener</a></code>.</p>
-
-<h3 id="באיזה_מנגנון_אירועים_להשתמש">באיזה מנגנון אירועים להשתמש?</h3>
-
-<p>מתוך שלושת המנגנונים הללו, בוודאות <u><strong>אל</strong></u> תשתמשו במנגנון HTML event handler attributes - זה מנגנון ישן, שלא נמצא כבר בשימוש ונחשב כ- bad practice להשתמש בו.</p>
-
-<p>השניים האחרים הם יחסית די חלופיים כאשר מדובר בתוכנית פשוטה או כאשר מדובר בשימוש פשוט שנרצה לעשות באירועים:</p>
-
-<ul>
- <li>ל- <strong>Event handler properties</strong> יש פחות אפשרויות ופחות כוח אך תמיכת הדפדפנים רחבה יותר (כולל Internet Explorer 8).</li>
- <li>DOM Level 2 Events - כגון <code>addEventListener() ו-()removeEventListener</code> ועוד, מאפשרים לנו הרבה יותר אפשרויות, אבל יכולים להיות מורכבים ובעלי פחות תמיכת דפדפנים (נתמך החל מגרסת Internet Explorer 9). השתדלו לנסות ולהשתמש בהם בכך מתי שניתן. </li>
-</ul>
-
-<p>כמו שאמרנו, היתרון העיקרי של המנגנון השלישי הוא שאתם יכולים להסיר קוד שמטפל באירוע, באמצעות <code>()removeEventListener</code>, ואתם יכולים להוסיף מספר מאזיני אירוע לאותו אלמנט. לדוגמא, אנחנו יכולים לקרוא ל-<code>({ ... }()addEventListener('click', function</code> על אלמנט מסויים מספר רב של פעמים, כאשר בכל פעם תהיה פונקציה אחרת בארגומנט השני. אופציה זו לא אפשרית ב- event handler properties כי כל הגדרה נוספת של property תמחוק את ההגדרה הקודמת שלו:</p>
-
-<pre class="brush: js">element.onclick = function1;
-element.onclick = function2;
-etc.</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אם אתם נדרשים לתמוך בדפדפנים ישנים מאינטרנט אקפלורר 8, אתם עלולים להיתקל בקשיים שכן דפדפדנים ישנים אלו משתמשים במודל אירועים שונה מדפדפנים חדשים, אך אל פחד. מרבית ספריות JavaScript (כמו לדוגמא jQuery) מכילות פונקציות מובנות שמבטלות כביכול את ההבדלים בין הדפדנים השונים. אין לכם צורך לדאוג לנושא זה בתחילת הלמידה שלכם.</p>
-</div>
-
-<h2 id="עקרונות_נוספים_בנושא_אירועים">עקרונות נוספים בנושא אירועים</h2>
-
-<p>בחלק זה, אנחנו נגע בקצרה בנושאים מתקדמים הקשורים לאירועים. אין זה הכרחי להבין נושאים אלו לעומק בשלב זה, אך זה עלול לסייע לכם להבין תבניות קוד שתיתקלו בהם מדי פעם.</p>
-
-<h3 id="Event_objects">Event objects</h3>
-
-<p>לפעמים בתוך פונקצייה המטפלת באירוע (event handler) - אתם תראו פרמטר המצויין בתך הסוגריים, הנושא שם כמו <code>event</code>, <code>evt</code>, או סתם <code>e</code>. זה נקרא <strong>event object - האובייקט של האירוע עצמו,</strong> והוא <strong>מועבר בצורה אוטומטית למטפלי האירוע</strong> על מנת לספק אפשרויות נוספות ומידע נוסף. לדוגמא, נרשום את דוגמת הצבעים שלנו מחדש בצורה קצת שונה:</p>
-
-<pre class="brush: js">function bgChange(e) {
- var rndCol = 'rgb(' + random(255) + ',' + random(255) + ',' + random(255) + ')';
- e.target.style.backgroundColor = rndCol;
- console.log(e);
-}
-
-btn.addEventListener('click', bgChange);</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: תוכלו למצוא <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/events/random-color-eventobject.html">את קוד המקור</a> ב-GitHub וגם לראות <a href="http://mdn.github.io/learning-area/javascript/building-blocks/events/random-color-eventobject.html">את הדוגמא כדף אינטרנט</a>.</p>
-</div>
-
-<p>כאן אנחנו יכולים לראות שאנחנו כוללים את האובייקט של האירוע - <strong>e</strong>, בתוך הפונקציה, ובתוך הפונקציה אנחנו קובעים צבע רקע ל- <code>e.target</code> — שזה בעצם הכפתור עצמו. המאפין <code>target</code> של event object הוא תמיד <strong>הפנייה לאלמנט שהאירוע התרחש עליו</strong>. כך, בדוגמא שלנו, אנחנו קובעים בעצם צבע רקע אקראי לכפתור עצמו שהאירוע הלחיצה התרחש עליו ולא לדף.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אתם יכולים להשתמש באיזה שם שנרצה עבור event object — רק השתמשו בשם שיהיה ברור שזה הפניה ל- event object. השמות המקובלים הם <code>e</code>/<code>evt</code>/<code>event</code> מכיוון שהם קצרים וקל לזכור את ההקשר שלהם.</p>
-</div>
-
-<p><code>e.target</code> הוא שימושי להפליא כשאנחנו רוצים לקבוע את אותו event handler על מספר אלמנטים ולעשות משהו לכולם כאשר אותו אירוע מתרחש. לדוגמא, נניח ויש לנו סט של 16 אריחים שנעלמים כאשר הם נלחצים. זה נוח יותר כאשר מתאפשר לנו לקבוע שאלמנט יעלם כשאנחנו נלחץ עליו באמצעות שימוש ב- <code>e.target</code> , מאשר לבחור אותו בצורה מורכבת אחרת. בדוגמאות הבאות למשל ב-<a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/events/useful-eventtarget.html">useful-eventtarget.html - קוד המקור</a> (ניתן לראות גם ב-<a href="http://mdn.github.io/learning-area/javascript/building-blocks/events/useful-eventtarget.html">דף האינטרנט</a>) יצרנו 16 אלמנטים מסוג {{htmlelement("div")}} באמצעות JavaScript, ואנחנו בוחרים את כולם באמצעות {{domxref("document.querySelectorAll()")}} ואז עוברים על כל אחד מהם באמצעות לולאה ומוסיפים מאזין אירוע ומטפל אירוע של <code>onclick</code> לכל אחד מהם כך שכאשר כל אחד מהאלמנטים הללו נלחץ על ידי המשתמש, צבע אקראי אחר ניתן לאותו אלמנט:</p>
-
-<pre class="brush: js">var divs = document.querySelectorAll('div');
-
-for (var i = 0; i &lt; divs.length; i++) {
- divs[i].onclick = function(e) {
- e.target.style.backgroundColor = bgChange();
- }
-}</pre>
-
-<p>הפלט נראה כך. נסו לשחק איתו:</p>
-
-<div class="hidden">
-<h6 id="Hidden_example">Hidden example</h6>
-
-<pre class="brush: html">&lt;!DOCTYPE html&gt;
-&lt;html&gt;
- &lt;head&gt;
- &lt;meta charset="utf-8"&gt;
- &lt;title&gt;Useful event target example&lt;/title&gt;
- &lt;style&gt;
- div {
- background-color: red;
- height: 100px;
- width: 25%;
- float: left;
- }
- &lt;/style&gt;
- &lt;/head&gt;
- &lt;body&gt;
- &lt;script&gt;
- for (var i = 1; i &lt;= 16; i++) {
- var myDiv = document.createElement('div');
- document.body.appendChild(myDiv);
- }
-
- function random(number) {
- return Math.floor(Math.random()*number);
- }
-
- function bgChange() {
- var rndCol = 'rgb(' + random(255) + ',' + random(255) + ',' + random(255) + ')';
- return rndCol;
- }
-
- var divs = document.querySelectorAll('div');
-
- for (var i = 0; i &lt; divs.length; i++) {
- divs[i].onclick = function(e) {
- e.target.style.backgroundColor = bgChange();
- }
- }
- &lt;/script&gt;
- &lt;/body&gt;
-&lt;/html&gt;</pre>
-</div>
-
-<p>{{ EmbedLiveSample('Hidden_example', '100%', 400, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<p>הרבה ממאזיני האירועים/מטפלי האירועים שניתקל בהם הם בעלי סט סטנדרטי של properties ופונקציות - או יותר נכון מתודות, אשר זמינים עבור ה-event object - ראו את הדף בנושא אובייקט {{domxref("Event")}} לרשימה המלאה.</p>
-
-<p>יש מטפלי אירועים יותר מורכבים, המכילים properties מיוחדים בעלי מידע ספציפי שהם צריכים על מנת לתפקד כמטפל אירוע. לדוגמא ל-<a href="/en-US/docs/Web/API/MediaRecorder_API">Media Recorder API</a>, יש סוג אירוע - <code>dataavailable</code> - שמתרחש כאשר אודיו או וידאו הוקלטו והם זמינים כך שניתן לבצע עליהם פעולות מסויימות - לדוגמא לשמור אותם או לנגן אותם שוב. למאזין האירוע/מטפל אירוע התואם <a href="/en-US/docs/Web/API/MediaRecorder/ondataavailable">ondataavailable</a> יש property שזמין בשם <code>data</code> עבורו המכיל את האודיו/וידאו שהוקלט ומאפשר לנו לגשת אליו ולעשות איתו דברים.</p>
-
-<h3 id="מניעת_התנהגות_ברירת_מחדל">מניעת התנהגות ברירת מחדל</h3>
-
-<p>לפעמים אנחנו ניתקל בסיטואצית שאנחנו נרצה למנוע מאירוע לבצע את מה שהוא אמור לעשות כברירת מחדל. הדוגמא הכי נפוצה היא טופס באינטרנט. כאשר אנחנו נמלא את הפרטים ונלחץ על כפתור ה-Submit , ההתנהגות ברירת המחדל תהיה לשלוח את המידע שהוכנס בטופס לדף מסויים בשרת לשם עיבוד, והדפדפן יועבר למעין דף של ״הפרטים נשלחו בהצלחה״ או משהו דומה.</p>
-
-<p>הבעיה מתעוררת כאשר המשתמש לא הזין את המידע כראוי - כמפתחים, אנחנו נרצה למנוע שליחה של המידע השגוי לשרת ולתת למשתמש הודעת שגיאה שאומרת להם מה הייתה הטעות ומה הם צריכים לעשות. חלק מהדפדנים תומכים בולידציה של מידע בטפסים, אך מכיון שהרבה לא ומסיבות נוספות, אנחנו ממליצים לא להסתמך על ולידציה של דפדפנים אלא לבנות את הולידציה בעצמכם. לדוגמא:</p>
-
-<p>נתחיל עם טופס HTML פשוט דורש מאיתנו להכניס שם פרטי ושם משפחה:</p>
-
-<pre class="brush: html">&lt;form&gt;
- &lt;div&gt;
- &lt;label for="fname"&gt;First name: &lt;/label&gt;
- &lt;input id="fname" type="text"&gt;
- &lt;/div&gt;
- &lt;div&gt;
- &lt;label for="lname"&gt;Last name: &lt;/label&gt;
- &lt;input id="lname" type="text"&gt;
- &lt;/div&gt;
- &lt;div&gt;
- &lt;input id="submit" type="submit"&gt;
- &lt;/div&gt;
-&lt;/form&gt;
-&lt;p&gt;&lt;/p&gt;</pre>
-
-<div class="hidden">
-<pre class="brush: css">div {
- margin-bottom: 10px;
-}
-</pre>
-</div>
-
-<p>כעת קצת JavaScript - כאן החלנו בדיקה פשוטה מאוד בתוך מטפל האירוע <a href="/en-US/docs/Web/API/GlobalEventHandlers/onsubmit">onsubmit</a> (האירוע של submit מתרחש כאשר הטופס נשלח).</p>
-
-<p>הבדיקה שלנו בודקת הם שדות הטקסט ריקים. אם כן, אנחנו קוראים לפונקציית <code><a href="/en-US/docs/Web/API/Event/preventDefault">()preventDefault</a></code> על ה- event object - כלומר על האלמנט שעליו התרחש האירוע. פונקצייה זו מונעת מהטופס להישלח - ומציגה הודעת שגיאה בפסקה מתחת לטופס שלנו, על מנת להציג למשתמש מה השתבש:</p>
-
-<pre class="brush: js">var form = document.querySelector('form');
-var fname = document.getElementById('fname');
-var lname = document.getElementById('lname');
-var submit = document.getElementById('submit');
-var para = document.querySelector('p');
-
-form.onsubmit = function(e) {
- if (fname.value === '' || lname.value === '') {
- e.preventDefault();
- para.textContent = 'You need to fill in both names!';
- }
-}</pre>
-
-<p>ברור שזו ולידציה פשוטה וחלשה מאוד - זה לא ימנע מהמשתמש להזין רווחים או מספרים לתוך שדות הטקסט, אך זה מספיק לשם הדוגמא. הפלט ייראה כך:</p>
-
-<p>{{ EmbedLiveSample('Preventing_default_behavior', '100%', 140, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: ראו את קוד המקור פה <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/events/preventdefault-validation.html">preventdefault-validation.html</a> או <a href="http://mdn.github.io/learning-area/javascript/building-blocks/events/preventdefault-validation.html">דף אינטרנט</a>.</p>
-</div>
-
-<h3 id="event_bubbling_ו-_capture">event bubbling ו- capture</h3>
-
-<p>נושא נוסף שאנחנו נרצה לדון הוא משהו שאמנם לא ניתקל בו הרבה, אך אם לא נכיר אותו ונבין אותו, יכול לעשות לנו כאב ראש לא קטן.</p>
-
-<p>event bubbling ו- capture אלו שני מנגנונים אשר מסבירים מה קורה כאשר שנים או יותר <strong>מטפלי אירוע</strong> של <strong>אותו אירוע</strong> מופעלים על <strong>אלמנט אחד</strong>. לצורך ההסבר, פתחו את <a href="http://mdn.github.io/learning-area/javascript/building-blocks/events/show-video-box.html">show-video-box.html</a> בלשונית חדשה בדפדפן ואת <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/events/show-video-box.html">קוד המקור</a> בלשונית אחרת. ניתן גם לראות את הדוגמא כאן למטה:</p>
-
-<div class="hidden">
-<h6 id="Hidden_video_example">Hidden video example</h6>
-
-<pre class="brush: html">&lt;!DOCTYPE html&gt;
-&lt;html&gt;
- &lt;head&gt;
- &lt;meta charset="utf-8"&gt;
- &lt;title&gt;Show video box example&lt;/title&gt;
- &lt;style&gt;
- div {
- position: absolute;
- top: 50%;
- transform: translate(-50%,-50%);
- width: 480px;
- height: 380px;
- border-radius: 10px;
- background-color: #eee;
- background-image: linear-gradient(to bottom, rgba(0,0,0,0), rgba(0,0,0,0.1));
- }
-
- .hidden {
- left: -50%;
- }
-
- .showing {
- left: 50%;
- }
-
- div video {
- display: block;
- width: 400px;
- margin: 40px auto;
- }
-
- &lt;/style&gt;
- &lt;/head&gt;
- &lt;body&gt;
- &lt;button&gt;Display video&lt;/button&gt;
-
- &lt;div class="hidden"&gt;
- &lt;video&gt;
- &lt;source src="https://raw.githubusercontent.com/mdn/learning-area/master/javascript/building-blocks/events/rabbit320.mp4" type="video/mp4"&gt;
- &lt;source src="https://raw.githubusercontent.com/mdn/learning-area/master/javascript/building-blocks/events/rabbit320.webm" type="video/webm"&gt;
- &lt;p&gt;Your browser doesn't support HTML5 video. Here is a &lt;a href="rabbit320.mp4"&gt;link to the video&lt;/a&gt; instead.&lt;/p&gt;
- &lt;/video&gt;
- &lt;/div&gt;
-
- &lt;script&gt;
-
- var btn = document.querySelector('button');
- var videoBox = document.querySelector('div');
- var video = document.querySelector('video');
-
- btn.onclick = function() {
- displayVideo();
- }
-
- function displayVideo() {
- if(videoBox.getAttribute('class') === 'hidden') {
- videoBox.setAttribute('class','showing');
- }
- }
-
- videoBox.addEventListener('click',function() {
- videoBox.setAttribute('class','hidden');
- });
-
- video.addEventListener('click',function() {
- video.play();
- });
-
- &lt;/script&gt;
- &lt;/body&gt;
-&lt;/html&gt;</pre>
-</div>
-
-<p>{{ EmbedLiveSample('Hidden_video_example', '100%', 500, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<p>זו דוגמא פשוטה שמראה ומסתירה אלמנט {{htmlelement("div")}} שמכיל אלמנט {{htmlelement("video")}} בתוכו:</p>
-
-<pre class="brush: html">&lt;button&gt;Display video&lt;/button&gt;
-
-&lt;div class="hidden"&gt;
- &lt;video&gt;
- &lt;source src="rabbit320.mp4" type="video/mp4"&gt;
- &lt;source src="rabbit320.webm" type="video/webm"&gt;
- &lt;p&gt;Your browser doesn't support HTML5 video. Here is a &lt;a href="rabbit320.mp4"&gt;link to the video&lt;/a&gt; instead.&lt;/p&gt;
- &lt;/video&gt;
-&lt;/div&gt;</pre>
-
-<p>כאשר אנחנו לוחצים על {{htmlelement("button")}} הוידאו מוצג, באמצעות שינוי ה-class של <code>&lt;div&gt;</code> מ- <code>hidden</code> ל- <code>showing</code> (ה-css בקובץ מכיל בין היתר שני classes אשר מציגים את הקופסא במסך או מסתירים אותה, בהתאמה) :</p>
-
-<pre class="brush: js">btn.onclick = function() {
- videoBox.setAttribute('class', 'showing');
-}</pre>
-
-<p>לאחר מכן אנחנו מוסיפים עוד שני מטפלי אירוע של <code>onclick</code> - הראשון ל- <code>&lt;div&gt;</code> והשני ל - <code>&lt;video&gt;</code>. הרעיון הוא שכאשר האזור של ה- <code>&lt;div&gt;</code> מחוץ לוידאו מקבל לחיצה, הקופסא אמורה להיעלם שוב; כאשר הוידאו עצמו נלחץ, הוידאו אמור לפעול שוב:</p>
-
-<pre>videoBox.onclick = function() {
- videoBox.setAttribute('class', 'hidden');
-};
-
-video.onclick = function() {
- video.play();
-};</pre>
-
-<p>אבל ישנה בעי כרגע, כאשר אנחנו לוחצים על הוידאו הוא מתחיל להתנגן, אבל גורם גם ל- <code>&lt;div&gt;</code> להיות מוסתר באותו הזמן. זה מכיוון שהוידאו שבתוך ה-<code>&lt;div&gt;</code> - הוא חלק ממנו - אז כאשר אנחנו לוחצים על הוידאו - אנחנו בעצם גם מפעילים את האירוע על ה-<code>&lt;div&gt;</code> עצמו, ושני מטפלי האירוע נכנסים לפעולה.</p>
-
-<h4 id="bubbling_ו-_capturing">bubbling ו- capturing</h4>
-
-<p>כאשר אירוע מתרחש על אלמנט שיש לו אלמנט אב - לדוגמא האלמנט {{htmlelement("video")}} שלנו, לדפדפנים המודרניים יש שני תהליכים שונים שהם מבצעים: שלב ה- <strong>capturing</strong> ושלב ה- <strong>bubbling</strong>.</p>
-
-<p>בשלב - <strong>capturing</strong>:</p>
-
-<ul>
- <li>הדפדפן בודק האם אלמנט האב הראשי ({{htmlelement("html")}}) מכיל event handler של <code>onclick</code> הרשום בשלב capturing ואם כן הוא מריץ אותו.</li>
- <li>לאחר מכן, ובכל מקרה, הוא עובר לאלמנט הבן שנמצא בתוך - ({{htmlelement("html")}}) - ובודק שוב את הדבר, וכך הלאה, עד אשר הוא מגיע לאלמנט שבפועל לחצנו עליו.</li>
-</ul>
-
-<p>בשלב - <strong>bubbling</strong> קורה בדיוק ההפך:</p>
-
-<ul>
- <li>הדפדפן בודק האם האלמנט שלחצו עליו בפועל מכיל event handler של <code>onclick</code> הרשום עליו בשלב bubbling ואז מריץ אותו אם כן.</li>
- <li>לאחר מכן הוא ממשיך בכל מקרה לאלמנט האב הישיר שלו ומבצע את אותו דבר וכך הלאה, עד שהוא מגיע לאלמנט <code>&lt;html&gt;</code>.</li>
-</ul>
-
-<p><a href="https://mdn.mozillademos.org/files/14075/bubbling-capturing.png"><img alt="" src="https://mdn.mozillademos.org/files/14075/bubbling-capturing.png" style="display: block; height: 452px; margin: 0px auto; width: 960px;"></a></p>
-
-<p>לחצו על התמונה על מנת להגדיל אותה.</p>
-
-<p>בדפדפנים מודרניים, <strong>ברירת המחדל היא שכל ה-event handlers נרשמים בשלב ה-bubbling</strong>. בדוגמא שלנו למשל, כאשר לחצנו על הוידאו, <u><strong>האירוע</strong></u> מסוג לחיצה ״בועבע״ מאלמנט <code>&lt;video&gt;</code> הלאה לאלמנט <code>&lt;html&gt;</code>, כאשר במהלך הדרך :</p>
-
-<ul>
- <li>הוא מצא מטפל אירוע - <code>video.onclick...</code> והריץ אותו ולכן הוידאו החל להתנגן.</li>
- <li>לאחר מכן הוא מצא מטפל אירוע  <code>videoBox.onclick...</code> והריץ אותו גם, ולכן הסתיר את הוידאו (או יותר נכון הסתיר את ה-div שהכיל את הוידאו).</li>
-</ul>
-
-<p><strong>שימו לב שמה שבועבע הוא התרחשות האירוע עצמו, ולא מטפל האירוע (אותו דבר קורה גם בשלב ה-capturing). </strong></p>
-
-<h4 id="תיקון_הבעיה_עם_()stopPropagation">תיקון הבעיה עם ()stopPropagation</h4>
-
-<p>על מנת לתקן את ההתנהגות הזו, לאובייקט האירוע עצמו - event object - יש מתודה זמינה עבורו שנקראת <code><a href="/en-US/docs/Web/API/Event/stopPropagation">()stopPropagation</a></code>, כאשר היא מופעלת על מטפל האירוע של אובייקט האירוע, היא תריץ את מטפל האירוע, אבל <strong>תמנע מהאירוע עצמו להמשיך לבעבע במעלה השרשרת לאלמנטי האב שלו</strong> (וכנ״ל גם בשלב ה- capturing)<strong> </strong>וכך מטפלי אותו אירוע של אלמנטי האב לא ירוצו.</p>
-
-<p>כך, על מנת לתקן את הבעיה בדוגמא שלנו, אנחנו נשנה את הפונקציה המטפלת באירוע כך:</p>
-
-<pre class="brush: js">video.onclick = function(e) {
- e.stopPropagation();
- video.play();
-};</pre>
-
-<p>אתם יכולים ליצור עותק מקומי של קוד המקור של <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/events/show-video-box.html">show-video-box.html </a> ולתקן זאת בעצמכם או לראות הקובץ המתוקן <a href="http://mdn.github.io/learning-area/javascript/building-blocks/events/show-video-box-fixed.html">כאן</a> ואת <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/events/show-video-box-fixed.html">קוד המקור</a> כאן.</p>
-
-<div class="note">
-<p><strong>הערה חשובה</strong>: אתם בטח שואלים את עצמכם מדוע לטרוח וליצור שני שלבים  - גם capturing וגם bubbling? התשובה נעוצה בהיסטוריה ובימי העבר כאשר התאימות בין דפדפנים הייתה שונה מאוד ולא כפי שהיא היום.</p>
-
-<p>בימים ההם Netscape השתמש ב-event capturing בלבד ואילו Internet Explorer השתמש ב - event bubbling בלבד. כאשר ארגון W3C החליט לנסות וליצור סטדרט אחיד, הם החליטו על מנגנון שיכלול את שני השלבים - וכל הדפדפנים אימצו את שני השלבים.</p>
-</div>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: יחד עם זאת, כברירת מחדל, כל מטפלי האירועים נרשמים בשלב bubbling ולא בשלב capturing וברוב המוחלט של הפעמים זה עושה שכל. אם אנחנו ממש רוצים לרשום אירוע בשלב ה-capturing, אנחנו יכולים לעשות זאת באמצעות הוספת <code>true</code> כפרמטר שלישי בתוך <code><a href="/en-US/docs/Web/API/EventTarget/addEventListener">()addEventListener</a></code>. היכנסו לקישור זה אם תרצו להרחיב בנושא. </p>
-</div>
-
-<h4 id="Event_delegation">Event delegation</h4>
-
-<p>bubbling מאפשר לנו להשתמש ביתרונות של <strong>event delegation</strong> — רעיון זה מתבסס על העובדה שאם אנחנו רוצים להריץ קוד מסויים כאשר אנחנו לוחצים על אלמנט ילד אחד שהוא חלק ממספר אלמנטים ילדים של אלמנט אב, אנחנו יכולים לקבוע את מאזין האירוע על אלמנט האב, ואז כאשר האירוע מתרחש על אחד מאלמנטים הילדים, האירוע ״יבועבע״ לאלמנט ההורה שלהם.</p>
-
-<p>כתיבה שכזו עדיפה על רישום מאזין אירוע לכל אחד מהילדים בנפרד. להזכירכם - בשלב ה-bubbling נבדק האם האלמנט שהאירוע התרחש עליו מכיל מטפל אירוע לאירוע שהתרחש ומתקדם הלאה לאלמנט ההורה ומבעבע אליו את האירוע ובודק האם הוא מכיל מטפל אירוע לאירוע שהתרחש וכך הלאה.</p>
-
-<p>דוגמא טובה לכך היא רשימה של פריטים - אם אנחנו רוצים שכל פריט מהרשימה יקפיץ הודעה כאשר לוחצים עליו, אנחנו יכולים לקבוע מאזין אירוע על האלמנט ההורה - במקרה שלנו <code>&lt;ul&gt;</code>, וכל לחיצה על פריט מהרשימה (<code>&lt;li&gt;</code>) -  כלומר כל התרחשות אירוע שכזה על פריט מהרשימה - אירוע הלחיצה יבעבע מאלמנט <code>&lt;li&gt;</code> לאלמנט האב - <code>&lt;ul&gt;</code>.</p>
-
-<p>רעיון זה מוסבר בפירוט רב בבלוג של David Walsh עם דוגמאות נוספות. ראו את המאמר שלו בנושא <a href="https://davidwalsh.name/event-delegate">How JavaScript Event Delegation Works</a>.</p>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>במאמר זה ניסינו להסביר כל מה שאתם צריכים לדעת על אירועי Web בשלב זה. כפי שנאמר למעלה, אירועים הם לא חלק מה-core של JavaScript - הם מוגדרים ב-Web APIs של הדפדפן.</p>
-
-<p>חשוב להבין בנוסף שיש הבדלים בין מודלי האירועים של JavaScript בסביסות השונות שהיא מורצת - החל מ- Web APIs ועד לסביבות אחרות כמו Browser WebExtensions ו- Node.js. לא מצפים מכם שכרגע תבינו את כל הסביבות הללו, אבל זה עוזר לכם להבין את הבסיס ככל ותתקדמו בלמידה.</p>
-
-<p>אם משהו לא ברור, הרגישו חופשי לקרוא שוב את המאמר או <a href="/en-US/Learn#Contact_us">ליצור עמנו קשר</a>.</p>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li><a href="http://www.quirksmode.org/js/events_order.html">Event order</a>  - מאמר מפורט בנושא capturing and bubbling שנכתב על ידי Peter-Paul Koch.</li>
- <li><a href="http://www.quirksmode.org/js/events_access.html">Event accessing</a>  - מאמר מפורט בנושא event object שנכתב גם הוא על ידי Peter-Paul Koch.</li>
- <li><a href="/en-US/docs/Web/Events">Event reference</a></li>
-</ul>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/Building_blocks/Return_values","Learn/JavaScript/Building_blocks/Image_gallery", "Learn/JavaScript/Building_blocks")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/conditionals">קבלת החלטות בקוד - משפטי תנאי - Conditionals</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Looping_code">לולאות - Loops</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Functions">פונקציות - בלוקי קוד לשימוש חוזר - Functions</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Build_your_own_function">בניית פונקציות משלנו</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Return_values">ערכים מוחזרים מהפונקציה - Function return values </a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Events">היכרות ראשונית עם אירועים -Introduction to events</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Image_gallery">תרגול: בניית גלריית תמונות</a></li>
-</ul>
diff --git a/files/he/learn/javascript/building_blocks/functions/index.html b/files/he/learn/javascript/building_blocks/functions/index.html
deleted file mode 100644
index 99255d0591..0000000000
--- a/files/he/learn/javascript/building_blocks/functions/index.html
+++ /dev/null
@@ -1,386 +0,0 @@
----
-title: Functions — פונקציות - חלקי קוד לשימוש חוזר
-slug: Learn/JavaScript/Building_blocks/Functions
-translation_of: Learn/JavaScript/Building_blocks/Functions
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/Building_blocks/Looping_code","Learn/JavaScript/Building_blocks/Build_your_own_function", "Learn/JavaScript/Building_blocks")}}</div>
-
-<p class="summary">עקרון חשוב והכרחי נוסף בתכנות הוא פונקציות - <strong>functions. פונקציות</strong> מאפשרות לנו לאחסן קוד בתוך בלוק מוגדר ומבצע פעולה מסויימת, ואז לקרוא לאותו קוד מתי שנצטרך אותו באמצעות פקודה קצרה. זאת במקום לרשום את אותו קוד שוב ושוב. במאמר זה אנחנו נחקור את העקרונות הבסיסיים והחשובים שמאחורי פונקציות כמו הסינטקס הבסיסי שלהן, כיצד להגדיר אותן, כיצד להפעיל אותן, נלמד מהו סקופ ופרמטרים ועוד.</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>הכרות בסיסית עם המחשב ועם הבסיס של HTML ו- CSS, וכן סיום במלאו של <a href="/en-US/docs/Learn/JavaScript/First_steps">מודול צעדים ראשונים ב-JavaScript</a>.</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>הבנה של עקרונות היסוד בנושא פונקציות ב-JavaScript.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="איפה_נמצא_פונקציות">איפה נמצא פונקציות?</h2>
-
-<p>ב-JavaScript אנחנו נמצא פונקציות בכל מקום. בעיקרון, אנחנו השתמשנו בפונקציות לאורך כל הדרך של הקורס, פשוט לא פירטנו עליהם לעומק. כעת אנחנו ניכנס לעומק של אלו ונבין כיצד להשתמש בהם.</p>
-
-<p>כמעט כל פעם שאנחנו עושים שימוש בביטוי מסויים של JavaScript שעושה שימוש בסוגריים רגילות <code>()</code> וזה <u><strong>לא</strong></u> במסגרת לולאת <a href="/en-US/Learn/JavaScript/Building_blocks/Looping_code#The_standard_for_loop">for</a> או לולאות <a href="/en-US/Learn/JavaScript/Building_blocks/Looping_code#while_and_do_..._while">while ו- do...while loop</a> או משפטי תנאי <a href="/en-US/Learn/JavaScript/Building_blocks/conditionals#if_..._else_statements">if...else</a> אנחנו בעצם עושים שימוש בפונקציות.</p>
-
-<h2 id="פונקציות_מובנות_Built-in_של_הדפדפן">פונקציות מובנות (Built-in) של הדפדפן</h2>
-
-<p>אנחנו ביצענו לא מעט שימוש בפונקציות המובנות בדפדפן. בכל פעם שעשינו מניפולציה על מחרוזת לדוגמא:</p>
-
-<pre class="brush: js notranslate">let myText = 'I am a string';
-let newString = myText.replace('string', 'sausage');
-console.log(newString);
-// the replace() string function takes a source string,
-// and a target string and replaces the source string,
-// with the target string, and returns the newly formed string</pre>
-
-<p>או בכל פעם שעשינו מניפולציה על מערך:</p>
-
-<pre class="brush: js notranslate">let myArray = ['I', 'love', 'chocolate', 'frogs'];
-let madeAString = myArray.join(' ');
-console.log(madeAString);
-// the join() function takes an array, joins
-// all the array items together into a single
-// string, and returns this new string</pre>
-
-<p>או בכל פעם שרצינו ליצור מספר רנדומלי:</p>
-
-<pre class="brush: js notranslate">let myNumber = Math.random();
-// the random() function generates a random number between
-// 0 and up to but not including 1, and returns that number</pre>
-
-<p>אנחנו בעצם השתמשנו בפונקציות.</p>
-
-<div class="note">
-<p><strong>תשומת לבכם</strong>: נסו להכניס את השורות קוד הרשומות למעלה לקונסולה אם אתם לא זוכרים איך לעשות בהם שימוש.</p>
-</div>
-
-<p>ל- JavaScript יש לא מעט פונקציות מובנות אשר מאפשרות לנו לעשות דברים שימושיים מבלי לכתוב את כל הקוד בעצמנו. בפועל, חלק מהקוד שאנחנו מריצים כאשר אנחנו אנחנו קוראים לפונקציה מובנית של הדפדפן, לא יכל היה להירשם ב-JavaScript - הרבה מהפונקציות הללו קוראות לחלקים בקוד הדפדפן עצמו, אשר נבנה בשפה אחרת שאינה JavaScript כלל.</p>
-
-<p>אנא זכרו שחלק מהפונקציות המובנות של הדפדפם אינן חלק מהבסיס של שפת JavaScript - חלקן מהן מוגדרות כחלק מה-API של הדפדפן, אשר בנוי מעל שפת הכתיבה של הדפדפן על מנת להעניק יותר פונקציונליות. אנחנו נסתכל על ה-API של הדפדפן בהמשך המודול. לרענון זכרונכם, <a href="/en-US/Learn/JavaScript/First_steps/What_is_JavaScript#So_what_can_it_really_do">ראו מאמר זה מתחילת הקורס</a>.</p>
-
-<h2 id="functions_vs._methods_-_פונקציות_מול_מתודות">functions vs. methods  - פונקציות מול מתודות</h2>
-
-<p>אנו קוראים לפונקציות שהן חלק מאובייקטים כ-מתודות (methods). אנחנו לא צריכים כרגע לדעת על המבנה הפנימי של אובייקטים ב-JavaScript - אנו נלמד את זה לעומק במודול הבא. לבינתיים, רק רצינו למנוע בלבול בין המושגים השונים. רוב הסיכויים שתשמעו את שניהם.</p>
-
-<p>הקוד המובנה שעשינו בו שימוש לבינתיים מגיע ב-2 תצורות: פונקציות ו-מתודות. אתם יכולים לבדוק את הרשימה המלאה של פונקציות מובנות וכן את הרשימה המלאה של אובייקטים מובנים והמתודות שלהם <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects">פה</a>.</p>
-
-<p>כמו כן, ראינו הרבה פונקציות מותאמות -<strong>custom functions</strong> - פונקציות שאנחנו הגדרנו בעצמנו ולא מוגדרות בתוך הדפדפן עצמו. בכל פעם שאנחנו רואים שם שאינו שם שמור של השפה ולאחריו סוגריים רגילות <code>()</code>, זוהי פונקציה שהמפתח הגדיר בעצמו. בתרגול שלנו <a href="http://mdn.github.io/learning-area/javascript/building-blocks/loops/random-canvas-circles.html">random-canvas-circles.html</a> וגם <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/loops/random-canvas-circles.html">בקוד המקור שלו</a> במאמר בנושא <a href="/en-US/docs/Learn/JavaScript/Building_blocks/Looping_code">לולאות</a>, כללנו פונקציה <code>()draw</code> שאנחנו בנינו שנראית כך :</p>
-
-<pre class="brush: js notranslate">function draw() {
- ctx.clearRect(0,0,WIDTH,HEIGHT);
- for (let i = 0; i &lt; 100; i++) {
- ctx.beginPath();
- ctx.fillStyle = 'rgba(255,0,0,0.5)';
- ctx.arc(random(WIDTH), random(HEIGHT), random(50), 0, 2 * Math.PI);
- ctx.fill();
- }
-}</pre>
-
-<p>פונקציה זו מציירת 100 עיגולים אקראיים בתוך אלמנט {{htmlelement("canvas")}} . בכל פעם שאנחנו רוצים לעשות זאת, אנחנו יכולים להפעיל את הפונקציה עם הקוד הבא:</p>
-
-<pre class="brush: js notranslate">draw();
-</pre>
-
-<p>במקום לכתוב את כל הקוד שבתוך הפונקציה בכל פעם שאנחנו רוצים שיצוייר עיגול. </p>
-
-<p>פונקציות יכולות להכיל כל קוד שנרצה - אנחנו אפילו יכולים לקרוא לפונקציות אחרות מתוך פונקציות. הפונקציה למעלה לדוגמא, קוראת לפונקציה <code>()random</code> שלוש פעמים, כפי שאנו רואים בקוד הבא:</p>
-
-<pre class="brush: js notranslate">function random(number) {
- return Math.floor(Math.random()*number);
-}</pre>
-
-<p>אנחנו צריכים לבנות את הפונקציה <code>()random</code> כי הפונקציה המובנית של הדפדפן <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/random">()Math.random</a> מייצרת לנו מספר רנדומלי, אבל מספר רנדומלי עשרוני בין 0 ל-1. אנחנו לעומת זאת רצינו מספר רנדומלי שלם ולא עשרוני ושיהיה בין 0 למספר מסויים שאנחנו נגדיר לו.</p>
-
-<h2 id="Invoking_functions_-_קריאה_לפונקציה">Invoking functions - קריאה לפונקציה</h2>
-
-<p>ככל הנראה אתם כבר מבינים את הנושא, אבל בכל מקרה אנו מזכירים שכדי להשתמש בפועל בפונקציה אחרי שהיא הוגדרה, אנחנו צריכים להריץ אותה, לקרוא לה. בשפה האנגלית זה נקרא <strong>To invoke</strong>. זה נעשה באמצעות כתיבת שם הפונקציה איפה שנרצה בתוך הקוד שלנו, ולאחריו סוגריים מסולסלות <code>()</code>.</p>
-
-<pre class="brush: js notranslate">function myFunction() {
- alert('hello');
-}
-
-myFunction()
-// calls the function once</pre>
-
-<h2 id="Anonymous_functions_-_פונקציות_אנונימיות">Anonymous functions - פונקציות אנונימיות</h2>
-
-<p>אולי נתקלתם בפונקציות אשר מוגדרות ומופעלות בצורות אחרות. עד עכשיו, יצרנו פונקציה בצורה כזו:</p>
-
-<pre class="brush: js notranslate">function myFunction() {
- alert('hello');
-}</pre>
-
-<p>אבל אנחנו גם יכולים ליצור פונקציה שאין לה שם:</p>
-
-<pre class="brush: js notranslate">function() {
- alert('hello');
-}</pre>
-
-<p>פונקציה שכזו נקראת פונקציה אנונימית - <strong>anonymous function</strong> - אין לה שם. היא גם לא עושה כלום בעצמה. בדרך כלל אנחנו נשתמש בפונקציה אנונימית ביחד עם ״מטפל אירוע״ - event handler. לדוגמא, הקוד הבא יריץ את הקוד בנמצא בתוך הפונקציה, כאשר הכפתור myButton נלחץ:</p>
-
-<pre class="brush: js notranslate">var myButton = document.querySelector('button');
-
-myButton.onclick = function() {
- alert('hello');
-}</pre>
-
-<p>הדוגמא למעלה דורשת שיהיה אלמנט {{htmlelement("button")}} זמין על גבי הדף כדי שנוכל לבחור אותו וללחוץ עליו. ראיתם מבנה שכזה מספר פעמים במהלך הקורס ואתם תלמדו עליו עוד בהמשך הקורס.</p>
-
-<p>אנחנו יכולים להשים פונקציה אנונימית לתוך משתנה כך שהיא תהיה הערך של אותו משתנה. לדוגמא:</p>
-
-<pre class="brush: js notranslate">let myGreeting = function() {
- alert('hello');
-}</pre>
-
-<p>ניתן להפעיל את הפונקציה הזו (invoke) באמצעות:</p>
-
-<pre class="brush: js notranslate">myGreeting();</pre>
-
-<p>בפועל, זה מעניק לשם פונקציה, למרות שהיא הייתה פונקציה אנונימית. אנחנו גם יכולים להשים את הפונקציה כך שהיא תהיה הערך של מספר משתנים. לדוגמא:</p>
-
-<pre class="brush: js notranslate">let anotherGreeting = myGreeting;</pre>
-
-<p>הפונקציה הזו יכולה להיות מופעלת בשתי הדרכים:</p>
-
-<pre class="brush: js notranslate">myGreeting();
-anotherGreeting();</pre>
-
-<p>אבל זה עלול להיות מבלבל, <strong>אז אל תעשו זאת</strong>. כשאנחנו יוצרים פונקציות, עדיף יהיה להיצמד למבנה הזה:</p>
-
-<pre class="brush: js notranslate">function myGreeting() {
- alert('hello');
-}</pre>
-
-<p>אנחנו נשתמש בפונקציות אנונימיות בעיקר על מנת להריץ קוד בתגובה לאירוע שהתרחש - כמו לחיצה על כפתור - וזאת באמצעות ״מטפל אירוע״ - event handler. לדוגמא:</p>
-
-<pre class="brush: js notranslate">myButton.onclick = function() {
- alert('hello');
- // I can put as much code
- // inside here as I want
-}</pre>
-
-<h2 id="הפרמטרים_של_הפונקציה">הפרמטרים של הפונקציה</h2>
-
-<p>חלק מהפונקציות דורשות שיינתנו להם פרמטרים מסויימים כשאנחנו מפעילים אותן - אלו בעצם ערכים שאנחנו צריכים לכלול בתוך הסוגריים הרגילות <code>()</code>, וזאת על מנת שהפונקציה תוכל לבצע את מה שהיא צריכה לבצע.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: פרמטרים אלו נקראים ארגומנטים</p>
-</div>
-
-<p>כדוגמא, הפונקציה המובנית של הדפדפן לא דורשת שום פרמטרים. כשאנחנו קוראים לה, היא מחזירה מספר עשרוני בין 0 ל-1. <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/random">()Math.random</a>:</p>
-
-<pre class="brush: js notranslate">let myNumber = Math.random();</pre>
-
-<p>הפונקציה המובנית של הדפדפן <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/replace">()replace</a> לעומת זאת, צריכה שני ארגומנטים - מחרוזת משנה שנרצה לחפש בתוך מחרוזת ראשית ואת המחרוזת המשנה שתחליף את זו שמצאנו בתוך המחרוזת הראשית:</p>
-
-<pre class="brush: js notranslate">let myText = 'I am a string';
-let newString = myText.replace('string', 'sausage');</pre>
-
-<div class="note">
-<p><strong>שימו לב</strong>: כשאנחנו צריכים לציין מספר של ארגומנטים, אנחנו נפריד ביניהם באמצעות פסיק - <code>,</code>.</p>
-</div>
-
-<p>חשוב לדעת כי לפעמים ארגומנטים יהיו אופציונליים - כלומר אנחנו לא נהיה חייבים לציין אותם. אם לא נציין אותם כאשר הם אופציונליים, הפונקציה בדרך כלל תאמץ סוג של התנהגות ברירת מחדל. לדוגמא, הפרמטר של פונקציה <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/join">()join</a> של מערכים הוא אופציונלי:</p>
-
-<pre class="brush: js notranslate">let myArray = ['I', 'love', 'chocolate', 'frogs'];
-let madeAString = myArray.join(' ');
-// returns 'I love chocolate frogs'
-let madeAString = myArray.join();
-// returns 'I,love,chocolate,frogs'</pre>
-
-<p>אם לא נציין אותו, ערך ברירת המחדל הוא שיהיה התו המחבר - במקרה הזה זה יהיה פסיק <code>,</code>.</p>
-
-<h2 id="סקופ_של_הפונקציה_והתנגשויות">סקופ של הפונקציה והתנגשויות</h2>
-
-<p>בוא נדבר מעט על {{glossary("scope")}} - עקרון חשוב מאוד להבנה כאשר אנחנו עוסקים בפונקציות. כאשר אנחנו יוצרים פונקציה, המשתנים וכל הדברים האחרים המוגדרים בתוך הפונקציה נמצאים בתוך <strong>scope</strong> נפרד, כלומר, הם נעולים בתוך מתחם מסויים, שלא ניתן לגשת אליו מחוץ לפונקציה.</p>
-
-<p>הסקופ או התחום שנמצא מחוץ לכל הפונקציות שלנו נקרא <strong>global scope</strong>. ערכים שמוגדרים ב-<strong>global scope</strong> נגישים מכל מקום בקוד.</p>
-
-<p>JavaScript נבנתה כך בצורה מסיבות מסויימות - אבל בעיקר מסיבות של אבטחה וארגון. לפעמים אנחנו לא נראה שמשתנים יהיו נגישים מכל מקום בקוד - סקריפטים חיצוניים שאנחנו מפעילים ממקומות אחרים יכולים לעשות לנו בלאגן ולגרום לשגיאות במקרה והם ישתמשו בשמות משתנים זהים ועלולים ליצור התנגשויות בין אם בטעות ובין אם מכוון.</p>
-
-<p>לדוגמא, נניח ויש לנו קובץ HTML אשר קורא לשני קבצי JavaScript חיצוניים, ובשניהם יש משתנה ופונקציה מוגדרים שמשתמשים באותו שם:</p>
-
-<pre class="brush: html notranslate">&lt;!-- Excerpt from my HTML --&gt;
-&lt;script src="first.js"&gt;&lt;/script&gt;
-&lt;script src="second.js"&gt;&lt;/script&gt;
-&lt;script&gt;
- greeting();
-&lt;/script&gt;</pre>
-
-<pre class="brush: js notranslate">// first.js
-var name = 'Chris';
-function greeting() {
- alert('Hello ' + name + ': welcome to our company.');
-}</pre>
-
-<pre class="brush: js notranslate">// second.js
-var name = 'Zaptec';
-function greeting() {
- alert('Our company is called ' + name + '.');
-}</pre>
-
-<p>שתי הפונקציות שאנחנו רוצים לקרוא להם נקראות <code>()greeting</code>, אבל אנחנו יכולים לגשת רק לפונקציה <code>()greeting</code> שבקובץ <code>second.js</code> - שכן הקישור לקובץ מבוצע ב -HTML מאוחר יותר בקוד שלנו, ולכן המשתנים והפונקציה שלו דורסים את אלו שב- <font face="consolas, Liberation Mono, courier, monospace"><span style="background-color: rgba(220, 220, 220, 0.498039);">first.js</span></font>.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: ניתן לראות את הדוגמא <a href="http://mdn.github.io/learning-area/javascript/building-blocks/functions/conflict.html">ב-GitHub</a> וכן את <a href="https://github.com/mdn/learning-area/tree/master/javascript/building-blocks/functions">קוד המקור</a>).</p>
-</div>
-
-<p>שמירה על הקוד שלנו נעול בתוך סקופ מונע בעיות שכאלו ונחשב כ- best practice.</p>
-
-<p>ניתן לחשוב על זה כמו גן חיות. האריות, זברות, נמרים ופינגווינים נמצאים כל במתחמים נפרדים כל אחד, ויש להם גישה רק לדברים שנמצאים במתחם שלהם - בדיוק כמו בסקופים של פונקציות. אם הם היו יכולים להיכנס למתחמים אחרים, היו נוצרות לא מעט בעיות. במקרה הטוב, החיות האחרות היו מרגישות לא בנוח, במקרה הרע, הן היו נאכלות על ידי חיה אחרת.</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/14079/MDN-mozilla-zoo.png" style="display: block; margin: 0 auto;"></p>
-
-<h3 id="למידה_אקטיבית_לשחק_עם_ה-scope">למידה אקטיבית: לשחק עם ה-scope</h3>
-
-<p>נסתכל על דוגמא על מנת להבין מהו scope.</p>
-
-<ol>
- <li>ראשית, צרו לעצמכם עותק של הדוגמא שלנו <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/functions/function-scope.html">function-scope.html</a>. הקובץ מכיל 2 פונקציות שנקראות <code>()a</code> ו- <code>()b</code> וכן שלושה משתנים - <code>x</code>, <code>y</code>, ו- <code>z</code> - שניים מתוכם מוגדרים בתוך פונקציות ואחד מתוכם מוגדר ב-global scope. בנוסף, הדוגמא גם מכילה פונקציה שלישית שנקראת <code>()output</code>, אשר מקבלת ארגומנט אחד ומציגה אותו בתוך פסקה על גבי הדף.</li>
- <li>פתחו את הדוגמא בדפדפן ובעורך הקוד שלכם.</li>
- <li>הקלידו בקונסולה את הקוד הבא:
- <pre class="brush: js notranslate">output(x);</pre>
- אתם אמורים לראות שהערך של המשתנה <code>x</code> הוצג למסך.</li>
- <li>כעת נסו להזין את הקוד הבא לקונסולה:
- <pre class="brush: js notranslate">output(y);
-output(z);</pre>
- שתי הפקודות הללו יחזירו לנו שגיאה ביחד עם המשפט: "<a href="/en-US/docs/Web/JavaScript/Reference/Errors/Not_defined">ReferenceError: y is not defined</a>". מדוע? הסיבה נעוצה ב-scope של הפונקציות: - <code>y</code> ו- <code>z</code> נעולים בתוך הפונקציות <code>()a</code> ו- <code>()b</code> ולכן הפונקציה <code>()output</code> לא יכולה לגשת אליהם כשהיא נקראת מה-global scope.</li>
- <li>עם זאת, מה לדעתכם יקרה כשנקרא לפונקציה <code>()output </code>מתוך הפונקציות? נסו לשנות את <code>()a</code> ו- <code>()b</code> שייראו כך:
- <pre class="brush: js notranslate">function a() {
- let y = 2;
- output(y);
-}
-
-function b() {
- let z = 3;
- output(z);
-}</pre>
- שמרו את הקוד ואז העלו מחדש את הדף בדפדפן ונסו לקרוא לפונקציות <code>()a</code> ו- <code>()b</code> מהקונסולה:
-
- <pre class="brush: js notranslate">a();
-b();</pre>
- אתם אמורים לראות את הערכים של <code>y</code> ו- <code>z</code> על גבי הדף. זה עובד מכיוון שהפונקציה <code>()output</code> מופעלת מתוך פונקציה אחרת - כלומר מתוך אותו סקופ שבו מוגדרים המשתנים שהיא מדפיסה. הפונקציה <code>()output</code> עצמה זמיני מכל מקום, שכן היא מוגדרת ב-global scope.</li>
- <li>נסו עכשיו לעדכן את הקוד שלכם כך:
- <pre class="brush: js notranslate">function a() {
- var y = 2;
- output(x);
-}
-
-function b() {
- var z = 3;
- output(x);
-}</pre>
- רענון והעלו את הדף שוב והזינו את הקוד הבא בקונסולה:</li>
- <li>
- <pre class="brush: js notranslate">a();
-b();</pre>
- גם <code>a()</code> וגם <code>b()</code> מחזירים את הערך של x — 1. זה עובד מכיוון שלמרות ש-<code>()output</code> לא מוגדרת באותו סקופ ש- <code>x</code> מוגדר בו, אבל <font face="consolas, Liberation Mono, courier, monospace"><span style="background-color: rgba(220, 220, 220, 0.498039);">x</span></font> הוא משתנה גלובלי אז הוא זמין בכל מקום בקוד.</li>
- <li>לבסוף, עדכנו את הקוד כך:
- <pre class="brush: js notranslate">function a() {
- var y = 2;
- output(z);
-}
-
-function b() {
- var z = 3;
- output(y);
-}</pre>
- שמור ורענן את הדף. לאחר מכן הזן את הקוד הבא בקונסולה:</li>
- <li>
- <pre class="brush: js notranslate">a();
-b();</pre>
- הפעם כשקראנו ל- <code>()a</code> ו- <code>()b</code> אנחנו נקבל שגיאה מסוג "<a href="/en-US/docs/Web/JavaScript/Reference/Errors/Not_defined">ReferenceError: z is not defined</a>" זה מכיוון שביצוע הקוד <code>()output</code> והמשתנים שהם מנסים להשיג לא מוגדרים בתוך אותו סקופ של פונקציה - המשתנים בעיקרון בלתי נראים לקריאות הפונציה הזו.</li>
-</ol>
-
-<div class="note">
-<p><strong>לתשומת לבכם</strong>: אותו מנגנון סקופינג לא חל על לולאות <code>{ ... }(...) for</code> ובלוקים של תנאים - <code>{ ... }(...) if</code> הם אמנם נראים דומים, אבל הם לא אותו דבר. אל תתבלבלו.</p>
-</div>
-
-<div class="note">
-<p><strong>לתשומת לבכם</strong>: השגיאה <a href="/en-US/docs/Web/JavaScript/Reference/Errors/Not_defined">ReferenceError: "x" is not defined</a> היא אחת מהשגיאות השכיחות שתיתקלו בה. אם קיבלתם שגיאה שכזו, וודאו שהגדרת את המשתנה הרלוונטי ובסקופ הרלוונטי.</p>
-</div>
-
-<ul>
-</ul>
-
-<h3 id="פונקציות_בתוך_פונקציות">פונקציות בתוך פונקציות</h3>
-
-<p>זכרו שאנחנו יכולים לקרוא לפונקציה מכל מקום, <strong>גם מתוך פונקציה אחרת</strong>. זה שימושי על מנת על מנת להשאיר את הקוד שלנו מסודר - אם יש לנו פונקציה אחת מורכבת וגדולה יהיה יותר ברור להבין אותה אם נפרק אותה לכמה פונקציות:</p>
-
-<pre class="brush: js notranslate">function myBigFunction() {
- var myValue;
-
- subFunction1();
- subFunction2();
- subFunction3();
-}
-
-function subFunction1() {
- console.log(myValue);
-}
-
-function subFunction2() {
- console.log(myValue);
-}
-
-function subFunction3() {
- console.log(myValue);
-}
-</pre>
-
-<p>חשוב לוודא שה<strong>ערכים שמבוצע בהם שימוש בתוך הפונקציה, מוגדרים בסקופ הנכון</strong>. הדוגמא למעלה תחזיר לנו שגיאה <code>ReferenceError: myValue is not defined</code> מכיוון שאמנם המשתנה <code>myValue</code> מוגדר באותו סקופ שהפונקציה נקראת, אך הוא לא מוגדר בתוך הפונקציות עצמן - בתוך הקוד שירוץ בפועל כשאנחנו קוראים לתתי פונקציות. על מנת לגרום לכך לעבוד, היינו צריכים להעביר אליהם את הפונקציה כפרמטר כמו שרשום בקוד מטה:</p>
-
-<pre class="brush: js notranslate">function myBigFunction() {
- var myValue = 1;
-
- subFunction1(myValue);
- subFunction2(myValue);
- subFunction3(myValue);
-}
-
-function subFunction1(value) {
- console.log(value);
-}
-
-function subFunction2(value) {
- console.log(value);
-}
-
-function subFunction3(value) {
- console.log(value);
-}</pre>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>מאמר זה סקר את העקרונות יסוד של פונקציות, על מנת לסלול את הדרך שלכם להבנה של כלים שימושיים נוספות ולהבנה כיצד לבנות פונקציה משלכם.</p>
-
-<h2 id="ראו_גם">ראו גם</h2>
-
-<ul>
- <li><a href="/en-US/docs/Web/JavaScript/Guide/Functions">Functions מדריך מפורט בנושא</a> — מכסה אפשרויות מתקדמות שלא נדונו במאמר זה.</li>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Functions">Functions reference</a></li>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Functions/Default_parameters">Default parameters</a>, <a href="/en-US/docs/Web/JavaScript/Reference/Functions/Arrow_functions">Arrow functions</a> — הסבר מתקדם בנושא.</li>
-</ul>
-
-<ul>
-</ul>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/Building_blocks/Looping_code","Learn/JavaScript/Building_blocks/Build_your_own_function", "Learn/JavaScript/Building_blocks")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/conditionals">קבלת החלטות בקוד - משפטי תנאי - Conditionals</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Looping_code">לולאות - Loops</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Functions">פונקציות - בלוקי קוד לשימוש חוזר - Functions</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Build_your_own_function">בניית פונקציות משלנו</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Return_values">ערכים מוחזרים מהפונקציה - Function return values </a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Events">היכרות ראשונית עם אירועים -Introduction to events</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Image_gallery">תרגול: בניית גלריית תמונות</a></li>
-</ul>
diff --git a/files/he/learn/javascript/building_blocks/index.html b/files/he/learn/javascript/building_blocks/index.html
deleted file mode 100644
index e60d618b4e..0000000000
--- a/files/he/learn/javascript/building_blocks/index.html
+++ /dev/null
@@ -1,51 +0,0 @@
----
-title: אבני הבנין של JavaScript
-slug: Learn/JavaScript/Building_blocks
-tags:
- - JavaScript
- - events
- - אירועים
- - לולאות
- - מדריך
- - ערכים מוחזרים מפונקציה
- - פונקציות
- - תנאים - Conditionals
-translation_of: Learn/JavaScript/Building_blocks
----
-<div>{{LearnSidebar}}</div>
-
-<p class="summary">במודול זה, אנחנו נמשיך להעמיק ביסודות ובמאפיינים והחשובים של JavaScript ונתמקד בסוגים שונים של קוד כגון משפטי תנאי (conditional statements),לולאות (loops), פונקציות (functions), ואירועים (events). חלק מהם כבר ראינו בשלבים קודמים של הקורס, אך לא העמקנו בהם. במודול זה ניכנס לעומק של אותן אבני בניין ונבין כיצד הן עובדות ומה מטרתן.</p>
-
-<h2 id="ידע_מוקדם">ידע מוקדם</h2>
-
-<p>לפני שתתחילו את המודול הזה, אנא וודאו כי הנכם בקיאים ביסודות <a href="/he/docs/Learn/HTML/Introduction_to_HTML">HTML</a> ושל <a href="/he/docs/Learn/CSS/Introduction_to_CSS">CSS</a>, וכן סיימתם לעבור על המודול הקודם שלנו <a href="/he/docs/Learn/JavaScript/First_steps"> צעדים ראשונים ב-JavaScript</a>.</p>
-
-<div class="note">
-<p><strong>הערה</strong>: אם אתם עובדים על מחשב\טבלט\מכשיר אחר שאין לכם אפשרות ליצור עליו קבצים אישיים, אתם יכולים לנסות את (רוב) דוגמאות הקוד על תוכנות קוד אינטרנטיות כמו <a href="http://jsbin.com/">JSBin</a> או <a href="https://thimble.mozilla.org/">Thimble</a>.</p>
-</div>
-
-<h2 id="מדריכים">מדריכים</h2>
-
-<dl>
- <dt><a href="/he/docs/Learn/JavaScript/Building_blocks/conditionals">קבלת החלטות בקוד - משפטי תנאי - Conditionals</a></dt>
- <dd>כמו בכל שפת תכנות, קוד צריך לקבל החלטות ולבצע פעולות מסויימות בהתאם למקרים שונים. לדוגמא - במשחק, אם מספר הנסיונות המותרים של השחקן עבר את מספר הנסיונות המקסימלי שהוגדר, המשמעות היא שהמשחק הסתיים. או יישום אינטרנט של מזג אוויר אשר יציג למשתמש עיצוב מסויים של מזג האוויר בהתאם לשעה הנוכחית ביום, כך שבשעות היום יוצג עיצוב בהיר ובשעות הערב יוצג עיצוב כהה. במאמר זה אנחנו נחקור את המבנה של <strong>משפטי תנאי</strong> ב-JavaScript וכיצד הם עובדים.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/Building_blocks/Looping_code">לולאות - Loops</a></dt>
- <dd>לפעמים אנחנו נצטרך לבצע את אותה פעולה או משימה ברצף, יותר מפעם אחת. לדוגמא -  כשנרצה לעבור רשימת שמות. בתכנות, <strong>לולאות</strong> יכולות לעשות את העבודה הזו בצורה מצויינת. במאמר זה אנחנו נחקור את המבנה של לולאות ב- JavaScript וכיצד הן עובדות.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/Building_blocks/Functions">פונקציות - בלוקי קוד לשימוש חוזר - Functions</a></dt>
- <dd>קונספט הכרחי חשוב בתכנות הוא <strong>פונקציות. </strong>פונקציות מאפשרות לנו לאחסן חלקי קוד שמבצעים פעולה מסויימת בתוך בלוק מוגדר, ואז לקרוא לאותו קוד כשנצטרך להשתמש בו, באמצעות פקודה קצרה - וזאת במקום לרשום את אותו קוד פעם אחר פעם, כל פעם מחדש. במאמר זה נחקור את המבנה של פונקציה והרעיון העומד מאחוריה, ונבין מה הוא הסינטקס הבסיסי על מנת לרשום פונקציה, כיצד אנו קוראים לפונקציה ועוד. כמו כן, נלמד מהם ארגומנטים או פרמטרים אשר הפונקציות יכולות לקבל וכן מהו Scope.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/Building_blocks/Build_your_own_function">בניית פונקציות משלנו</a></dt>
- <dd>לאחר שנסיים לעבור על התיאוריה ונבין מהן פונקציות, במאמר זה נתרגל ונבין בצורה מעשית כיצד לבנות פונקציות משלנו, בהתאם לפעולת שנרצה לבצע. בהמשך הדרך, אנחנו נסביר גם פרטים שימושיים כיצד לטפל בפונקציות ובערכים שהן יכולות להחזיר לנו. </dd>
- <dt><a href="/he/docs/Learn/JavaScript/Building_blocks/Return_values">ערכים מוחזרים מהפונקציה</a> - <a href="/he/docs/Learn/JavaScript/Building_blocks/Return_values">Function return values</a></dt>
- <dd>עקרון הכרחי וחשוב שאנחנו צריכים להכיר לגבי פונקציות הוא אילו ערכים פונקציות מחזירות לנו, אם בכלל. ישנן פונקציות שלא מחזירות ערכים לאחר שסיימו להריץ את הקוד שבתוכן, וישנן פונקציות שיחזירו לנו ערכים מסויימים. במאמר זה אנחנו נבין מהם אותם <strong>ערכים מוחזרים</strong>, כיצד אנחנו יכולים להשתמש בהם וכיצד אנחנו יכולים לגרום לפונקציות שלנו להחזיר ערכים. </dd>
- <dt><a href="/he/docs/Learn/JavaScript/Building_blocks/Events">היכרות ראשונית עם אירועים -Introduction to events </a></dt>
- <dd><strong>אירועים</strong> אלו בעצם פעולות או התרחשויות אשר קורים במערכת, אשר אנחנו יכולים ״להאזין״ להם כך שנוכל להגיב בדרך מסויימת, ברגע שהם יתרחשו. לדוגמא, כאשר משתמש לוחץ על כפתור, אולי נרצה להגיב לאותה התרחשות, לאותו אירוע של לחיצת הכפתור על ידי הקפצת הודעה מסויימת. במאמר אחרון זה אנחנו נדון בכמה מהעקרונות החשובים בהקשר של אירועים, ונסתכל כיצד הם עובדים בדפדפנים.</dd>
-</dl>
-
-<h2 id="תרגול">תרגול</h2>
-
-<p>התרגול הבא יבדוק את ההבנה שלכם של החומר שנלמד במודול זה</p>
-
-<dl>
- <dt><a href="/he/docs/Learn/JavaScript/Building_blocks/Image_gallery">בניית גלריית תמונות</a></dt>
- <dd>אנו נתרגל שימוש בלולאות ופונקציות וכן בתנאים ואירועים על ידי בנייה של גלריית תמונות.</dd>
-</dl>
diff --git a/files/he/learn/javascript/building_blocks/looping_code/index.html b/files/he/learn/javascript/building_blocks/looping_code/index.html
deleted file mode 100644
index b9067199e7..0000000000
--- a/files/he/learn/javascript/building_blocks/looping_code/index.html
+++ /dev/null
@@ -1,931 +0,0 @@
----
-title: לולאות
-slug: Learn/JavaScript/Building_blocks/Looping_code
-translation_of: Learn/JavaScript/Building_blocks/Looping_code
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/Building_blocks/conditionals","Learn/JavaScript/Building_blocks/Functions", "Learn/JavaScript/Building_blocks")}}</div>
-
-<p class="summary">שפות תכנות הן שימושיות מאוד כשזה קשור לביצוע משימות מסויימות שוב ושוב. מביצוע חישובים מתמטיים עד לכל דבר שאנחנו יכולים לחשוב עליו. במאמר זה נסתכל על מבנים שלו לולאות שזמינים עבורנו ב-JavaScript.</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>הכרות בסיסית עם המחשב ועם הבסיס של HTML ו- CSS, וכן סיום במלאו של <a href="/en-US/docs/Learn/JavaScript/First_steps">מודול צעדים ראשונים ב-JavaScript</a>.</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>להבין כיצד להשתמש בלולאות ב-JavaScript ומתי.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="מה_הן_לולאות">מה הן לולאות?</h2>
-
-<p>לולאו הן עקרון חשוב מאוד בתכנות. לולאות קוד מכילות פעולות שנרצה לבצע שוב ושוב - ובשפה מקצועית - איטראציה - <strong>Iteration</strong>.</p>
-
-<p>יש הרבה סוגי לולאות - אבל כולן עושות בעיקרון את אותו דבר: הן חוזרות על פעולה מסויימת מספר פעמים (ואף יכול להיות גם 0 פעמים).</p>
-
-<p>ננסה להבין זאת באמצעות דוגמא פשוטה. נניח ויש לנו חקלאי אשר רוצה לוודא שיש לו מספיק אוכל למשפחה להמשך השבוע. הוא עשוי להשתמש בלולאה הבאה על מנת לעשות זאת:</p>
-
-<p><br>
- <img alt="" src="https://mdn.mozillademos.org/files/13755/loop_js-02-farm.png" style="display: block; margin: 0 auto;"></p>
-
-<p>ללולאה יהיו בדרך כלל<strong> אחד או יותר </strong>(לא בהכרח את כולם) מהמאפיינים הבאים:</p>
-
-<ul>
- <li>מונה - (<strong>counter</strong>)<strong> </strong>-<strong> </strong> אשר <strong>מאותחל לערך התחלתי</strong> מסויים - זו בעצם נקודת ההתחלה של הלולאה. ("Start: I have no food", למעלה).</li>
- <li>תנאי יציאה - (<strong>condition</strong>) -<strong> </strong> התנאי להפסקת ריצת הלולאה - בדרך כלל, כאשר המונה מגיע לערך מסויים. כאשר תנאי זה מקבל ערך <font face="consolas, Liberation Mono, courier, monospace"><span style="background-color: rgba(220, 220, 220, 0.498039);">false</span></font>, הלולאה תפסיק לרוץ ויורץ הקוד שאחרי הלולאה.</li>
- <li>ביטוי לקידום הלולאה (<strong>iterator</strong>)<strong> </strong>-<strong> </strong> אשר באופן כללי, מעלה את המונה של הלולאה לאחר כל ריצה מוצלחת של הקוד שבתוך הלולאה, עד אשר תנאי היציאה יתקיים (כלומר יחזיר ערך של טרו). יש מפתחים שקוראים לו המונה.</li>
-</ul>
-
-<h3 id="למה_צריך_לולאות">למה צריך לולאות?</h3>
-
-<p>בשלב זה כנראה הבנו את הרעיון העומד מאחורי לולאות. כעת ננסה להבין כיצד זה עוזר לנו לבצע פעולות מסויימות שוב ושוב. </p>
-
-<p>בדרך כלל, הקוד שלנו יהיה מעט שונה בכל ריצה של הלולאה (כלומר - בכל איטראציה מוצלחת של הלולאה). דבר זה מאפשר לנו להשלים את ביצוען של כמות רבה של משימות דומות, אך שונות מעט. כך לדוגמא, אם יש לנו כמות רבה של חישובים שונים אשר נרצה לבצע קצת אחרת בכל ריצה/איטראציה.</p>
-
-<p>נסתכל על דוגמא נוספת על מנת להסביר את הנושא. נניח שאנחנו רוצים לצייר 100 עיגולים אקראיים על אלמנט מסוג {{htmlelement("canvas")}}, ובאמצעות לחיצה על כפתור <em>Update</em> אנחנו נרצה לקבל סט חדש ואחר של 100 עיגולים אקראיים:</p>
-
-<div class="hidden">
-<h6 id="Hidden_code">Hidden code</h6>
-
-<pre class="brush: html">&lt;!DOCTYPE html&gt;
-&lt;html&gt;
- &lt;head&gt;
- &lt;meta charset="utf-8"&gt;
- &lt;title&gt;Random canvas circles&lt;/title&gt;
- &lt;style&gt;
- html {
- width: 100%;
- height: inherit;
- background: #ddd;
- }
-
- canvas {
- display: block;
- }
-
- body {
- margin: 0;
- }
-
- button {
- position: absolute;
- top: 5px;
- left: 5px;
- }
- &lt;/style&gt;
- &lt;/head&gt;
- &lt;body&gt;
-
- &lt;button&gt;Update&lt;/button&gt;
-
- &lt;canvas&gt;&lt;/canvas&gt;
-
-
- &lt;script&gt;
- const btn = document.querySelector('button');
- const canvas = document.querySelector('canvas');
- const ctx = canvas.getContext('2d');
-
- let WIDTH = document.documentElement.clientWidth;
- let HEIGHT = document.documentElement.clientHeight;
-
- canvas.width = WIDTH;
- canvas.height = HEIGHT;
-
- function random(number) {
- return Math.floor(Math.random()*number);
- }
-
- function draw() {
- ctx.clearRect(0,0,WIDTH,HEIGHT);
- for (let i = 0; i &lt; 100; i++) {
- ctx.beginPath();
- ctx.fillStyle = 'rgba(255,0,0,0.5)';
- ctx.arc(random(WIDTH), random(HEIGHT), random(50), 0, 2 * Math.PI);
- ctx.fill();
- }
- }
-
- btn.addEventListener('click',draw);
-
- &lt;/script&gt;
-
- &lt;/body&gt;
-&lt;/html&gt;</pre>
-</div>
-
-<p>{{ EmbedLiveSample('Hidden_code', '100%', 400, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<p>אתם לא צריכים להבין את כל הקוד הרשום למעלה, אבל הסתכלו לעומק על החלק שמצייר בפועל 100 כדורים:</p>
-
-<pre class="brush: js">for (let i = 0; i &lt; 100; i++) {
- ctx.beginPath();
- ctx.fillStyle = 'rgba(255,0,0,0.5)';
- ctx.arc(random(WIDTH), random(HEIGHT), random(50), 0, 2 * Math.PI);
- ctx.fill();
-}</pre>
-
-<ul>
- <li>הפונקציה <code>()random</code>, אשר הוגדרה מוקדם יותר בקוד, מחזירה לנו מספר שלם בין <code>0</code> ו- <code>x-1</code>.</li>
- <li><code>WIDTH</code> ו- <code>HEIGHT</code> אלו הרוחב והגובה של החלק הפנימי של הדפדפן.</li>
-</ul>
-
-<p>אתם מבינים את הרעיון - אנחנו משתמשים בלולאה על מנת לרוץ 100 איטראציות של הקוד הזה, כאשר בכל ריצה כזו נקבל עיגול במיקום אקראי אחר. אם נרצה יותר מ-100 עיגולים פשוט נשנה מספר אחד!.</p>
-
-<p>אם לא היינו משתמשים בלולאה, היינו צריכים לרשום את הקוד הבא שוב ושוב בהתאם לכמות הפעמים שהיינו רוצים שיצוייר עיגול:</p>
-
-<pre class="brush: js">ctx.beginPath();
-ctx.fillStyle = 'rgba(255,0,0,0.5)';
-ctx.arc(random(WIDTH), random(HEIGHT), random(50), 0, 2 * Math.PI);
-ctx.fill();</pre>
-
-<h2 id="לולאת_for">לולאת for</h2>
-
-<p>נחקור כיצד לולאות מסויימות בנויות. סוגי הלולאות השונים מאפשרים לנו דרכים שונות על מנת לקבוע את נקודת ההתחלה והעצירה של הלולאה.</p>
-
-<p>הראשונה, שאנחנו נשתמש בה הרבה מאוד פעמים, היא <strong>לולאה מסוג <a href="/en-US/docs/Web/JavaScript/Reference/Statements/for">for</a></strong>. לולאה זו היא בעלת הסינטקס הבא:</p>
-
-<pre>for (initializer; exit-condition; final-expression) {
- // code to run
-}</pre>
-
-<p>הסבר:</p>
-
-<ol>
- <li>המילה השמורה <code>for</code>, ולאחריה סוגריים רגילות <code>()</code>.</li>
- <li>בתוך הסוגריים הרגילות <code>()</code> יש לנו 3 ביטויים, מופרדים על ידי <code>;</code>:
- <ol>
- <li><strong>initializer  - מונה-מאתחל</strong> — פה אנו נראה בדרך כלל הצהרה על משתנה, בדרך כלל משתנה <code>let</code> אשר אנחנו נותנים לו ערך (מספר) התחלתי לפני שהלולאה רצה. הוא ישמש את הלולאה כמונה של מספר הריצה הרלוונטית. </li>
- <li><strong>exit-condition - תנאי יציאה</strong> — זהו התנאי שנבדק בטרם כל איטרציה. אם תוצאת המבחן היא <code>true</code>, הלולאה תמשיך לרוץ והביטוי שבתוך הסוגריים המסולסלות יבוצע. אם תוצאת המבחן היא <code>false</code> הלולאה תפסיק לרוץ. תנאי היציאה הוא בדרך כלל ביטוי הכולל אופטורים להשוואה - מבחנים לבדיקה האם התקיים תנאי מסויים.</li>
- <li><strong>final-expression - iterator - ביטוי לקידום הלולאה </strong>— ביטוי זה יבוצע או ירוץ בכל פעם שהלולאה ביצעה ריצה/איטראציה במלואה. ביטוי זה משמש בדרך כלל להעלות (או להוריד) את המונה-מאתחל על מנת לקרב אותו לקיום תנאי היציאה.</li>
- <li>שימו לב כי כל הביטויים האלו הם אופציונליים - אך לא ניכנס לאפשרויות השונות לעומק. אתם מוזמנים להרחיב בנושא בדף <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/statements/for">בנושא לולאת for</a>. </li>
- </ol>
- </li>
- <li>לאחר מכן יש לנו סוגריים מסולסלות <code>{...}</code> שכוללות בתוכן קוד אשר ירוץ בכל פעם שהלולאה מבצעת איטרציה.</li>
-</ol>
-
-<p>נסתכל על הדוגמא הבאה:</p>
-
-<pre class="brush: js">const cats = ['Bill', 'Jeff', 'Pete', 'Biggles', 'Jasmin'];
-let info = 'My cats are called ';
-const para = document.querySelector('p');
-
-for (let i = 0; i &lt; cats.length; i++) {
- info += cats[i] + ', ';
-}
-
-para.textContent = info;</pre>
-
-<p>הקוד למעלה יציג לנו את הפלט הבא:</p>
-
-<div class="hidden">
-<h6 id="Hidden_code_2">Hidden code 2</h6>
-
-<pre class="brush: html">&lt;!DOCTYPE html&gt;
-&lt;html&gt;
- &lt;head&gt;
- &lt;meta charset="utf-8"&gt;
- &lt;title&gt;Basic for loop example&lt;/title&gt;
- &lt;style&gt;
-
- &lt;/style&gt;
- &lt;/head&gt;
- &lt;body&gt;
-
- &lt;p&gt;&lt;/p&gt;
-
-
- &lt;script&gt;
- const cats = ['Bill', 'Jeff', 'Pete', 'Biggles', 'Jasmin'];
- let info = 'My cats are called ';
- const para = document.querySelector('p');
-
- for (let i = 0; i &lt; cats.length; i++) {
- info += cats[i] + ', ';
- }
-
- para.textContent = info;
-
- &lt;/script&gt;
-
- &lt;/body&gt;
-&lt;/html&gt;</pre>
-</div>
-
-<p>{{ EmbedLiveSample('Hidden_code_2', '100%', 60, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<div class="note">
-<p><strong>תשומת לב</strong>: ניתן למצוא את <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/loops/basic-for.html">הקוד ב- GitHub</a> או לראות אותו <a href="http://mdn.github.io/learning-area/javascript/building-blocks/loops/basic-for.html">פה</a>.</p>
-</div>
-
-<p>קוד זה מראה לולאת <code>for</code> שמבצעת איטרציה על הפריטים במערך ועושה משהו עם כל אחד מהם - זוהי תבנית שנראה שוב ושוב ב-JavaScript. בדוגמא זו למשל:</p>
-
-<ol>
- <li><u><strong>המונה:</strong></u> לפעמים גם נקרא כמאתחל, הינו משתנה <code>i</code>, והוא מתחיל ב-<code>0</code>.   (<code>let i = 0</code>).</li>
- <li><u><strong>בדיקת תנאי יציאה/עצירת הלולאה:</strong></u> הלולאה תרוץ כל עוד <code>i</code> קטן יותר ממספר האיברים שנמצאים במערך <code>cats</code>. (מציאת כמות האיברים שנמצאת במערך זה מתבצעת באמצעות <code>cats.length</code>. תנאי היציאה הוא חשוב ביצירת לולאה - הוא קובע מהו <strong>התנאי אשר רק כאשר תוצאות תהיה </strong><code>true</code><strong>, הלולאה תמשיך ותבצע איטרציה נוספת</strong>. במקרה הזה, כל עוד <code>i &lt; cats.length</code> עדיין נכון, הלולאה תמשיך לרוץ.</li>
- <li><u><strong>הרצת הקוד שבתוך הסוגריים המסולסלות:</strong></u> בתוך הלולאה, אנחנו מחברים בין הפריט הנוכחי שהלולאה מבצעת עליו איטרציה [הערך של <code>i</code> באותה ריצה] <code>cats</code>,  ביחד עם פסיק ורווח בסוף המשתנה <code>info</code>:
- <ol>
- <li>במהלך הריצה הראשונה - האיטרציה הראשונה, , <code>i = 0</code>, ולכן <code>cats[0] + ', '</code> (שהוא שווה ל-<code>Bill, </code>) יצורף לתוך <code>info</code>.</li>
- <li>במהלך הריצה השנייה - האיטרציה השנייה , <code>i = 1</code>, ולכן <code>cats[1] + ', '</code> (אשר שווה ל- <code>Jeff, </code>) יצורך גם הוא לתוך <code>info</code>.</li>
- </ol>
- </li>
- <li><u><strong>קירוב המונה לתנאי היציאה: </strong></u>אחרי כל ריצה של הלולאה, נוסיף 1 ל-<code>i</code> באמצעות <code>++i</code>. <strong>שימו לב</strong> - רק אחרי שהקוד שבתוך הסוגריים המסולסלות מבוצע, מתבצעת הוספה של 1 למשתנה i וכך הלאה.</li>
- <li><u><strong>ביצוע בדיקה חוזרת לתנאי העצירה ועמידה בו:</strong></u>  לאחר קירוב המונה לתנאי העצירה, תבוצע בדיקה חוזרת האם התנאי מתקיים -  <strong>כאשר תוצאת התנאי תהיה שוב </strong><code>true</code><strong>, הלולאה תמשיך ותבצע איטרציה נוספת</strong>.</li>
- <li>רק כאשר <code>i</code> יהיה שווה ל- <code>cats.length</code> (במקרה זה, 5), הלולאה תפסיק שכן הערך המתקבל בתוצאה הוא <code>false</code> והדפדפן יעבור לקוד שמתחת לולאה. </li>
-</ol>
-
-<div class="note">
-<p><strong>לתשומת לבכם</strong>: רשמנו את תנאי היציאה כ- <code>i &lt; cats.length</code>, ולא <code>i &lt;= cats.length</code>, מכיוון שמחשבים מתחילים לספור מ-0 ולא מ-1 — אנחנו מתחילים כאשר <code>i</code> שווה ל<code>0</code>, וממשיכים עד אשר <code>i = 4</code> (האינדקס של האיבר האחרון במערך).</p>
-
-<p> <code>cats.length</code> יחזיר 5, ומכיוון שאכן ישנם 5 פריטים, אבל הפריט החמישי של <code>cats.length</code>, נמצא באינדקס מס׳ 4. ולכן אנחנו לא רוצים את <code>cats.length</code> אלא את <code>cats.length</code> פחות אחד. אם נשים רק את <code>cats.length,</code> כאשר   <code>i = 5</code>  המבחן יחזיר לנו ערך של  <code>undefined</code> בעבור הפריט האחרון - שכן אין איבר באינדקס 5. ולכן, אנחנו נרצה להריץ את הלולאה מספר 1 פחות.</p>
-</div>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: טעות נפוצה עם תנאי יציאה היא להשתמש עם (<em>״שווה ל-״</em>)  (<code>===</code>)  במקום עם (<em>״קטן מ- או שווה ל-״</em>) (<code>&lt;=</code>) .</p>
-
-<p>אם אנחנו נרצה להריץ את הלולאה שלנו עד אשר <code>i = 5</code>, תנאי היציאה יצטרך להיות <code>i &lt;= cats.length</code>.אם נקבע אותו כ <code>i === cats.length</code>  אזי הלולאה לא תרוץ בכלל מכיוון ש-<code>i</code> לא שווה ל-<code>5</code> באיטרציה הראשונה של הלולאה, ולכן הלולאה תעצור במיידי.</p>
-</div>
-
-<p>בעיה אחת קטנה שנותרה לנו היא שהמשפט בסופה של הלולאה לא מסודר כראוי במלואו שכן בריצה האחרונה גם הוספנו פסיק ולכן יש לנו פסיק בסוף המשפט.</p>
-
-<blockquote>
-<p>My cats are called Bill, Jeff, Pete, Biggles, Jasmin,</p>
-</blockquote>
-
-<p>באופן הגיוני, אנחנו נרצה לשנות את צורת חיבור המחרוזת כך שבאיטרציה האחרונה של הלולאה, לא נקבל פסיק בסוף המשפט. לשם כך אנחנו יכולים להכניס משפט <code>if</code> בתוך לולאת <code>for</code> שלנו על מנת לטפל במקרה זה:</p>
-
-<pre class="brush: js">for (let i = 0; i &lt; cats.length; i++) {
- if (i === cats.length - 1) {
- info += 'and ' + cats[i] + '.';
- } else {
- info += cats[i] + ', ';
- }
-}</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: ניתן למצוא את <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/loops/basic-for-improved.html">קוד הדוגמא הזו ב- GitHub</a> או כ- <a href="http://mdn.github.io/learning-area/javascript/building-blocks/loops/basic-for-improved.html">דף אינטרנט</a>).</p>
-</div>
-
-<div class="warning">
-<p><strong>זהירות</strong>: בלולאת for — כמו ביתר הלולאות, אנחנו צריכים לוודא שהמונה שלנו עולה או יורד, בהתאם למקרה הרלוונטי, כך שבשלב מסויים הוא יגיע לתנאי היציאה. אם לא - הלולאה תמשיך בלי סוף, ותגרום לכך שהדפדפן יעצור אותה או יקרוס. דבר כזה נקרא <strong>לולאה אינסופית</strong>.</p>
-</div>
-
-<h2 id="יציאה_מלולאות_באמצעות_break">יציאה מלולאות באמצעות break</h2>
-
-<p>אם אנחנו רוצים לצאת מלולאה לפני שכל האיטרציות הושלמו, אנחנו יכולים להשתמש בביטוי <a href="/en-US/docs/Web/JavaScript/Reference/Statements/break">break</a>. ראינו אותו בעבר כשלמדנו על משפטי תנאי מסוג <a href="/en-US/Learn/JavaScript/Building_blocks/conditionals#switch_statements">switch</a> (כאשר ביטוי מסויים עונה למקרה מסויים - <code>break</code> עוצר באופן מיידי את המשך הבדיקה וממשיך לקוד שלאחר משפט <code>switch</code>).</p>
-
-<p>בדיוק אותו הדבר כמו עם לולאות - הביטוי <code>break</code> יגרום ליציאה מיידית מהלולאה והדפדפן ימשיך לקוד שנמצא לאחר מכן.</p>
-
-<p>נניח ואנחנו רוצים לחפש בתוך מערך של אנשי קשר וטלפונים, ואז להחזיר רק את המספר שאנחנו רוצים למצוא? נתחיל ב-HTML פשוט - תיבת טקסט
- {{htmlelement("input")}}, המאפשרת לנו להכניס את השם שנרצה לחפש ואלמנט מסוג כפתור {{htmlelement("button")}} על מנת לשלוח את החיפוש וכן אלמנט של פסקה  {{htmlelement("p")}} על מנת להציג בו את התוצאות.</p>
-
-<pre class="brush: html">&lt;label for="search"&gt;Search by contact name: &lt;/label&gt;
-&lt;input id="search" type="text"&gt;
-&lt;button&gt;Search&lt;/button&gt;
-
-&lt;p&gt;&lt;/p&gt;</pre>
-
-<p>כעת נכניס - JavaScript:</p>
-
-<pre class="brush: js">const contacts = ['Chris:2232322', 'Sarah:3453456', 'Bill:7654322', 'Mary:9998769', 'Dianne:9384975'];
-const para = document.querySelector('p');
-const input = document.querySelector('input');
-const btn = document.querySelector('button');
-
-btn.addEventListener('click', function() {
- let searchName = input.value.toLowerCase();
- input.value = '';
- input.focus();
- for (let i = 0; i &lt; contacts.length; i++) {
- let splitContact = contacts[i].split(':');
- if (splitContact[0].toLowerCase() === searchName) {
- para.textContent = splitContact[0] + '\'s number is ' + splitContact[1] + '.';
- break;
- } else {
- para.textContent = 'Contact not found.';
- }
- }
-});</pre>
-
-<div class="hidden">
-<h6 id="Hidden_code_3">Hidden code 3</h6>
-
-<pre class="brush: html">&lt;!DOCTYPE html&gt;
-&lt;html&gt;
- &lt;head&gt;
- &lt;meta charset="utf-8"&gt;
- &lt;title&gt;Simple contact search example&lt;/title&gt;
- &lt;style&gt;
-
- &lt;/style&gt;
- &lt;/head&gt;
- &lt;body&gt;
-
- &lt;label for="search"&gt;Search by contact name: &lt;/label&gt;
- &lt;input id="search" type="text"&gt;
- &lt;button&gt;Search&lt;/button&gt;
-
- &lt;p&gt;&lt;/p&gt;
-
-
- &lt;script&gt;
- const contacts = ['Chris:2232322', 'Sarah:3453456', 'Bill:7654322', 'Mary:9998769', 'Dianne:9384975'];
- const para = document.querySelector('p');
- const input = document.querySelector('input');
- const btn = document.querySelector('button');
-
- btn.addEventListener('click', function() {
- let searchName = input.value.toLowerCase();
- input.value = '';
- input.focus();
- for (let i = 0; i &lt; contacts.length; i++) {
- let splitContact = contacts[i].split(':');
- if (splitContact[0].toLowerCase() === searchName) {
- para.textContent = splitContact[0] + '\'s number is ' + splitContact[1] + '.';
- break;
- } else if (i === contacts.length-1)
-  para.textContent = 'Contact not found.';
-  }
- });
- &lt;/script&gt;
-
- &lt;/body&gt;
-&lt;/html&gt;</pre>
-</div>
-
-<p>{{ EmbedLiveSample('Hidden_code_3', '100%', 100, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<ol>
- <li>ראשית - הגדרנו קבועים - יש לנו מערך עם פרטי קשר - כאשר כל איבר במערך הוא מחרוזת המכילה שם ומספר טלפון המופרדים על ידי <code>:</code>. הגדרנו קבוע בשם <code>para</code> שמקבל הפנייה לאלמנט <code>&lt;p&gt;</code>. הגדרנו קבוע בשם <code>input</code> שמקבל הפניה לאלמנט <font face="consolas, Liberation Mono, courier, monospace"><span style="background-color: rgba(220, 220, 220, 0.498039);">&lt;input&gt;</span></font> וקבוע בשם <code>btn</code> שמקבל הפניה ל-<code>&lt;button&gt;</code>. </li>
- <li>לאחר מכן חיברנו ״מאזין אירוע״ לכפתור - (<code>btn</code>), כך שבכל פעם שהוא יילחץ ירוץ קוד מסויים לביצוע החיפוש ויחזיר את התוצאה (event handler). במקרה הזה, זו הפונקציה האנונימית שנמצאת מיד לאחר הביטוי 'click'.</li>
- <li>אחסנו את הערך שהוכנס לתוך תיבת הטקסט (<code>input)</code>  בתוך משתנה שנקרא <code>searchName</code>, לאחר מכן ריקנו את תיבת הטקסט מתוכן, ועשינו עליה פוקוס באמצעות מתודת <code>()focus</code> , על מנת שתהיה מוכנה לחיפוש הבא. שימו לב שאנחנו גם הרצנו את מתודת <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/toLowerCase">()toLowerCase</a></code> על הערך שהתקבל ב-<code>input</code> כדי לנרמל את המחרוזת. </li>
- <li>ועכשיו לחלק המעניין של לולאת ה-<code>for</code>:
- <ol>
- <li>אנחנו מתחילים את המונה ב-<code>0</code>, מתבצעת בדיקת עמידה בתנאי, ככל והערך המוחזר הוא <code>true</code>, מתבצעת איטרציה - הרצה של הקוד שבתוך הסוגריים המסולסלות של הלולאה:
- <ol>
- <li>בתוך הלולאה אנחנו תחילה מחלצים כל חלק מהמחרוזת הראשית באמצעות מתודה שאנחנו מכירים <code>()split</code>, אשר מקבלת את התו <code>:</code> כתו שיחצה את המחרוזת <code>contacts</code> בכל פעם שהמתודה תמצא את התו הזה. להזכירכם מתודה זו מחזירה מערך של מחרוזות שהופרדו על ידי התו שהיא קיבלה. במקרה הזה אנחנו מאחסנים במשתנה בשם <code>splitContact</code> את המערך החדש שהוחזר לנו בכל איטרציה שזה בעצם מערך עם שני איברים: שם ומספר. </li>
- <li>לאחר מכן אנחנו משתמשים במשפט תנאי לבדוק האם <code>[splitContact[0</code> שזה בעצם שם האדם מנורמל באמצעות<code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/toLowerCase">()toLowerCase</a></code>, שווה לטקסט שנמצא ב-<code>searchName</code>. אם כן, אנחנו נכניס מחרוזת לתוך הפסקה עם הטלפון שלו שזה בעצם <code>[splitContact[1</code>, ונשתמש ב-<code>break</code> על מנת לעצור את הלולאה. </li>
- </ol>
- </li>
- <li>לאחר מכן מתבצעת הגדלת של ה-<code>i</code> ב-<code>1</code> בכל איטרציה מוצלחת של הלולאה באמצעות <code>++i</code>.</li>
- </ol>
- </li>
- <li>אחרי כל האיטרציות, כאשר i יהיה שווה לאיבר האחרון במערך של המחרוזת הראשית - כלומר אחרי <code>(contacts.length-1)</code> אם <code>searchName</code> לא זהה לאף  <code>[splitContact[i</code>, אז טקטסט של הפסקה הופך ל- "Contact not found."  </li>
-</ol>
-
-<div class="note">
-<p>לתשומת לב: ניתן למצוא את <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/loops/contact-search.html">קוד המקור - GitHub code on GitHub</a> או כדף <a href="http://mdn.github.io/learning-area/javascript/building-blocks/loops/contact-search.html">אינטרנט</a>.</p>
-</div>
-
-<h2 id="דילוג_על_איטרציה_עם_continue">דילוג על איטרציה עם continue</h2>
-
-<p>ביטוי ה-<a href="/en-US/docs/Web/JavaScript/Reference/Statements/continue">continue</a> עובד בדרך דומה לביטוי <code>break</code>, רק שבמקום לעצור את הלולאה ולצאת ממנה, הוא פשוט ממשיך לאיטרציה הבאה של הלולאה. נעבור כעת על דוגמא נוספת שבה אנחנו נזין מספר מקבל מספר כערך, ומחזיקה רק המספרים שהם מספרים שלמים.</p>
-
-<p>ה-HTML  בעיקרון דומה לדוגמא הקודמת - יש לנו תיבת טקסט פשוטה ופסקה להציג את הפלט. ה-JavaScript גם דומה, למרות שהלולאה שלנו קצת אחרת:</p>
-
-<pre class="brush: js">let num = input.value;
-
-for (let i = 1; i &lt;= num; i++) {
- let sqRoot = Math.sqrt(i);
- if (Math.floor(sqRoot) !== sqRoot) {
- continue;
- }
-
- para.textContent += i + ' ';
-}</pre>
-
-<p>זה הפלט שלנו:</p>
-
-<div class="hidden">
-<h6 id="Hidden_code_4">Hidden code 4</h6>
-
-<pre class="brush: html">&lt;!DOCTYPE html&gt;
-&lt;html&gt;
- &lt;head&gt;
- &lt;meta charset="utf-8"&gt;
- &lt;title&gt;Integer squares generator&lt;/title&gt;
- &lt;style&gt;
-
- &lt;/style&gt;
- &lt;/head&gt;
- &lt;body&gt;
-
- &lt;label for="number"&gt;Enter number: &lt;/label&gt;
- &lt;input id="number" type="text"&gt;
- &lt;button&gt;Generate integer squares&lt;/button&gt;
-
- &lt;p&gt;Output: &lt;/p&gt;
-
-
- &lt;script&gt;
- const para = document.querySelector('p');
- const input = document.querySelector('input');
- const btn = document.querySelector('button');
-
- btn.addEventListener('click', function() {
- para.textContent = 'Output: ';
- let num = input.value;
- input.value = '';
- input.focus();
- for (let i = 1; i &lt;= num; i++) {
- let sqRoot = Math.sqrt(i);
- if (Math.floor(sqRoot) !== sqRoot) {
- continue;
- }
-
- para.textContent += i + ' ';
- }
- });
- &lt;/script&gt;
-
- &lt;/body&gt;
-&lt;/html&gt;</pre>
-</div>
-
-<p>{{ EmbedLiveSample('Hidden_code_4', '100%', 100, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<ol>
- <li>במקרה הזה, הקלט צריך להיות מספר - <code>num</code>. אנו נותנים ללולאת ה-<code>for</code> מונה שמתחיל ב-<code>1</code> (אנחנו לא מעוניינים ב- <code>0</code> במקרה הנוכחי), תנאי יציאה שאומר שהלולאה תפסיק כאשר המונה יהיה גדול מהמספר שהכנסנו - מ-<code>num</code>, ואז ביטוי העלאה שמוסיף למונה <code>1</code> בכל איטרציה. </li>
- <li>בתוך הלולאה, אנחנו מוצאים את השורש הריבועי של כל מספר (של כל <code>num</code>) באמצעות שימוש במתודה <a href="/he/docs/">(</a>)<a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/sqrt">Math.sqrt</a>, ואז בודקים האם השורש הריבועי הוא שלם על ידי בדיקה האם הוא זהה לעצמו כשהוא מעוגל כלפי מטה לשלם הקרוב - זה מה שמתודת <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/floor">()Math.floor</a> עושה למספר שמועבר אליה - היא מחזירה את המספר השלם הגדול ביותר אשר נמוך מהמספר שהבאנו לה או השווה לו.</li>
- <li>אם השורש הריבועי והמספר שעוגל כלפי מטה אינהם זהים אחד לשני - (<code>!==</code>), המשמעות היא שהשורש הריבועי הוא לא מספר שלם, ולכן אנחנו לא מעוניינים בו. במקרה כזה, אנחנו נשתמש בביטוי <code>continue</code> על מנת לעבור לאיטרציה הבאה, אבל מבלי להמשיך להריץ את קוד אשר נמצא בהמשך האיטרציה הנוכחית (וביתר האיטרציות) ומבלי לצאת מהלולאה.</li>
- <li>אם השורש הריבוע הוא מספר שלם, אנחנו לא עומדים בתנאי שרשום במשפט ה-<code>if</code> ולכן המשפט <code>continue</code> לא מורץ. במקום, אנחנו מצרפים את הערך שבתוך <code>i</code> בצירוף רווח, לסוף של הטקסט שבתוך הפסקה. </li>
-</ol>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: ניתן לראות את  <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/loops/integer-squares.html">קוד המקור ב-GitHub</a> או לראות את הדף <a href="http://mdn.github.io/learning-area/javascript/building-blocks/loops/integer-squares.html">אינטרנט</a>.</p>
-</div>
-
-<h2 id="while_ו-do_..._while">while ו-do ... while</h2>
-
-<p>לולאות <code>for</code> הן לא הלולאות היחידות שיש לנו ב-JavaScript. האמת שיש עוד הרבה אחרות. אנחנו ללא צריכים לדעת את כולן כעת, אבל שווה יהיה להעיף מבט בכמה ונבין שאפשרויות שונות עובדים בצורה שונה.</p>
-
-<p>לולאת <a href="/en-US/docs/Web/JavaScript/Reference/Statements/while">while</a> מורכבת מהסינטקס הבא:</p>
-
-<pre>initializer
-while (exit-condition) {
- // code to run
-
- final-expression
-}</pre>
-
-<p>לולאה זו עובדת בצורה דומה ללולאת <code>for</code>, למעט העובדה שהערך המאתחל נקבע לפני הלולאה, והביטוי שיביא למימוש תנאי היציאה יהיה כלול בתוך הסוגריים המסולסלות <code>{}</code>. תנאי היציאה נכלל בתוך המרכאות העגולים, כאשר לפני המרכאות יש את המילה השמורה <code>while</code> ולא <code>for</code>.</p>
-
-<p>משפטי while ממשיכים לפעול עד שהתנאי המופיע בראש המשפט אינו נכון עוד. שימו לב שניתן להכניס בלולאה זו את את כל שלושת הביטויים המוכרים לנו מלולאת <code>for</code> - ערך מאתחל (לא חובה), תנאי יציאה וביטוי  סופי שיבוצע בסוף האיטרציה (לא חובה). כלומר, הערך היחיד שחובה לכלול בלולאת while הוא התנאי ליציאה - אך יחד עם זאת, ראו הערה חשובה בסוף פסקה זו בדבר סיום ריצת הלולאה. </p>
-
-<p>בוא נסתכל שוב על רשימת החתולים, אבל נכתוב אותה באמצעות לולאת while:</p>
-
-<pre class="brush: js">let i = 0;
-
-while (i &lt; cats.length) {
- if (i === cats.length - 1) {
- info += 'and ' + cats[i] + '.';
- } else {
- info += cats[i] + ', ';
- }
-
- i++;
-}</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: זה עובד כמו שציפינו — ראו את <a href="http://mdn.github.io/learning-area/javascript/building-blocks/loops/while.html"> הדף עובד ב-GitHub</a> או את <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/loops/while.html">קוד המקור</a>).</p>
-</div>
-
-<p>לולאת <a href="/en-US/docs/Web/JavaScript/Reference/Statements/do...while">do...while</a> דומה מאוד ללולאת while אבל שונה מעט:</p>
-
-<pre>initializer
-do {
- // code to run
-
- final-expression
-} while (exit-condition)</pre>
-
-<p>במקרה הזה, המאתחל מגיע שוב ראשון, לפני שהלולאה מתחילה. המילה שמורה <code>do</code> ולאחר מכן סוגריים מסולסלות <code>{}</code> שבותכן ייכנס הקוד שנרה שירוץ בלולאה. ולסוף , המילה השמורה <code>while</code> ולאחרי קוד היציאה.</p>
-
-<p>השוני כאן זה שתנאי היציאה מגיע בסוף, עטוף בתוך סוגריים רגילות <code>()</code>. בלולאת <code>do...while</code>, הקוד בתוך הסוגריים המסולסלות <code>{...}</code> תמיד ירוץ <u><strong>פעם אחת לפחות</strong></u> <u><strong>לפני</strong></u> בדיקת התנאי ואז יבדוק את התנאי על מנת לבדוק האם לרוץ שוב. להזכירכם - בלולאות <code>while</code> ובלולאות <code>for</code>, בדיקת התקיימות התנאי מתבצעת לפני הרצת הקוד שבתוך <code>{...}</code>  כך שיכול להיות שהקוד בלולאות אלו לא יבוצע לעולם. בלולאת <code>do...while</code> לעומת זאת, הקוד תמיד ירוץ פעם אחת לפחות.</p>
-
-<p>בוא נכתוב את הדוגמא שלנו באמצעות הלולאה <code>do...while</code>:</p>
-
-<pre class="brush: js">let i = 0;
-
-do {
- if (i === cats.length - 1) {
- info += 'and ' + cats[i] + '.';
- } else {
- info += cats[i] + ', ';
- }
-
- i++;
-} while (i &lt; cats.length);</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: הלולאה עובדת בדיוק כפי שרצינו - ראו <a href="http://mdn.github.io/learning-area/javascript/building-blocks/loops/do-while.html">ב- GitHub</a> וכן את <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/loops/do-while.html">קוד המקור</a>.</p>
-</div>
-
-<div class="warning">
-<p><strong>זהירות</strong>: בלולאות <code>while</code>  וב-<code>do...while</code> - אנחנו חייבם לוודא שהמאתחל מועלה או, בהתאם למקרה, יורד, כך שבסופו של דבר הקוד יגיע לתנאי היציאה והלולאה תסתיים. אחרת, הלולאה תמשיך עד אינסוף. במקרה כזה הדפדפן יכריח אותה להפסיק או שהוא יקרוס. זה נקרא <strong>לולאה אינסופית</strong>.</p>
-</div>
-
-<h2 id="למידה_עצמאית_בניית_שעון_ספירה_לאחור">למידה עצמאית: בניית שעון ספירה לאחור</h2>
-
-<p>בתרגיל זה, אנחנו נרצה שתבנה תוכנית שתדפיס שעון עצר מ-10 ל-0 וכן:</p>
-
-<ul>
- <li>תבנה לולאה שתרוץ מ-10 עד 0. סיפקנו לכם מאתחל - <code>let i = 10;</code></li>
- <li>בעבור כל איטרציה, צרו פסקה חדשה והוסיפו אותה ל-<code>output div</code>', המיוצגת על ידי <code>const output = document.querySelector('.output');</code></li>
- <li>בהערות סיפקנו לכם 2 שורות קוד שתצטרכו להתמש בהם איפשהו בלולאה:
- <ul>
- <li><code>const para = document.createElement('p');</code> — יוצרת פסקה חדשה.</li>
- <li><code>output.appendChild(para);</code> — מוסיפה את הפסקה החדש ל <code>&lt;div&gt;</code> של האאוטפוט.</li>
- <li><code>para.textContent =</code> — הופכת את הטקסט שבתוך הפסקה למה שנשים מצד ימין לסימן ה-<code>=</code>.</li>
- </ul>
- </li>
- <li>בכל מספר ריצה דרוש טקסט אחר שיהיה מוצג לאותה ריצה - אתם תצטרכו משפט תנאי ומניפולציה ל- <code>para.textContent:</code>
- <ul>
- <li>אם המספר הוא 10, הדפיסו ״Countdown 10״ לתוך הפסקה.</li>
- <li>אם המספר הוא 0, הדפיסו "Blast off!" לתוך הפסקה.</li>
- <li>בכל יתר המספרים, פשוט הדפיסו את המספר לתוך הפסקה.</li>
- </ul>
- </li>
- <li>זכרו לכלול ביטוי לקידום הלולאה. שימו לב שבדוגמא הזו אנחנו סופרים למטה לאחר כל ריצה ולא למעלה, אז אנחנו לא יכולים להשתמש ב-<code>++i</code>. </li>
-</ul>
-
-
-<p>אם עשיתם טעות אתם תמיד יכולים לאתחל את הקוד באמצעות הכפתור "Reset" ואם ממש נתקתעם לחצו על כפתור "Show solution" לפתרון.</p>
-
-<div class="hidden">
-<h6 id="למידה_עצמאית">למידה עצמאית</h6>
-
-<pre class="brush: html">&lt;h2&gt;Live output&lt;/h2&gt;
-&lt;div class="output" style="height: 410px;overflow: auto;"&gt;
-
-&lt;/div&gt;
-
-&lt;h2&gt;Editable code&lt;/h2&gt;
-&lt;p class="a11y-label"&gt;Press Esc to move focus away from the code area (Tab inserts a tab character).&lt;/p&gt;
-&lt;textarea id="code" class="playable-code" style="height: 300px;width: 95%"&gt;
-let output = document.querySelector('.output');
-output.innerHTML = '';
-
-// let i = 10;
-
-// const para = document.createElement('p');
-// para.textContent = ;
-// output.appendChild(para);
-&lt;/textarea&gt;
-
-&lt;div class="playable-buttons"&gt;
- &lt;input id="reset" type="button" value="Reset"&gt;
- &lt;input id="solution" type="button" value="Show solution"&gt;
-&lt;/div&gt;
-</pre>
-
-
-
-<pre class="brush: css">html {
- font-family: sans-serif;
-}
-
-h2 {
- font-size: 16px;
-}
-
-.a11y-label {
- margin: 0;
- text-align: right;
- font-size: 0.7rem;
- width: 98%;
-}
-
-body {
- margin: 10px;
- background: #f5f9fa;
-}</pre>
-
-
-<pre class="brush: js">const textarea = document.getElementById('code');
-const reset = document.getElementById('reset');
-const solution = document.getElementById('solution');
-let code = textarea.value;
-let userEntry = textarea.value;
-
-function updateCode() {
- eval(textarea.value);
-}
-
-reset.addEventListener('click', function() {
- textarea.value = code;
- userEntry = textarea.value;
- solutionEntry = jsSolution;
- solution.value = 'Show solution';
- updateCode();
-});
-
-solution.addEventListener('click', function() {
- if(solution.value === 'Show solution') {
- textarea.value = solutionEntry;
- solution.value = 'Hide solution';
- } else {
- textarea.value = userEntry;
- solution.value = 'Show solution';
- }
- updateCode();
-});
-
-let jsSolution = 'let output = document.querySelector(\'.output\');\noutput.innerHTML = \'\';\n\nlet i = 10;\n\nwhile(i &gt;= 0) {\n let para = document.createElement(\'p\');\n if(i === 10) {\n para.textContent = \'Countdown \' + i;\n } else if(i === 0) {\n para.textContent = \'Blast off!\';\n } else {\n para.textContent = i;\n }\n\n output.appendChild(para);\n\n i--;\n}';
-let solutionEntry = jsSolution;
-
-textarea.addEventListener('input', updateCode);
-window.addEventListener('load', updateCode);
-
-// stop tab key tabbing out of textarea and
-// make it write a tab at the caret position instead
-
-textarea.onkeydown = function(e){
- if (e.keyCode === 9) {
- e.preventDefault();
- insertAtCaret('\t');
- }
-
- if (e.keyCode === 27) {
- textarea.blur();
- }
-};
-
-function insertAtCaret(text) {
- let scrollPos = textarea.scrollTop;
- let caretPos = textarea.selectionStart;
-
- let front = (textarea.value).substring(0, caretPos);
- let back = (textarea.value).substring(textarea.selectionEnd, textarea.value.length);
- textarea.value = front + text + back;
- caretPos = caretPos + text.length;
- textarea.selectionStart = caretPos;
- textarea.selectionEnd = caretPos;
- textarea.focus();
- textarea.scrollTop = scrollPos;
-}
-
-// Update the saved userCode every time the user updates the text area code
-
-textarea.onkeyup = function(){
- // We only want to save the state when the user code is being shown,
- // not the solution, so that solution is not saved over the user code
- if(solution.value === 'Show solution') {
- userEntry = textarea.value;
- } else {
- solutionEntry = textarea.value;
- }
-
- updateCode();
-};</pre>
-
-<p class="brush: js"></p>
-</div>
-
-<p>{{ EmbedLiveSample('Active_learning', '100%', 880, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<h2 id="למידה_עצמאית_-_מילוי_של_רשימת_אורחים">למידה עצמאית - מילוי של רשימת אורחים</h2>
-
-<p>
- בתרגיל זה, אנחנו רוצים שתיקחו רשימה של שמות שמאוחסנים במערך ותכניסו אותם לתוך רשימת אורחים. זה לא כזה קל - אנחנו רוצים רשימת אורחים שמורשים להיכנס ורשימת אורחים שלא מורשים להיכנס.</p>
-
-<p>אתם מתבקשים לבצע את הדברים הבאים:</p>
-
-<ul>
- <li>
- כתבו לולאה שתרוץ מ-0 ועד לאורך של מערך <code>people</code> array. אתם צריכים להתחיל עם ערך מאתחל כמו <code>let i = 0;</code>, אבל מה יהיה תנאי היציאה?
-</li>
- <li>
- בכל איטרציה, אתם צריכים לבדוק האם האיבר הנוכחי של המערך <code>people</code> שווה להאורחים Phil או Lola באמצעות משפט תנאי:
- <ul>
- <li>
- אם כן, צרפו את איבר המערך הרלוונטי ה<code>textContent</code> של פסקת <code>refused</code>, בצירוף פסיק וכן רווח.
-
- </li>
- <li>
- אם לא, צרפו את האיבר הרלוונטי של המערך לסוף הcode&gt;admitted של פסקת code&gt;admitted, בצירוף פסיק וכן רווח.
- </li>
- </ul>
- </li>
-</ul>
-
-<p>לבינתיים סיפקנו לכם:</p>
-
-<ul>
- <li><code>let i = 0;</code> — המאתחל .</li>
- <li><code>refused.textContent +=</code> — זו ההתחלה של השורה שמצרפת ערך לסוף של <code>refused.textContent</code>.</li>
- <li><code>admitted.textContent +=</code> — זו ההתחלה של השורה שמצרפת ערך לסוף של<code>admitted.textContent</code>.</li>
-</ul>
-
-<p>
- שאלת בונוס - אחרי השלמת המשימה, אתם תישארו עם 2 רשימת שמות, מופרדות על ידי פסיקים, אבל לא מסודרות, שכן בסוף כל רשימה יש לנו פסיק.
- מה ניתן לעשות כדי לחתוך את אותו פסיק או לבטל אותו? הסכתלו על
-<a href="/en-US/docs/Learn/JavaScript/First_steps/Useful_string_methods">מתודות מחרוזות שימושיות</a> לעזרה.</p>
-
-<p>אם עשיתם טעות אתם תמיד יכולים לאתחל את הקוד באמצעות הכפתור "Reset" ואם ממש נתקתעם לחצו על כפתור "Show solution" לפתרון</p>
-
-<div class="hidden">
-<h6 id="תרגול_עצמאי_נוסף">תרגול עצמאי נוסף</h6>
-
-<pre class="brush: html">&lt;h2&gt;Live output&lt;/h2&gt;
-&lt;div class="output" style="height: 100px;overflow: auto;"&gt;
- &lt;p class="admitted"&gt;Admit: &lt;/p&gt;
-  &lt;p class="refused"&gt;Refuse: &lt;/p&gt;
-&lt;/div&gt;
-
-&lt;h2&gt;Editable code&lt;/h2&gt;
-&lt;p class="a11y-label"&gt;Press Esc to move focus away from the code area (Tab inserts a tab character).&lt;/p&gt;
-&lt;textarea id="code" class="playable-code" style="height: 400px;width: 95%"&gt;
-const people = ['Chris', 'Anne', 'Colin', 'Terri', 'Phil', 'Lola', 'Sam', 'Kay', 'Bruce'];
-
-const admitted = document.querySelector('.admitted');
-const refused = document.querySelector('.refused');
-admitted.textContent = 'Admit: ';
-refused.textContent = 'Refuse: '
-
-// let i = 0;
-
-// refused.textContent += ;
-// admitted.textContent += ;
-
-&lt;/textarea&gt;
-
-&lt;div class="playable-buttons"&gt;
- &lt;input id="reset" type="button" value="Reset"&gt;
- &lt;input id="solution" type="button" value="Show solution"&gt;
-&lt;/div&gt;
-</pre>
-
-<pre class="brush: css">html {
- font-family: sans-serif;
-}
-
-h2 {
- font-size: 16px;
-}
-
-.a11y-label {
- margin: 0;
- text-align: right;
- font-size: 0.7rem;
- width: 98%;
-}
-
-body {
- margin: 10px;
- background: #f5f9fa;
-}</pre>
-
-<pre class="brush: js">const textarea = document.getElementById('code');
-const reset = document.getElementById('reset');
-const solution = document.getElementById('solution');
-let code = textarea.value;
-let userEntry = textarea.value;
-
-function updateCode() {
- eval(textarea.value);
-}
-
-reset.addEventListener('click', function() {
- textarea.value = code;
- userEntry = textarea.value;
- solutionEntry = jsSolution;
- solution.value = 'Show solution';
- updateCode();
-});
-
-solution.addEventListener('click', function() {
- if(solution.value === 'Show solution') {
- textarea.value = solutionEntry;
- solution.value = 'Hide solution';
- } else {
- textarea.value = userEntry;
- solution.value = 'Show solution';
- }
- updateCode();
-});
-
-let jsSolution = 'const people = [\'Chris\', \'Anne\', \'Colin\', \'Terri\', \'Phil\', \'Lola\', \'Sam\', \'Kay\', \'Bruce\'];\n\nconst admitted = document.querySelector(\'.admitted\');\nconst refused = document.querySelector(\'.refused\');\n\nadmitted.textContent = \'Admit: \';\nrefused.textContent = \'Refuse: \'\nlet i = 0;\n\ndo {\n if(people[i] === \'Phil\' || people[i] === \'Lola\') {\n refused.textContent += people[i] + \', \';\n } else {\n admitted.textContent += people[i] + \', \';\n }\n i++;\n} while(i &lt; people.length);\n\nrefused.textContent = refused.textContent.slice(0,refused.textContent.length-2) + \'.\';\nadmitted.textContent = admitted.textContent.slice(0,admitted.textContent.length-2) + \'.\';';
-let solutionEntry = jsSolution;
-
-textarea.addEventListener('input', updateCode);
-window.addEventListener('load', updateCode);
-
-// stop tab key tabbing out of textarea and
-// make it write a tab at the caret position instead
-
-textarea.onkeydown = function(e){
- if (e.keyCode === 9) {
- e.preventDefault();
- insertAtCaret('\t');
- }
-
- if (e.keyCode === 27) {
- textarea.blur();
- }
-};
-
-function insertAtCaret(text) {
- let scrollPos = textarea.scrollTop;
- let caretPos = textarea.selectionStart;
-
- let front = (textarea.value).substring(0, caretPos);
- let back = (textarea.value).substring(textarea.selectionEnd, textarea.value.length);
- textarea.value = front + text + back;
- caretPos = caretPos + text.length;
- textarea.selectionStart = caretPos;
- textarea.selectionEnd = caretPos;
- textarea.focus();
- textarea.scrollTop = scrollPos;
-}
-
-// Update the saved userCode every time the user updates the text area code
-
-textarea.onkeyup = function(){
- // We only want to save the state when the user code is being shown,
- // not the solution, so that solution is not saved over the user code
- if(solution.value === 'Show solution') {
- userEntry = textarea.value;
- } else {
- solutionEntry = textarea.value;
- }
-
- updateCode();
-};</pre>
-</div>
-
-<p>{{ EmbedLiveSample('Active_learning_2', '100%', 680, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<h2 id="באיזו_לולאה_עלינו_להשתמש">באיזו לולאה עלינו להשתמש??</h2>
-
-<p>
- בדרך כךך, לשימושים בסיסים, הלולאות <code>for</code>, <code>while</code>, ו-<code>do...while</code>, הן חלופיות. כולן לרוב יכולות לפתור את אותן בעיות ואתם תחליטו במה לבחור.</p>
-
-<p>תחילה לולאת <code>for</code>:</p>
-
-<pre>for (initializer; exit-condition; final-expression) {
- // code to run
-}</pre>
-
-<p>לולאת <code>while</code>:</p>
-
-<pre>initializer
-while (exit-condition) {
- // code to run
-
- final-expression
-}</pre>
-
-<p>לולאת <code>do...while</code>:</p>
-
-<pre>initializer
-do {
- // code to run
-
- final-expression
-} while (exit-condition)</pre>
-
-<p>
- אנחנו ממליצים על לולאת _____, לפחות בהתחלה, כיוון שהיא לרוב הקלה ביותר לזכור - המאתחל, תנאי היציאה ומקדם/מחסיר, אשר כולם נכנסים בתוך הסוגריים הרגילות וכך קל לבדוק שלא שכחנו כלום.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>:
- יש סוגי לולאות נוספים ואפשרויות נוספות ללולאות, גם לאלו שסקרנו במאמר זה. אפשרויות ולולאות אלו הן מאוד שימושיות במקרים מתקדמים או פרטניים ולא נגע בהם במאמר זה. אם תרצו להעמיק, ראו את הדף בנושא
- <a href="/en-US/docs/Web/JavaScript/Guide/Loops_and_iteration">Loops and iteration guide</a>.</p>
-</div>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>
- מאמר זה נועד להעניק לכם את העקרונות הבסיסים והאפשרויות העומדות בפניהם כאשר תרצו לבצע לולאה של קוד. אתם אמורים בלשב זה להבין את הרעיון והטכניקה שבה לולאות עובדות על מנת לבצע את אותו קוד שוב ושוב. </p>
-
-<h2 id="ראו_גם">ראו גם</h2>
-
-<ul>
- <li><a href="/en-US/docs/Web/JavaScript/Guide/Loops_and_iteration">Loops and iteration</a></li>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Statements/for">for statement דף הסבר בנושא</a></li>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Statements/while">while</a> ו- <a href="/en-US/docs/Web/JavaScript/Reference/Statements/do...while">do...while</a> דפי הסבר</li>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Statements/break">break</a> ו- <a href="/en-US/docs/Web/JavaScript/Reference/Statements/continue">continue</a> דפי הסבר</li>
- <li>
- <p class="entry-title"><a href="https://www.impressivewebs.com/javascript-for-loop/">What’s the Best Way to Write a JavaScript For Loop?</a> — בנושא לולאות best practices</p>
- </li>
-</ul>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/Building_blocks/conditionals","Learn/JavaScript/Building_blocks/Functions", "Learn/JavaScript/Building_blocks")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/conditionals">קבלת החלטות בקוד - משפטי תנאי - Conditionals</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Looping_code">לולאות - Loops</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Functions">פונקציות - בלוקי קוד לשימוש חוזר - Functions</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Build_your_own_function">בניית פונקציות משלנו</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Return_values">ערכים מוחזרים מהפונקציה - Function return values </a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Events">היכרות ראשונית עם אירועים -Introduction to events</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Image_gallery">תרגול: בניית גלריית תמונות</a></li>
-</ul>
diff --git a/files/he/learn/javascript/building_blocks/return_values/index.html b/files/he/learn/javascript/building_blocks/return_values/index.html
deleted file mode 100644
index 52e224289b..0000000000
--- a/files/he/learn/javascript/building_blocks/return_values/index.html
+++ /dev/null
@@ -1,180 +0,0 @@
----
-title: return values - ערכים המוחזרים מפונקציה
-slug: Learn/JavaScript/Building_blocks/Return_values
-tags:
- - Beginner
- - Functions
- - JavaScript
- - Return values
- - מדריך
- - ערכים מוחזרים
- - פונקציות
-translation_of: Learn/JavaScript/Building_blocks/Return_values
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/Building_blocks/Build_your_own_function","Learn/JavaScript/Building_blocks/Events", "Learn/JavaScript/Building_blocks")}}</div>
-
-<p class="summary">עקרון חשוב שנותר לנו לדון בו בהקשר של פונקציות הוא הערכים שהפונקציות יכולות להחזיר - <strong>return values</strong>. יש פונקציות שלא מחזירות ערך משמעותי אחרי שהן סיימו, אבל אחרות כן וזה חשוב שנבין מהם אותם ערכים, כיצד אנחנו יכולים לעשות בהם שימוש ואיך לגרום לפונקציות שאנחנו בונים להחזיר ערכים שנוכל להשתמש בהם. במאמר זה נדון בהיבטים אלו.</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>
- <p>הכרות בסיסית עם המחשב ועם הבסיס של HTML ו- CSS, סיום במלואו של <a href="/en-US/docs/Learn/JavaScript/First_steps">מודול צעדים ראשונים ב-JavaScript</a>. וכן, את המאמר בנושא <a href="/en-US/docs/Learn/JavaScript/Building_blocks/Functions">Functions — פונקציות - חלקי קוד לשימוש חוזר</a>.</p>
- </td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>להבין מהם return values, וכיצד להתשמש בהם.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="מה_הם_return_values">מה הם return values?</h2>
-
-<p><strong>Return values</strong> הם בדיוק כמו שהם נשמעים - אלו ערכים שמוחזרים על ידי הפונקציה כאשר היא מסיימת. אנחנו כבר ראינו return values במספר פעמים, למרות שאולי לא חשבנו עליהם כך. נחזור לקוד שאנחנו מכירים:</p>
-
-<pre class="brush: js">var myText = 'I am a string';
-var newString = myText.replace('string', 'sausage');
-console.log(newString);
-// the replace() string function takes a string,
-// replaces one substring with another, and returns
-// a new string with the replacement made</pre>
-
-<p>ראינו את הקוד הזה בעבר במאמר הראשון בנושא פונקציות. אנחנו קוראים/מפעילים את הפונקציה <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/replace">()replace</a> על המחרוזת <code>myText</code> ומעבירים לה שני פרמטרים (ארגומנטים) - את המחרוזת משנה(<code>'string'</code>) שהיא צריכה לחפש במחרוזת הראשית (<code>myText</code>) ואת המחרוזת משנה החדשה שתחליף את המחרוזת משנה שנמצאה (<code>'sausage'</code>). כאשר פונקציה זו מסיימת - משלימה את הריצה שלה, היא מחזירה ערך, שהוא בעצם המחרוזת החדשה עם ההחלפה שבוצgה. בקוד למעלה, אנחנו שומרים את אותו ערך מוחזר כערך של המשתנה <code>newString</code> שלנו.</p>
-
-<p>אם תעיפו מבט על הדף שלנו בנושא פונקציית <code>()replace</code>, אתם תראו חלק שנקרא <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/replace#Return_value">Return value</a>. תמיד חשוב לדעת ולהבין אלו ערכים מוחזרים על ידי פונקציה, על מנת שנוכל להשתמש בהם אם נרצה או כשנצטרך.</p>
-
-<p>חלק מהפונקציות לא מחזירות return value. במקרים כאלו, הערך המוחזר יהיה <code>void</code> או <code>undefined</code>. לדוגמא, בפונקציה <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/functions/function-stage-4.html#L50">()displayMessage</a> שבנינו במאמר הקודם, אין ערך מוחזר כתוצאה מהשלמת ריצת הפונקציה. היא רק גרמה לקופסא להיות מוצגת איפשהו על המסך.</p>
-
-<p>באופן כללי, return value משמש כאשר הפונקציה היא שלב ביניים בחישוב כלשהו שאנחנו מבצעים לשם קבלת תוצאה סופית. ערכים מוחזרים אלו צריכים להיות מחושבים על ידי הפונקציה, והיא מחזירה את הערכים הללו בתור התוצאות של הקריאה לה (הריצה שלה), ובתוצאות הללו ניתן להשתמש בשלב הבא של החישוב.</p>
-
-<h3 id="שימוש_ב-_return_values_בפונקציות_שלנו">שימוש ב- return values בפונקציות שלנו</h3>
-
-<p>על מנת להחזיר ערך מפונקציה שאנחנו בונים, אנחנו צריכים להשתמש במילה השמורה <a href="/en-US/docs/Web/JavaScript/Reference/Statements/return">return</a>. ראינו מילה זו בפעולה לאחרונה בתרגול שלנו בנושא <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/loops/random-canvas-circles.html">random-canvas-circles.html</a>. פונקציית <code>()draw</code> שלנו מציירת 100 עיגולים אקראיים על האלמנט {{htmlelement("canvas")}}:</p>
-
-<pre class="brush: js">function draw() {
- ctx.clearRect(0,0,WIDTH,HEIGHT);
- for (var i = 0; i &lt; 100; i++) {
- ctx.beginPath();
- ctx.fillStyle = 'rgba(255,0,0,0.5)';
- ctx.arc(random(WIDTH), random(HEIGHT), random(50), 0, 2 * Math.PI);
- ctx.fill();
- }
-}</pre>
-
-<p>בכל איטרציה של הלולאה, מבוצעות שלוש קריאות לפונקציה <code>()random</code>, על מנת לייצר מספר אקראי לקוארדינטות <code>x</code> ו-<code>y</code> של העיגול הנוכחי וכן לרדיוס שלו. הפונקציה <code>()random</code> מקבלת ארגומנט אחד - מספר שלם - ומחזירה מספר שלם בין 0 לאותו מספר שלם שהכנסנו לה כארגומנט. זה נראה כך:</p>
-
-<pre class="brush: js">function randomNumber(number) {
- return Math.floor(Math.random()*number);
-}</pre>
-
-<p>הקוד למעלה היה יכול להירשם גם כך:</p>
-
-<pre class="brush: js">function randomNumber(number) {
- var result = Math.floor(Math.random()*number);
- return result;
-}</pre>
-
-<p>אבל הגרסה הראשונה של הקוד קלה יותר לכתיבה וגם קומפקטית יותר.</p>
-
-<p>אנחנו מחזירים את התוצאה של החישוב <code>(Math.floor(Math.random()*number</code> בכל פעם שקוראים לפונקציה. הערכים המוחזרים הללו מופיעים ברגע שהפונקציה נקראת (מופעלת), והקוד ממשיך. לדוגמא, אם נריץ את השורות הבאות:</p>
-
-<pre class="brush: js">ctx.arc(random(WIDTH), random(HEIGHT), random(50), 0, 2 * Math.PI);</pre>
-
-<p>ושלושת הקריאות לפונקציה <code>()random</code> החזירו נניח את הערכים 500, 200, ו- 35, בהתאמה, השורה תרוץ בפועל כאילו היא נכתבה כך :</p>
-
-<pre class="brush: js">ctx.arc(500, 200, 35, 0, 2 * Math.PI);</pre>
-
-<p>הקריאות לפונקציה באותה שורה רצות קודם והערכים המוחזרים של אותן קריאות נכנסים לתוך השורה עוד לפני ששורת הקוד עצמה מורצת במלואה.</p>
-
-<h2 id="למידה_עצמאית_הגדרת_-_return_value_של_הפונקציה_שלנו">למידה עצמאית: הגדרת - return value של הפונקציה שלנו</h2>
-
-<p>בתרגול זה אנחנו נכתוב פונקציות משלנו הכוללות return values.</p>
-
-<ol>
- <li>ראשית, שמרו עותק מקומי של הקובץ <a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/functions/function-library.html">function-library.html</a> מ-GitHub. זהו דף HTML פשוט המיכל שדה טקסט {{htmlelement("input")}} ופסקה. בנוסף יש גם אלמנט {{htmlelement("script")}} כאשר בתוכו עשינו הפנייה לשני האלמנטים של ה-HTML בתוך שני משתנים. דף זה יאפשר לנו להכניס מספר כלשהו לתוך תיבת טקסט, ולהציג חישובים שונים על המספר הזה בתוך הפסקה שמתחת.</li>
- <li>כעת, נוסיף פונקציות בתוך <code>&lt;script&gt;</code>. מתחת לשתי השורות הקיימות של JavaScript, הוסיפו את הגדרות הפונקציות הבאות:
- <pre class="brush: js">function squared(num) {
- return num * num;
-}
-
-function cubed(num) {
- return num * num * num;
-}
-
-function factorial(num) {
- var x = num;
- while (x &gt; 1) {
- num *= x-1;
- x--;
- }
- return num;
-}</pre>
- הפונקציות <code>()squared</code> ו- <code>()cubed</code> דיי ברורות - הן מחזירות את תוצאות ההכפלה או את השילוש של מספר שניתן להן כפרמטר, בעצמו. הפונקציה <code>()factorial</code> מחזירה את תוצאת העצרת של מספר מסויים. אם אתם לא זוכרים מה זה עצרת, ראו <a href="https://he.wikipedia.org/wiki/עצרת">הסבר על הערך </a>בויקיפדיה.</li>
- <li>כעת, אנחנו הולכים להוסיף דרך להדפיס את כל המידע הזה לגבי המספר שהכנסנו. הכניסו את הקוד הבא, מתחת לפונקציות הנוכחיות:
- <pre class="brush: js">input.onchange = function() {
- var num = input.value;
- if (isNaN(num)) {
- para.textContent = 'You need to enter a number!';
- } else {
- para.textContent = num + ' squared is ' + squared(num) + '. ' +
- num + ' cubed is ' + cubed(num) + '. ' +
- num + ' factorial is ' + factorial(num) + '.';
- }
-}</pre>
-
- <p>הוספנו פונקציה בתור ״מטפל אירוע״ אשר תרוץ כל פעם שאירוע מסוג <code>onchange</code> החל להתרחש בשדה הטקסט שלנו (<code>input</code>), כלומר - כל פעם שמוכנס ערך חדש לתוך שדה הטקסט והערך הזה הוגש - כלומר לחצנו על אנטר או עברנו לאלמנט אחר בדף. כאשר פונקציה אנונימית זו רצה, הערך שהוכנס לתוך שדה הטקסט מאוחסן בתוך המשתנה <code>num</code>.</p>
- </li>
- <li>
- <p>לאחר מכן, אנחו מבצעים בדיקה באמצעות משפט תנאי -</p>
-
- <ol>
- <li>
- <p>אם הערך שהוכנס <u><strong>אינו</strong></u> מספר, אנחנו נציג הודעת שגיאה לתוך הפסקה. המבחן שלנו מבצע שימוש בפונקציית <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/isNaN">()isNaN</a> אשר בודקת האם הערך שהוכנס ב-<code>num</code> הוא לא מספר. אם הערך שהוכנס הוא מספר - היא מחזירה <code>false</code> ואם הוא לא מספר היא מחזירה <code>true</code>.</p>
- </li>
- <li>
- <p>אם המבחן שלנו החזיר <code>false</code>, אז הערך של <code>num</code> הוא מספר ואנחנו יכולים להדפיס לתוך האלמנט <code>p</code> שלנו מהו תוצאת ההכפלה, השילוש והעצרת שלו. המשפט שלנו קורא לפונקציות <code>()squared()</code>, <code>cubed</code>, ו- <code>()factorial</code> על מנת לקבל את הערכים הללו.</p>
- </li>
- </ol>
- </li>
- <li>שמרו את הקוד ונסו אותו בדפדפן שלכם.</li>
-</ol>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אם נתקלתם בבעיות בתוכנית או אתם לא מצליחים לגרום לקוד שלכם לעבוד, נסו להשוו אותו ל<a href="https://github.com/mdn/learning-area/blob/master/javascript/building-blocks/functions/function-library-finished.html">גרסה הסופית שלנו ב-GitHub</a> או ראו אותו כ<a href="http://mdn.github.io/learning-area/javascript/building-blocks/functions/function-library-finished.html">דף אינטרנט</a>.</p>
-</div>
-
-<p>תרגיל זה ניסה להציג לכם כמה מהנקודות החשובות של ביטוי <code>return</code>. בנוסף:</p>
-
-<ul>
- <li>הסתכלנו על דוגמא כיצד לכתוב טיפול בשגיאה בתוך הפונקציה שלנו. באופן עקרוני, מומלץ תמיד לבדוק שהפונקציה קיבלה את הפרמטרים הדרושים לה, ככל ואלו דרושים, ושהם בסוג הנכון. ואם פרמטרים אלו הם אופציונליים, אז מומלץ להגדיר מעין ערך ברירת מחדל. כך רוב הסיכויים שהתוכניות שלנו תהיה עם פחות שגיאות.</li>
- <li>חישבו על הרעיון של ליצור לעצמכם ספריית פונקציות. ככל שתתקדמו בהמשך הלמידה והקריירה שלכם, אתה תיתקלו במקרים שבהם תצטרכו לעשות דברים דומים שוב ושוב. זה רעיון טוב ליצור לעצמכם ספריה של פונקציות שימושיות שאתם משתמשים בהם באופן תדיר, וכך אתם יכולים להעתיק אותם לפרוייקט חדש או פשוט להחיל אותם בכל פעם שתרצו.</li>
-</ul>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>במאמר זה ובשני המאמרים הקודמים למדנו על פונקציות, כמה הן שימושיות וכיצד ניתן להשתמש בהם. יש כמובן הרבה מה להוסיף על פונקציות בנוגע לסינטקס שלהם ולפונקציונליות שלהם, שלושת המאמרים האחרונים בנושא פונקציות ניסו להסביר לכם את עקרונות היסוד והבסיס. הרגישו חופשי להרחיב את הידיעות שלכם בנושא בקישורים המופיעים מטה.</p>
-
-<h2 id="ראו_גם">ראו גם</h2>
-
-<ul>
- <li><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Functions">Functions in-depth</a> — מדריך מפורט בנושא פונקציות המפרט לעומק את האפשרויות השונות של הפונקציות, סינטקסים אפשריים נוספים ועוד.</li>
- <li><a href="https://developer.mozilla.org/en-US/docs/Glossary/Callback_function">Callback functions ב- JavaScript</a> — תבנית נפוצה ב-JavaScript היא להעביר פונקציה כארגומנט לתוך פונקציה אחרת, ואז הפונקציה נקראת בתוך הפונקציה שהיא הועברה אליה. מומלץ להרחיב את הידע בנושא.</li>
-</ul>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/Building_blocks/Build_your_own_function","Learn/JavaScript/Building_blocks/Events", "Learn/JavaScript/Building_blocks")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/conditionals">קבלת החלטות בקוד - משפטי תנאי - Conditionals</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Looping_code">לולאות - Loops</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Functions">פונקציות - בלוקי קוד לשימוש חוזר - Functions</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Build_your_own_function">בניית פונקציות משלנו</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Return_values">ערכים מוחזרים מהפונקציה - Function return values </a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Events">היכרות ראשונית עם אירועים -Introduction to events</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Building_blocks/Image_gallery">תרגול: בניית גלריית תמונות</a></li>
-</ul>
diff --git a/files/he/learn/javascript/first_steps/a_first_splash/index.html b/files/he/learn/javascript/first_steps/a_first_splash/index.html
deleted file mode 100644
index 76a5d40f9b..0000000000
--- a/files/he/learn/javascript/first_steps/a_first_splash/index.html
+++ /dev/null
@@ -1,634 +0,0 @@
----
-title: מבט ראשון ל-JavaScript
-slug: Learn/JavaScript/First_steps/A_first_splash
-translation_of: Learn/JavaScript/First_steps/A_first_splash
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/First_steps/What_is_JavaScript", "Learn/JavaScript/First_steps/What_went_wrong", "Learn/JavaScript/First_steps")}}</div>
-
-<p class="summary">עכשיו כשלמדתם קצת על התיאוריה של JavaScript, אנחנו יכולים להיכנס לעומק יותר ולצדדים הפרקטיים. אנחנו נבנה יחד משחק ״נחש את המספר״, צעד אחד צעד. </p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>הבנה בסיסית של מחשב, הבנה בסיסית של  HTML, CSS ו - JavaScript.</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>להתנסות בכתיבת קוד JavaScript ולהבין כיצד לנסות לעשות זאת.</td>
- </tr>
- </tbody>
-</table>
-
-<p>אנו לא מצפים שתבינו את כל הקוד לפרטי פרטים ישר על ההתחלה. אנחנו רק רוצים להציג לכם בצורה עקרונית את הרעיון כיצד השפה עובדת. בהמשך המאמרים ניכנס יותר לעומק. </p>
-
-<div class="note">
-<p>הרבה מהמאפיינים והאפשרויות ב-JavaScript זהים לשפות תכנות אחרות - כמו לדוגמא לולאות, פונקציות וכד׳. הסינטקס אולי שונה, אבל הרעיונות בגדול דומים.</p>
-</div>
-
-<h2 id="לחשוב_כמו_מתכנת_או_מתכנתת">לחשוב כמו מתכנת או מתכנתת</h2>
-
-<p>אחד מהדברים הקשים ללמידה בפיתוח תוכנה אינו למידת השפה או הסינטקס, אלא איך אנחנו מחילים את השפה לפתרון בעיות אמיתיות. אנחנו צריכים להתחיל לחשוב כמו מתכנתים - זה בעצם כולל בתוכו התבוננות על התיאור של מה התוכנית שלנו צריכה לעשות, להבין מה מאפייני הקוד שאנחנו צריכים כדי להשיג את אותם דברים ואיך אנחנו גורמים להם לעבוד יחד. </p>
-
-<p>זה דורש מאיתנו שילוב של עבודה קשה, ניסיון עם סינטקס השפה, תרגול, וכן מעט יצירותיות. ככל שנכתוב קוד יותר, ככה נשתפר בכך. אנחנו לא יכולים להבטיח שנגרום לך לפתח ״מוח של מתכנת״ בחמש דקות, אבל אנחנו נתן לך את מירב ההזדמניות לתרגל חשיבה של מתכנת בקורס זה.</p>
-
-<h2 id="דוגמא_—_משחק_״נחש_את_המספר״">דוגמא — משחק ״נחש את המספר״</h2>
-
-<p>במאמר זה אנחנו נראה לך כיצד ליצור משחק פשוט:</p>
-
-<div class="hidden">
-<h6 id="Top_hidden_code">Top hidden code</h6>
-
-<pre class="brush: html">&lt;!DOCTYPE html&gt;
-&lt;html&gt;
-
-&lt;head&gt;
- &lt;meta charset="utf-8"&gt;
- &lt;title&gt;Number guessing game&lt;/title&gt;
- &lt;style&gt;
- html {
- font-family: sans-serif;
- }
-
- body {
- width: 50%;
- max-width: 800px;
- min-width: 480px;
- margin: 0 auto;
- }
-
- .lastResult {
- color: white;
- padding: 3px;
- }
- &lt;/style&gt;
-&lt;/head&gt;
-
-&lt;body&gt;
- &lt;h1&gt;Number guessing game&lt;/h1&gt;
- &lt;p&gt;We have selected a random number between 1 and 100. See if you can guess it in 10 turns or fewer. We'll tell you if your guess was too high or too low.&lt;/p&gt;
- &lt;div class="form"&gt; &lt;label for="guessField"&gt;Enter a guess: &lt;/label&gt;&lt;input type="text" id="guessField" class="guessField"&gt; &lt;input type="submit" value="Submit guess" class="guessSubmit"&gt; &lt;/div&gt;
- &lt;div class="resultParas"&gt;
- &lt;p class="guesses"&gt;&lt;/p&gt;
- &lt;p class="lastResult"&gt;&lt;/p&gt;
- &lt;p class="lowOrHi"&gt;&lt;/p&gt;
- &lt;/div&gt;
-&lt;script&gt;
- // Your JavaScript goes here
- let randomNumber = Math.floor(Math.random() * 100) + 1;
- const guesses = document.querySelector('.guesses');
- const lastResult = document.querySelector('.lastResult');
- const lowOrHi = document.querySelector('.lowOrHi');
- const guessSubmit = document.querySelector('.guessSubmit');
- const guessField = document.querySelector('.guessField');
- let guessCount = 1;
- let resetButton;
-
- function checkGuess() {
- let userGuess = Number(guessField.value);
- if (guessCount === 1) {
- guesses.textContent = 'Previous guesses: ';
- }
-
- guesses.textContent += userGuess + ' ';
-
- if (userGuess === randomNumber) {
- lastResult.textContent = 'Congratulations! You got it right!';
- lastResult.style.backgroundColor = 'green';
- lowOrHi.textContent = '';
- setGameOver();
- } else if (guessCount === 10) {
- lastResult.textContent = '!!!GAME OVER!!!';
- lowOrHi.textContent = '';
- setGameOver();
- } else {
- lastResult.textContent = 'Wrong!';
- lastResult.style.backgroundColor = 'red';
- if(userGuess &lt; randomNumber) {
- lowOrHi.textContent = 'Last guess was too low!' ;
- } else if(userGuess &gt; randomNumber) {
- lowOrHi.textContent = 'Last guess was too high!';
- }
- }
-
- guessCount++;
- guessField.value = '';
- }
-
- guessSubmit.addEventListener('click', checkGuess);
-
- function setGameOver() {
- guessField.disabled = true;
- guessSubmit.disabled = true;
- resetButton = document.createElement('button');
- resetButton.textContent = 'Start new game';
- document.body.appendChild(resetButton);
- resetButton.addEventListener('click', resetGame);
- }
-
- function resetGame() {
- guessCount = 1;
- const resetParas = document.querySelectorAll('.resultParas p');
- for(let i = 0 ; i &lt; resetParas.length ; i++) {
- resetParas[i].textContent = '';
- }
-
- resetButton.parentNode.removeChild(resetButton);
- guessField.disabled = false;
- guessSubmit.disabled = false;
- guessField.value = '';
- guessField.focus();
- lastResult.style.backgroundColor = 'white';
- randomNumber = Math.floor(Math.random() * 100) + 1;
- }
-&lt;/script&gt;
-
-&lt;/body&gt;
-&lt;/html&gt;</pre>
-</div>
-
-<p>{{ EmbedLiveSample('Top_hidden_code', '100%', 320, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<p>נסו לשחק עם הקוד קצת, הכירו את המשחק לפני שאתם ממשיכים הלאה.</p>
-
-<p>תדמיינו שהבוס שלכם נתן את התיאור הקצר ליצירת המשחק הזה:</p>
-
-<blockquote>
-<p>הבוס: ״אני רוצה שתצרו משחק פשוט של ״נחש את המספר״. </p>
-
-<p>הוא אמור ליצור מספר בין 1 ל-100, כאשר המשתתף צריך לנחש את המספר בכפולות של 10. </p>
-
-<p>אחרי כל פעם שהמשתתף ניחש את המספר, המשחק יגיד לו אם הוא טעה או צדק, אם הוא טעה, הוא יגיד לו האם הניחוש היה גבוה מדי או נמוך מדיץ בנוסף, המשחק צריך להגיד למשתתף כמה ניחושים הוא ביצע כבר. המשחק יסתיים ברגע שהמשתתף ינחש נכונה את המספר האקראי או ברגע שנגמרו לו הנסיונות. כשהמשחק הסתיים, המשתמש צריך לקבל אפשרות להתחיל את המשחק מחדש. </p>
-</blockquote>
-
-<p>עכשיו, ננסה להפוך את למשימות פשוטות, בצורה מתוכננת כמה שאפשר: </p>
-
-<ol>
- <li>צור מספר בין 1 ל-100.</li>
- <li>שמור את הניסיון של המשתתף. תתחיל במספר 1 שכן זהו הניסיון הראשון.</li>
- <li>ספק למשתמש דרך לנחש את המספר האקראי.</li>
- <li>ברגע שהמתשמש ניחש, שמור את הניחוש שלו כדי שתוכל להציג לו את הניחושים הקודמים.</li>
- <li>בדוק האם המשתמש ניחש את המספר האקראי.</li>
- <li>אם ניחש נכונה:
- <ol>
- <li>הצג הודעת זכייה. </li>
- <li>תמנע מהמשתמש להזין ניחושים נוספים.</li>
- <li>תציג למשתמש אפשרות לאתחל את המשחק.</li>
- </ol>
- </li>
- <li>אם המשתמש לא ניחש נכונה ונותרו לו הנסיונות :
- <ol>
- <li>תציג למשתמש שהוא טעה.</li>
- <li>תאפשר לו לנחש שוב.</li>
- <li>תעלה את מספר הנסיונות שלו ב-1.</li>
- </ol>
- </li>
- <li>אם המשתמש לא ניחש נכונה ונגמרו לו הנסיונות:
- <ol>
- <li>תציג למשתמש שהמשחק נגמר.</li>
- <li>תמנע מהמשתמש להזין ניחושים נוספים.</li>
- <li>תציג למשתמש אפשרות לאתחל את המשחק.</li>
- </ol>
- </li>
- <li>ברגע שהמשחק אותחל מחדש, תוודא שהלוגיקה והנראות של המשחק מאותחלים לחלוטין וחזור לצעד מספר 1.</li>
-</ol>
-
-<p>כעת נראה כיצד ניתן להפוך את רשימת המשימות הזו לקוד של JavaScript.</p>
-
-<h3 id="הגדרות_ראשונות">הגדרות ראשונות</h3>
-
-<p>על מנת להתחיל את המדריך, צרו עותק מקומי של הקובץ <a href="https://github.com/mdn/learning-area/blob/master/javascript/introduction-to-js-1/first-splash/number-guessing-game-start.html">number-guessing-game-start.html</a> או ראו <a href="http://mdn.github.io/learning-area/javascript/introduction-to-js-1/first-splash/number-guessing-game-start.html">כדף אינטרנט</a>.</p>
-
-<p>פתחו אותו גם בעורך הקוד וגם בדפדפן. בנקודה זו אתם תראו כותרת, פסקת הוראות וטופס להכניס ניחוש, אבל הטופס לא עובד כראוי. </p>
-
-<p>אנחנו נכניס את הקוד שלנו בתוך האלמנט {{htmlelement("script")}} בתחתית קובץ ה-HTML:</p>
-
-<pre class="brush: html">&lt;script&gt;
-
- // Your JavaScript goes here
-
-&lt;/script&gt;
-</pre>
-
-<h3 id="הוספת_משתנים_לשם_אחסון_המידע">הוספת משתנים לשם אחסון המידע</h3>
-
-<p>ראשית, הכניסו את השורות הבאות תוך האלמנט {{htmlelement("script")}} :</p>
-
-<pre class="brush: js">let randomNumber = Math.floor(Math.random() * 100) + 1;
-
-const guesses = document.querySelector('.guesses');
-const lastResult = document.querySelector('.lastResult');
-const lowOrHi = document.querySelector('.lowOrHi');
-
-const guessSubmit = document.querySelector('.guessSubmit');
-const guessField = document.querySelector('.guessField');
-
-let guessCount = 1;
-let resetButton;</pre>
-
-<p>חלק זה של הקוד מגדיר משתנים וקבועים שאנחנו צריכים על מנת לאחסן את המידע שהתוכנית שלנו תצטרך. <strong>משתנים הם בעצם כמו קופסאות אחסון עבור ערכים מסוגים שונים אשר יכולים להיות מספרים, טקסט, אובייקטים, מערכים וכד</strong>׳. </p>
-
-<p>אנו יוצרים משתנה באמצעות שימוש במילה שמורה של JavaScript בשם <code>let</code>או <code>var</code> ולאחר מכן בשם שאנחנו רוצים להעניק למשתנה שלנו. (אנחנו נלמד על ההבדלים ביניהם ב<a href="/en-US/docs/Learn/JavaScript/First_steps/Variables#The_difference_between_var_and_let">מאמר בהמשך</a>).</p>
-
-<p><strong>קבועים</strong> לעומת זאת, אלו מעין קופסאות אחסון שנועדו לאחסן ערכים שאנחנו לא נרצה לשנות, ואותם אנחנו יוצרים באמצעות מילה שמורה בשם  <code>const</code>. במקרה שלנו אנחנו משתמשים בקבועים על מנת לאחסן את ההפניות לאלמנטים בדף ה-html, כלומר לממשק המשתמש. אמנם יכול להיות שהתוכן שלהם ישתנה, אבל ההפניה לאותו אלמנט תישאר קבועה לאורך התוכנית.</p>
-
-<p>על מנת לשים ערך מסויים במשתנה או בקבוע מסויים, אנחנו משתמשים בסימן ״שווה״ (<code>=</code>), ולאחר מכן הערך שאנחנו רוצים להשים באותו משתנה או קבוע.</p>
-
-<p>בדוגמא שלנו :</p>
-
-<ul>
- <li>המשתנה הראשון — <code>randomNumber</code> — הושם לו ערך אקראי בין  1 ל- 100, באמצעות שימוש במתודה אשר נמצאת ב-JavaScript.</li>
- <li>שלושת הקבועים הראשונים נועדו על מנת לאחסן או להשים את ההפנייה לפסקאות הרלוונטיות ב-html אליהם אשר התוכן שלהם ימולא בערכים שיינתו להם בהמשך:
- <pre class="brush: html">&lt;p class="guesses"&gt;&lt;/p&gt;
-&lt;p class="lastResult"&gt;&lt;/p&gt;
-&lt;p class="lowOrHi"&gt;&lt;/p&gt;</pre>
- </li>
- <li>שני הקבועים הבאים נועדו לאחסן הפנייה לקלט של הטופס ולכפתור השליחה ונועדו לשם שליטה בניחוש שביצע המשתמש.</li>
- <li>
- <pre class="brush: html">&lt;label for="guessField"&gt;Enter a guess: &lt;/label&gt;&lt;input type="text" id="guessField" class="guessField"&gt;
-&lt;input type="submit" value="Submit guess" class="guessSubmit"&gt;</pre>
- </li>
- <li>שני המשתנים האחרונים שלנו נועדו לאחסן את מס׳ הניחושים וכן להוות הפנייה לכפתור הריסט, שאינו קיים לבינתיים.</li>
-</ul>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אתם תלמדו עוד על משתנים וקבועים בהמשך הקורס, החל מה<a href="https://developer.mozilla.org/en-US/docs/user:chrisdavidmills/variables">מאמר הבא</a>.</p>
-</div>
-
-<h3 id="פונקציות">פונקציות</h3>
-
-<p>הוסיפו את הקוד הבא, מתחת לקוד הקיים שלכם:</p>
-
-<pre class="brush: js">function checkGuess() {
- alert('I am a placeholder');
-}</pre>
-
-<p>פונקציות הם בעצם חלקי קוד הניתנים לשימוש חוזר, אותם ניתן לרשום פעם אחת, ולהריץ שוב ושוב. זה מאוד שימושי. יש כמה דרכים להגדיר פונקציה אבל כעת אנחנו נתמקד בצורה פשוטה אחת. </p>
-
-<p>כאן אנחנו הגדרנו את הפונקציה באמצעות שימוש במילה שמורה <code>function</code> ולאחר מכן שם הפונקציה וסוגריים <code>()</code>. לאחר מכן, הוספנו סוגריים מסולסלים <code>{}</code>. כל מה שנמצא בתוך הסוגריים המסולסלים זה הקוד שנרצה שירוץ בכל פעם שנקרא לפונקציה. </p>
-
-<p>כשנרצה להריץ את הקוד, אנחנו פשוט נקליד את שם הפונקציה ובצמוד לה נשים סוגריים <code>()</code>. שמרו את הקובץ ורענן את הדף בדפדפן. לאחר מכן, הזן<a href="/en-US/docs/Learn/Common_questions/What_are_browser_developer_tools"> בקונסולה</a>, את השורה הבאה:  </p>
-
-<pre class="brush: js">checkGuess();</pre>
-
-<p>לאחר שנלחץ על  <kbd>Return</kbd>/<kbd>Enter</kbd>, אנחנו אמורים לראות שקפצה הודעה שרשמה "<samp>I am a placeholder</samp>".</p>
-
-<p>הגדרנו פונקציה שמקפיצה הודעה למשתמש בכל פעם שנקרא לה.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אתם תלמדו עוד על פונקציות <a href="/en-US/docs/Learn/JavaScript/Building_blocks/Functions">בהמשך הקורס</a>.</p>
-</div>
-
-<h3 id="אופרטורים_(Operators)">אופרטורים (Operators)</h3>
-
-<p>אופרטורים של JavaScript מאפשרים לנו לבצע מבחנים מסויימים, חישובים מתמטיים, חיבור מחרוזות ודברים נוספים רבים. </p>
-
-<p>אם לא עשיתם זאת עד עכשיו, שמרו את הקוד, ורעננו את הדף. לאחר מכן, פתחו את הקונסולה. נסו להזין את הדוגמאות המפורטות למטה בעמודת ״דוגמא״, בדיוק בצורה שבה הן מופיעות ולאחר מכן לחצו <kbd>Return</kbd>/<kbd>Enter</kbd>  וראו את התוצאות. </p>
-
-<p>נתחיל עם אופרטורים מתמטיים:</p>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">אופרטור</th>
- <th scope="col">שם</th>
- <th scope="col">דוגמא</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td><code>+</code></td>
- <td>חיבור</td>
- <td><code>6 + 9</code></td>
- </tr>
- <tr>
- <td><code>-</code></td>
- <td>חיסור</td>
- <td><code>20 - 15</code></td>
- </tr>
- <tr>
- <td><code>*</code></td>
- <td>כפל</td>
- <td><code>3 * 7</code></td>
- </tr>
- <tr>
- <td><code>/</code></td>
- <td>חילוק</td>
- <td><code>10 / 5</code></td>
- </tr>
- </tbody>
-</table>
-
-<p>ניתן להשתמש בסימן החיבור + על מנת לחבר מחרוזות ביחד (בתכנות, בשפה האנגלית זה נקרא: <em>concatenation).</em></p>
-
-<p>נסו להזין את השורות הבאות בקונסולה, אחת בכל פעם:</p>
-
-<pre class="brush: js">let name = 'Bingo';
-name;
-let hello = ' says hello!';
-hello;
-let greeting = name + hello;
-greeting;</pre>
-
-<p>יש גם כמה קיצורים לאופרטורים מתמטיים, לדוגמא, אם אנחנו פשוט רוצים להוסיף מחרוזת טקסט חדשה למחרוזת טקסט קיימת ולהחזיר את המחרוזת המחוברת של שתיהן, נוכל לבצע את הדבר הבא: </p>
-
-<pre class="brush: js">name += ' says hello!';</pre>
-
-<p>זה זהה בתוצאה לדבר הבא:</p>
-
-<pre class="brush: js">name = name + ' says hello!';</pre>
-
-<p>כשאנחנו מריצים מבחני אמת/שקר (לדוגמא, בתוך תנאים), אנחנו משתמשים ב<a href="/en-US/docs/Web/JavaScript/Reference/Operators/Comparison_Operators">אופרטורים השוואתיים</a>: </p>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">אופרטור</th>
- <th scope="col">שם</th>
- <th scope="col">דוגמא</th>
- </tr>
- <tr>
- <td><code>===</code></td>
- <td>האם זהה לחלוטין?</td>
- <td>
- <pre class="brush: js">
-5 === 2 + 4 // false
-'Chris' === 'Bob' // false
-5 === 2 + 3 // true
-2 === '2' // false; number versus string
-</pre>
- </td>
- </tr>
- <tr>
- <td><code>!==</code></td>
- <td>האם לא זהה?</td>
- <td>
- <pre class="brush: js">
-5 !== 2 + 4 // true
-'Chris' !== 'Bob' // true
-5 !== 2 + 3 // false
-2 !== '2' // true; number versus string
-</pre>
- </td>
- </tr>
- <tr>
- <td><code>&lt;</code></td>
- <td>קטן מ-</td>
- <td>
- <pre class="brush: js">
-6 &lt; 10 // true
-20 &lt; 10 // false</pre>
- </td>
- </tr>
- <tr>
- <td><code>&gt;</code></td>
- <td>גדול מ-</td>
- <td>
- <pre class="brush: js">
-6 &gt; 10 // false
-20 &gt; 10 // true</pre>
- </td>
- </tr>
- </thead>
-</table>
-
-<h3 id="משפטי_תנאי">משפטי תנאי</h3>
-
-<p>נחזור לפונקציית  <code>()checkGuess</code> שלנו. אנחנו נרצה שהיא תעשה יותר מאשר להוציא הודעה פשוטה למשתמש. אנחנו רוצים לבדוק האם הניחוש של המשתמש היה נכון או לא  ולהגיב ובהתאם. </p>
-
-<p> בנקודה זו, החלף את הפונקציה <code>()checkGuess</code> עם הקוד הבא: </p>
-
-<pre class="brush: js">function checkGuess() {
- let userGuess = Number(guessField.value);
- if (guessCount === 1) {
- guesses.textContent = 'Previous guesses: ';
- }
- guesses.textContent += userGuess + ' ';
-
- if (userGuess === randomNumber) {
- lastResult.textContent = 'Congratulations! You got it right!';
- lastResult.style.backgroundColor = 'green';
- lowOrHi.textContent = '';
- setGameOver();
- } else if (guessCount === 10) {
- lastResult.textContent = '!!!GAME OVER!!!';
- setGameOver();
- } else {
- lastResult.textContent = 'Wrong!';
- lastResult.style.backgroundColor = 'red';
- if(userGuess &lt; randomNumber) {
- lowOrHi.textContent = 'Last guess was too low!';
- } else if(userGuess &gt; randomNumber) {
- lowOrHi.textContent = 'Last guess was too high!';
- }
- }
-
- guessCount++;
- guessField.value = '';
- guessField.focus();
-}</pre>
-
-<p>נעבור על כל חלק בקוד על מנת להסביר אותו: </p>
-
-<ul>
- <li>בשורה 2 אנחנו מצהירים על משתנה בשם <code>userGuess </code>ומשימים לו את הערך שיהיה הערך אשר מוכנס על ידי המשתמש לתוך תיבת הקלט. אנחנו מריצים את הערך שהוכנס על ידי המשתמש במתודה מובנית בשפה בשם <code>()Number</code>  מנת לוודא שאכן המספר שהמשתמש הזין, הוא מספר ולא טקסט.</li>
- <li>בשורות 3-5, אנחנו מזינים לראשונה את משפט התנאי שלנו. משפט תנאי מאפשר לנו להריץ קוד באופן סלקטיבי, כאשר הקוד ירוץ בהתבסס על התקיימות תנאי כלשהו או היעדר התקיימותו. הצורה הפשוטה ביותר של משפט תנאי תתחיל במילה השמורה <code>if</code> ולאחר מכן סוגריים רגילים <code>()</code> ואז סוגריים מסולסלות <code>{}</code>. בתוך הסוגריים הרגילים אנחנו נזין את התנאי/מבחן. אם התנאי יתקיים, כלומר תוצאת המבחן היא אמת, אז הקוד בתוך הסוגריים המסולסלות ירוץ. אם לא, אנחנו לא נריץ את הקוד בסוגריים המסולסלים והתוכנית תמשיך הלאה. </li>
- <li>במקרה הזה, התנאי/המבחן בודק האם המשתנה <code>userGuess</code> שווה באופן מוחלט ל-1, כלומר האם זה התור הראשון של המשתתף במשחק:
- <pre class="brush: js">guessCount === 1</pre>
- אם כן, אנחנו נציג לו הודעה כזו באמצעות שינוי הטקסט בתוכן של הפסקה למלל הבא:   "<samp>Previous guesses:</samp>"   ואם לא, לא. </li>
- <li>שורה 6 מוסיפה את התוכן הנוכחי של ניחוש המשתמש (<code>userGuess</code> ) לסוף הפסקה <code>guesses</code> בצירוף רווח מסויים בין הניחושים.</li>
- <li>שורות 8-24 מבצעות מספר בדיקות:
- <ul>
- <li>התנאי הראשון <code>{ }</code><code>()if</code>בודק האם הניחוש של המשתמש (<code>userGuess)</code> הוא שווה למספר האקראי (<code>randomNumber)</code> שהוגדר בתחילת הקוד שלנו.
- <ul>
- <li>אם כן, המשתתף ניחש נכונה את המספר, וניצח במשחק. </li>
- <li>נציג לו הודעת זכייה בצבע ירוק.</li>
- <li>נמחק את התוכן של הפסקה שמציינת האם הניחוש היה גדול/קטן. </li>
- <li>נריץ פונקציה שנקראת <code>()setGameOver</code> אשר נדון בה מאוחר יותר. </li>
- </ul>
- </li>
- <li>אם התנאי הראשון לא התקיים, נריץ מבחן נוסף באמצעות שימוש בביטוי <code> { } () else if</code>. מבחן זה בודק האם זהו התור האחרון של המשתתף ואם כן, ירוץ קוד זהה לקוד שנמצא בבלוק הקודם, למעט כך שתוקפץ הודעה שהמשחק נגמר ולא הודעת זכייה. </li>
- <li>התנאי האחרון בשרשרת, אותו הגדרנו באמצעות הביטוי <code>{} else</code> מתפקד כמו ברירת מחדל. הוא מכיל קוד שירוץ רק אם אף אחד מהתנאים לעיל לא התקיים, כלומר לא החזיר ערך אמת <code>true</code>. במקרה כזה, נודיע למשתמש שהוא טעה, ונבצע בדיקת תנאי נוספת (שורות 19-23) לבדוק האם הניחוש של המשתתף במשחק היה גבוה או נמוך מהמספר האקראי, וכן נודיע לו בהתאם. </li>
- </ul>
- </li>
- <li>שורות 26-28 של הפונקציה מבצעות הכנה לניחוש הבא של המשתתף - אנו מגדילים את המשתנה <code>guessCount</code> ב-1 על מנת לעדכן את כמות הניחושים של המשתתף, ומרוקנים את הערך של הקלט, על מנת שהמשתמש יזין את הניחוש החדש. לבסוף אנו מריצים מתודה על האובייקט המכיל את אלמנט הקלט מהמשתמש שמאפשרת לנו לגרום לכך שהפוקוס של המסך יהיה באלמנט הקלט. </li>
-</ul>
-
-<h3 id="אירועים">אירועים</h3>
-
-<p>בשלב זה הגדרנו את פונקציית <code>()checkGuess</code> אבל היא לא תעשה כלום כי לא קראנו לה עדיין. באופן אידיאלי, אנחנו רוצים ״<strong>לקרוא</strong>״ (<strong>Invoke</strong>) לפונקציה כאשר המשתמש ילחץ על לחצן ״Submit guess" ועל מנת לבצע זאת אנחנו צריכים לעשות שימוש באירוע (Event). אירועים אלו דברים המתרחשים בתוך הדפדפן - כפתור נלחץ, דף נטען, וידאו מתנגן וכד׳ - ובהתאם, אנחנו יכולים להריץ בלוקים של קוד. הקונסטרקטור (בעברית: הבנאי), שמאזין לאותו אירוע שמתרחש בדפדפן נקרא מאזין אירוע (<strong>event listeners</strong>), ואילו בלוק הקוד שרץ בתגובה לאותו אירוע נקרא מטפל אירוע (<strong>event handlers</strong>).</p>
-
-<p>הוסף את הקוד הבא מתחת לפונקציית<code> ()checkGuess</code> :</p>
-
-<pre class="brush: js">guessSubmit.addEventListener('click', checkGuess);</pre>
-
-<p>כאן אנו מוסיפים event listener<strong> </strong>לכפתור <code>guessSubmit</code>. מתודה זו מקבלת 2 ערכים (שנקראים ״ארגומנטים״) - הראשון הוא סוג האירוע שאנחנו רוצים להאזין לו (במקרה, אירוע מסוג  <code>click</code>), ואותו נזין כמחרוזת, עטוף בגרשיים, לאחר מכן פסיק, ואז את event handlers, שהוא בעצם הקוד שנרצה שירוץ ברגע שהתרחש האירוע (במקרה זה, פונקציית <code>()checkGuess</code> ). תשומת לב כי אנחנו לא צריכים להכניס סוגריים כאשר אנחנו רושמים את הפונקציה <code>checkGuess </code>בתוך המתודה {{domxref("EventTarget.addEventListener", "addEventListener()")}}.</p>
-
-<p>נסו לשמור ולרען את הדף כעת - הדוגמא אמורה לעבוד, עד נקודה מסויימת. הבעיה היחידה היא שכאשר המשתתף ינחש נכון או המשחק הסתיים כי נגמרו לו הנסיונות, המשחק יסתיים בצורה לא רצויה, מכיוון שלא הגדרנו את הפונקציה <code>()setGameOver</code> שאמורה לרוץ ברגע שהמשחק יסתיים (הן אם המשתתף ניחש נכון והן אם למשתתף נגמרו הנסיונות).</p>
-
-<p>כעת נוסיף את הקוד החסר ונשלים את הפונקציונליות של המשחק.  </p>
-
-<h3 id="השלמת_הפונקציונליות_של_המשחק">השלמת הפונקציונליות של המשחק</h3>
-
-<p>כעת נוסיף את הפונקציה <code>()setGameOver</code> מתחת לקוד הנוכחי: </p>
-
-<pre class="brush: js">function setGameOver() {
- guessField.disabled = true;
- guessSubmit.disabled = true;
- resetButton = document.createElement('button');
- resetButton.textContent = 'Start new game';
- document.body.appendChild(resetButton);
- resetButton.addEventListener('click', resetGame);
-}</pre>
-
-<ul>
- <li>שתי השורות הראשונות משנות את <code>guessField</code> ושל <code>guessSubmit</code> לבלתי זמין - זאת באמצעות שינוי המאפיין של אובייקטים אלו ל-<code>disabled</code>. זה הכרחי על מנת למנוע מהמשתמש להזין ניחושים נוספים. </li>
- <li>שלושת השורות הבאות מייצרות לנו אלמנט {{htmlelement("button")}} חדש, ומוסיפות אותו בתחתית ה-html הנוכחי שלנו. </li>
- <li>השורה האחרונה מוסיפה event listner לכפתור החדש, ש-״מאזין״ לאירוע של הקלקה על הכפתור, וכשזה קורה, מריץ את הפונקציה שנקראת <code>()resetGame</code>.</li>
-</ul>
-
-<p>עת אנחנו צריכים להגדיר את הפונקציה הזו. הוסף את הקוד הבא מתחת לקוד הנוכחי: </p>
-
-<pre class="brush: js">function resetGame() {
- guessCount = 1;
-
- const resetParas = document.querySelectorAll('.resultParas p');
- for (let i = 0 ; i &lt; resetParas.length ; i++) {
- resetParas[i].textContent = '';
- }
-
- resetButton.parentNode.removeChild(resetButton);
-
- guessField.disabled = false;
- guessSubmit.disabled = false;
- guessField.value = '';
- guessField.focus();
-
- lastResult.style.backgroundColor = 'white';
-
- randomNumber = Math.floor(Math.random() * 100) + 1;
-}</pre>
-
-<p>קוד זה מאתחל הכל לאיך שהוא היה בתחילת המשחק: </p>
-
-<ul>
- <li>משים ערך של 1 במשתנה <code>guessCount</code>. (שורה 2)</li>
- <li>מרוקן את כל תוכן הטקסט בפסקאות. (שורות 4-7)</li>
- <li>מוחק את כפתור האתחול. (שורה 9)</li>
- <li>הופך את <code>guessField</code> ו- <code>guessSubmit</code> לזמינים שוב. (שורות 11-12)</li>
- <li>מרוקן מתוך<code>guessField</code> כל טקסט שנמצא בתוכו. (שורה 13) </li>
- <li>מזיז את הפוקוס במסך ל-<code>guessField</code>. (שורה 14) </li>
- <li><span style="font-size: 1rem; letter-spacing: -0.00278rem;">משנה את הרקע של פסקת </span><code style="font-size: 1rem; letter-spacing: -0.00278rem;">lastResult</code>. (שורה 16)</li>
- <li><span style="font-size: 1rem; letter-spacing: -0.00278rem;">לבסוף, יוצר שוב מספר אקראי, חדש, על מנת שלא ננחש שוב את אותו מספר. </span></li>
-</ul>
-
-<p><strong>בשלב זה - יש לנו משחק שעובד במלואו. פשוט יחסית, אך עובד.  </strong></p>
-
-<p>כעת נדבר על אפשרויות נוספות שראינו, ואולי לא שמנו לב. </p>
-
-<h3 id="לולאות">לולאות</h3>
-
-<p>חלק מתוך הקוד למעלה שנרצה להתעמק בו הוא לולאת מסוג <a href="/en-US/docs/Web/JavaScript/Reference/Statements/for">for</a>.</p>
-
-<p>לולאות הן עקרון מאוד חשוב בתכנות, ומאפשרות לנו להריץ קוד שוב ושוב, עד שתנאי מסויים יתרחש. </p>
-
-<p>על מנת להתחיל, פתח את ה<a href="/en-US/docs/Learn/Common_questions/What_are_browser_developer_tools">קונסולה </a>שוב, והכנס את הקוד הבא: </p>
-
-<pre class="brush: js">for (let i = 1 ; i &lt; 21 ; i++) { console.log(i) }</pre>
-
-<p>מה קרה?</p>
-
-<p>המספרים 1 עד 20 הודפסו לקונסולה. זה מכיוון שהשתמשנו בלולאה מסוג <code>for</code>. לולאה מסוג <code>for</code> מקבלת 3 ערכים (ארגומנטים):</p>
-
-<ol>
- <li><strong>ערך ראשון (Starting Value) -</strong> במקרה זה אתחלנו את המונה ל-1, אך אנו יכולים להתחיל בכל מספר שנרצה. כמו כן, את שם המשתנה <code>i</code> ניתן להחליף בכל שם שנרצה. אנו מבצעים שימוש ב-<code>i</code> כי זה קצר ונוח לזכור. </li>
- <li><strong>תנאי יציאה (An exit condition) - </strong>כאן הגדרנו שתנאי היציאה מהלולאה, כלומר מתי הלולאה תפסיק לרוץ יהיה כל עוד <code>i &lt; 21</code>. כלומר הלולאה תרוץ כל זמן ש-<code>i</code> יהיה קטן מ-21. ברגע ש-<code>i</code> יהיה שווה ל-21, הלולאה תפסיק לרוץ.</li>
- <li>המוסיף (<strong>An incrementor</strong>) - כאן הגדרנו <code>i++</code> כלומר נעלה את הערך של <code>i</code>  ב-1 בכל פעם שהקוד שנמצא בתוך הסוגריים המסולסלות <code>{}</code> מסיים לרוץ (כל איטרציה-iteration), עד אשר <code>i</code> יגיע לערך 21. במקרה הזה אנחנו פשוט מדפיסים לקונסולה את הערך של <code>i</code> בכל איטרציה (iteration), באמצעות {{domxref("Console.log", "console.log()")}}.</li>
-</ol>
-
-<p>בוא נסתכל כעת על הלולאה במשחק הניחוש שבנינו בתוך פונקציית <code>()resetGame</code>:</p>
-
-<pre class="brush: js">let resetParas = document.querySelectorAll('.resultParas p');
-for (let i = 0 ; i &lt; resetParas.length ; i++) {
- resetParas[i].textContent = '';
-}</pre>
-
-<p>קוד זה יוצר משתנה מסוג מערך (נדבר עליו בהמשך) בשם <code>resetParas</code> המכיל רשימה של כל האלמנטים מסוג p הנמצאים בתוך אלמנט עם <code>class</code> בשם <code>resultParas</code> (במקרה שלנו זה האלמנט הבא: <code>&lt;div class="resultParas"&gt;</code>). </p>
-
-<p><code>resetParas</code> נוצר באמצעות שימוש במתודה {{domxref("Document.querySelectorAll", "querySelectorAll()")}}. </p>
-
-<p>לאחר מכן, הוא עובר באמצעות לולאה על כל איבר במערך, ומסיר את התוכן טקסט של כל איבר. </p>
-
-<h3 id="דיון_קצר_על_אובייקטים">דיון קצר על אובייקטים</h3>
-
-<p>נוסיף שיפור נוסף לפני שנמשיך בדיון : הוסיפו את הקוד הבא, מתחת לקוד זה: <code>let resetButton;</code> הנמצא בראש הדף, ולאחר מכן שמרו את הקובץ: </p>
-
-<pre class="brush: js">guessField.focus();</pre>
-
-<p>קוד זה עושה שימוש במתודה בשם {{domxref("HTMLElement.focus", "focus()")}} על מנת לשים את סמן העבר בתוך הטקסט של תיבת הקלט {{htmlelement("input")}} ברגע שהדף נטען, כך שהמשתמש יוכל הזין את הניחוש הראשון שלו ישר כשהדף נטען, ללא צורך ללחוץ על תיבת הקלט. זוהי אמנם תוספת קטנה, אך היא משפרת השימוש של המשתמש ומאפשרת לו להבין באופן ויזואלי איך לשחק את המשחק.</p>
-
-<p>נכנס לזה קצת יותר לעומק. ב-JavaScript, כל דבר הוא אובייקט. אובייקט הוא אוסף של מס׳ פונקציונליות וערכים אשר קובצו יחד לקבוצה אחת. אנו יכולים ליצור אובייקט בעצמו, אך נגע בנושא זה בהמשך. לצורך העניין במאמר הנוכחי, אנחנו נדון בקצרה באובייקטים המובנים בדפדפן, אשר מאפשרים לנו לעשות הרבה דברים שימושיים. </p>
-
-<p>במקרה הנוכחי, יצרנו תחילה קבוע בשם <code>guessField</code> אשר אחסן בתוכן הפנייה לתיבת קלט הטקסט ב-html - השורה הבאה יכולה להימצא באזור שבו הצרנו על המשתנים/קבועים בתחילת הקוד שלנו: </p>
-
-<pre class="brush: js">const guessField = document.querySelector('.guessField');</pre>
-
-<p>על מנת לקבל את ההפניה הזו, השתמשנו במתודה  {{domxref("document.querySelector", "querySelector()")}} של האובייקט {{domxref("document")}}. דוגמא נוספת היא למתודה של אובייקט זה היא  <code>()querySelector</code> אשר מקבלת מידע אחד מסוג <a href="/en-US/docs/Learn/CSS/Introduction_to_CSS/Selectors">סלקטור של CSS</a> - ואותו סלקטור בוחר את האלמנט שאנחנו רוצים להפנות אליו. </p>
-
-<p>מכיוון ש-<code>guessField</code> מכיל כעת הפנייה לאלמנט {{htmlelement("input")}}, הוא יכול כעת לגשת למספר מאפיינים (properties) ומתודות (methods). באופן עקרוני, properties אלו משתנים המאוחסנים בתוך אובייקט, וחלקם לא יכולים לשנות את ערכם, ואילו methods אלו פונקציות המאוחסנות בתוך אובייקט. מתודה אחת אשר זמינה לאלמנט {{htmlelement("input")}}, היא <code>()focus</code>, כך שאנחנו יכולים להשתמש בקוד למטה, על מנת לבצע פוקוס לתיבת קלט הטקסט: </p>
-
-<pre class="brush: js">guessField.focus();</pre>
-
-<p>משתנים שאינם כוללים הפנייה לאלמנטים של טפסים, אינם יכולים לגשת למתודה הזו והיא לא תהיה זמינה עבורם. לדוגמא, הקבוע <code>guesses</code> מכיל הפנייה לאלמנט  {{htmlelement("p")}} ו-המשתנה <code>guessCount</code> מכיל מספר. </p>
-
-<h3 id="לשחק_ולנסות_את_האובייקטים_של_הדפדפן">לשחק ולנסות את האובייקטים של הדפדפן</h3>
-
-<p>בואו נשחק טיפה עם האובייקטים של הדפדפן.</p>
-
-<ol>
- <li>פתחו תוכנית בדפדפן.</li>
- <li>פתחו את <a href="/en-US/docs/Learn/Common_questions/What_are_browser_developer_tools">browser developer tools</a> ווודאו שהקונסולה מופיעה. </li>
- <li>רשמו <code>guessField</code> והקונסולה תציג לכם את המשתנה המכיל את האלמנט {{htmlelement("input")}}. אתם תבחינו שהקונסולה גם משלימה את השמות של האובייקטים שקיימים בסביבת ההרצה, כולל משתנה. </li>
- <li>כעת הזינו את הקוד הבא: </li>
- <li>
- <pre class="brush: js">guessField.value = 'Hello';</pre>
- המאפיין (property) בשם <code>value</code> מייצג את הערך שהוזן לתוך שדה הטקסט. ניתן לראות שעם הזנת הקוד לעיל, אנחנו משנים את הטקסט בשדה הטקסט. </li>
- <li>נסו לרשום בקונסולה <code>guesses</code>. הקונסולה תראה לכם שהוא מכיל אלמנט מסוג{{htmlelement("p")}}.</li>
- <li><span style="font-size: 1rem; letter-spacing: -0.00278rem;">כעת הזן את הקוד הבא:</span></li>
- <li>
- <pre class="brush: js">guesses.value</pre>
- הקונסולה תחזיר את הערך <code>undefined</code> מכיוון שאלמנט מסוג {{htmlelement("p")}} לא מקבל מאפיין מסוג <code>value</code>.</li>
- <li><span style="font-size: 1rem; letter-spacing: -0.00278rem;">על מנת לשנות את הטקסט בתוך</span> {{htmlelement("p")}} , אנחנו צריכים להשתמש במאפיין בשם <span style="font-size: 1rem; letter-spacing: -0.00278rem;"> {{domxref("Node.textContent", "textContent")}}</span></li>
- <li>כעת הזינו את הקוד הבא<span style="font-size: 1rem; letter-spacing: -0.00278rem;">:</span></li>
- <li>
- <pre class="brush: js">guesses.textContent = 'Where is my paragraph?';</pre>
- </li>
- <li>כעת ננסה לשנות עיצוב באמצעות גישה ל-properties של האובייקט:
- <pre class="brush: js">guesses.style.backgroundColor = 'yellow';
-guesses.style.fontSize = '200%';
-guesses.style.padding = '10px';
-guesses.style.boxShadow = '3px 3px 6px black';</pre>
- כל אלמנט שנמצא בדף מכיל מאפיין בשם <code>style</code> אשר הוא בעצמו אובייקט המכיל את כללי ה-CSS ה-inline שהוחלו על אותו אובייקט (ואף ניתן להחיל עליו כללי CSS או למחוק את הכללים הנוכחיים או להחליפם באחרים) . זה מאפשר לנו לשנות באופן דינמי את העיצוב של האובייקט באמצעות JavaScript.</li>
-</ol>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>סיימנו לבנות את הדוגמא. בדקו את הקוד הסופי שלכם וודאו שהוא עובד כראוי, או שתוכלו <a href="http://mdn.github.io/learning-area/javascript/introduction-to-js-1/first-splash/number-guessing-game.html">לשחק עם הגרסה הסופית פה</a> אם אתם לא מצליחים לגרום לקוד שלכם לעבוד, נסו להשוות אותו אל מול <a href="https://github.com/mdn/learning-area/blob/master/javascript/introduction-to-js-1/first-splash/number-guessing-game.html">קוד המקור</a>. </p>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/First_steps/What_is_JavaScript", "Learn/JavaScript/First_steps/What_went_wrong", "Learn/JavaScript/First_steps")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/What_is_JavaScript">מה זה JavaScript?</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/A_first_splash">מבט ראשון ל- JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/What_went_wrong">מה השתבש? פתרון בעיות ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Variables">אחסון המידע שאנחנו צריכים - משתנים — Variables</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Math">מתמתיקה בסיסית ב-  JavaScript — מספרים ואופרטורים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Strings">התמודדות עם טקסט — מחרוזות (Strings) ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Useful_string_methods">מתודות שימושיות למחרוזות</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Arrays">מערכים - Arrays</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Silly_story_generator">תרגיל: Silly story generator</a></li>
-</ul>
diff --git a/files/he/learn/javascript/first_steps/arrays/index.html b/files/he/learn/javascript/first_steps/arrays/index.html
deleted file mode 100644
index 44675349fa..0000000000
--- a/files/he/learn/javascript/first_steps/arrays/index.html
+++ /dev/null
@@ -1,564 +0,0 @@
----
-title: Arrays - מערכים
-slug: Learn/JavaScript/First_steps/Arrays
-translation_of: Learn/JavaScript/First_steps/Arrays
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/First_steps/Useful_string_methods", "Learn/JavaScript/First_steps/Silly_story_generator", "Learn/JavaScript/First_steps")}}</div>
-
-<p class="summary">במאמר האחרון במודול זה, אנחנו נדע במערכים - דרך מסודרת וקלה לאחסן רשימה פריטי מידע תחת משתנה אחד. אנחנו נבין מדוע שמוש במערך הוא שימושי כל כך ונבין כיצד ליצור מערך, לשנות את האיברים שלו, למחוק או להוסיף לו איברים ועוד.</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>הבנה בסיסית של מחשב, הבנה בסיסית של HTML, CSS ו - JavaScript.</td>
- </tr>
- <tr>
- <th scope="row">Objective:</th>
- <td>הבנה של מערכים וביצוע פעולות שונות עליהם</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="מה_זה_בעצם_מערך_-_Array">מה זה בעצם מערך - Array?</h2>
-
-<p>מערכים לרוב מתוארים כאובייקט של מעין רשימה (״list-like objects״). בעיקרון, אלו אובייקטים המכילים מספר ערכים שמאוחסנים יחד.</p>
-
-<p>אובייקטים מסוג מערך יכולים להיות מאוחסנים בתוך משתנה ונוכל לטפל בהם בדיוק כמו שאנחנו מטפלים במשתנים אחרים.</p>
-
-<p>אנו יכולים לטפל בכל ערך בודד באותו במערך או במערך בכללותו. אנחנו יכולים לעבור על כל איברי המערך אחד אחרי השני ולבצע בהם פעולות שונות. כך לדוגמא, אם יש לנו סדרה של מוצרים והמחירים שלהם מאוחסנים במערך, אנחנו רוצים לעבור על כל המחירים ולהדפיס אותם בחשבונית, ובמקביל לחשב את הסכום הכולל של המוצרים יחד עם המחירים שלהם.</p>
-
-<p>אם לא היו לנו מערכים, היינו צריכים לשמור כל פריט במשתנה אחר, ואז לכתוב קוד שידפיס את המחיר בנפרד עבור כל משתנה. זה היה הופך את הקוד שלנו להרבה יותר מורכב וארוך ופחות יעיל. אם היו לנו 10 פריטי להדפיס לחשבונית זה עוד נשמע הגיוני, אך מה נעשה במצב שיש לנו 100 פריטים או 1,000 פריטים? נחזור לדוגמא זו בהמשך המאמר על מנת להבין כיצד ניתן לעשות זאת.</p>
-
-<p>כמו במאמרים קודמים, אנחנו נלמד על הבסיס של מערכים באמצעות שימוש ב<a href="/en-US/docs/Learn/Common_questions/What_are_browser_developer_tools">קונסולה</a>.</p>
-
-<h3 id="יצירת_מערכים">יצירת מערכים</h3>
-
-<p>מערכים כוללים סוגריים מרובעות <code>[]</code> וכל איבר (אלמנט) במערך מופרד מאיבר אחר על ידי פסיק <code>,</code>.</p>
-
-<ol>
- <li>נניח ואנחנו רוצים לאחסן רשימת פריטים בתוך מערך. הכניסו את הקוד הבא לקונסולה:
- <pre class="brush: js">let shopping = ['bread', 'milk', 'cheese', 'hummus', 'noodles'];
-shopping;</pre>
- </li>
- <li>בדוגמא למעלה, כל איבר הוא מחרוזת, אך ניתן לאחסן כל מיני סוגי ערכים בתוך מערכים - מחרוזות, מספרים, אובייקטים ואפילו מערכים נוספים. לדוגמא:
- <pre class="brush: js">let sequence = [1, 1, 2, 3, 5, 8, 13];
-let random = ['tree', 795, [0, 1, 2]];</pre>
- </li>
- <li>לפני שתמשיכו, נסו ליצור מספר מערכים וחקרו את האפשרויות השונות.</li>
-</ol>
-
-<h3 id="גישה_לאיברי_המערך_ושינוי_שלהם">גישה לאיברי המערך ושינוי שלהם</h3>
-
-<p>אנחנו יכולים לגשת לכל איבר במערך על ידי שימוש בסוגריים המרובעות <code>[]</code> בדיוק כפי שאנו <a href="/he/Learn/JavaScript/First_steps/Useful_string_methods#Retrieving_a_specific_string_character">ניגשים לתווים במחרוזת</a>.</p>
-
-<ol>
- <li>הכניסו את הקוד הבא לקונסולה:
- <pre class="brush: js">shopping[0];
-// returns "bread"</pre>
- </li>
- <li>אנחנו גם יכולים לשנות איבר במערך באמצעות מתן ערך חדש לאותו איבר במערך. ראו לדוגמא:
- <pre class="brush: js">shopping[0] = 'tahini';
-shopping;
-// shopping will now return [ "tahini", "milk", "cheese", "hummus", "noodles" ]</pre>
-
- <div class="note"><strong>להזכירכם</strong>: מחשבים מתחילים לספור מ-0 ולא מ-1. בדיוק כמו במחרוזות, כך גם במערכים.</div>
- </li>
- <li>שימו לב שמערך בתוך מערך נקרא <strong>מערך רב מימדי</strong>. אנחנו יכולים לגשת לאיבר שנמצא בתוך מערך מסויים, כאשר המערך הזה נמצא בתוך מערך באמצעות <strong>שרשור</strong> של שתי סוגריים מרובעות ביחד. לדוגמא, על מנת לגשת לאיבר במערך שהוא האיבר השלישי במערך המשורשר והמערך המשורשר הוא האיבר השלישי במערך הראשי בשם <code>random</code>, אנו נצטרך לרשום זאת בצורה הבאה:
- <pre class="brush: js">random[2][2];</pre>
- </li>
- <li>נסו לעשות כמה פעולות ושינויים בעצמכם על מנת להבין את הדרך שבה אנו ניגשים לאיברים במערך.</li>
-</ol>
-
-<h3 id="מציאת_האורך_של_מערך">מציאת האורך של מערך</h3>
-
-<p>מציאת האורך של מערך - כלומר כמה איברים יש לו - מתבצעת בדיוק באותה דרך שבה אנחנו מוצאים את מספר התווים במחרוזת - באמצעות המאפיין {{jsxref("Array.prototype.length","length")}}.</p>
-
-<p>נסו להזין את הקוד הבא:</p>
-
-<pre class="brush: js">sequence.length;
-// should return 7</pre>
-
-<p>מאפיין <code>length</code>  גם ישמש אותנו לצורך מעבר על איברי המערך באמצעות לולאת <code>for</code> וביצוע פעולות כלשהן שנבחר על כל איבר ואיבר, כך שהלולאה תעבור על כל איברי המערך. לדוגמא:</p>
-
-<pre class="brush: js">let sequence = [1, 1, 2, 3, 5, 8, 13];
-for (let i = 0; i &lt; sequence.length; i++) {
- console.log(sequence[i]);
-}</pre>
-
-<p>אנחנו נלמד יותר לעומק על לולאות במאמרים הבאים, אך בהסבר פשוט, הקוד הנוכחי אומר את הדברים הבאים:</p>
-
-<ol>
- <li>הרצת הקוד שנמצא בין הסוגריים המסולסלות <code>{}</code> על כל איבר במערך החל מהאיבר הראשון במערך (אשר נמצא במיקום 0 כמובן). את מספר המיקום של האיבר במערך אותו אנו מייצגים באמצעות המשתנה <font face="consolas, Liberation Mono, courier, monospace"><span style="background-color: rgba(220, 220, 220, 0.498039);">i</span></font>.</li>
- <li>הרצת הלולאה מסוג <code>for</code> כל עוד מיקומו של האיבר במערך (שכאמור מיוצג בכל ריצה על ידי המשתנה <code>i</code>) קטן מסך כל האיברים במערך. כלומר, במקרה זה הקוד בתוך הסוגריים המסולסלות <code>{}</code> לא ירוץ כאשר המשתנה <font face="consolas, Liberation Mono, courier, monospace"><span style="background-color: rgba(220, 220, 220, 0.498039);">i</span></font> יהיה שווה ל-7. (להזכירכם - אמנם יש שבעה איברים במערך, אך הספירה שלהם מתחילה ב-0, ולכן האיבר השביעי במערך, יהיה במיקום/אינדקס השישי וזו הסיבה שהשתמשנו בסימן קטן מאורך המערך (<code>&gt;</code>) ולא שווה לאורך המערך (<code>=</code>) שכן אז היינו מקבלים במיקום השביעי את הערך undefiened.</li>
- <li>בתוך הסוגריים המסולסלות, רשמנו את הקוד שאנחנו רוצים שיבוצע במסגרת כל ריצה של הלולאה. במקרה הזה, הדפסנו לקונסולה את הערך הנוכחי של האיבר שעליו רצה הלולאה באותה ריצה. לצורך הדפסה לקונסולה עשינו שימוש ב-<code><a href="/en-US/docs/Web/API/Console/log">()console.log</a></code>.</li>
-</ol>
-
-<h2 id="מס׳_מתודות_שימושיות_של_מערכים">מס׳ מתודות שימושיות של מערכים</h2>
-
-<p>בחלק זה אנחנו נסתכל על מתודות שימושיות של מערכים או מתודות שימושיות הקשורות למערכים, המאפשרות לנו להפוך מחרוזת למערך ומערך למחרוזת ונלמד כיצד להכניס איברים נוספים לתוך מערכים או להסיר איברים ממערך. </p>
-
-<h3 id="המרה_בין_מחרוזות_ומערכים">המרה בין מחרוזות ומערכים</h3>
-
-<p>הרבה פעמים אנחנו נקבל מידע גולמי אשר נמצא במחרוזת ארוכה ונרצה להפריד אותו לפריטי מידע אשר עמם נוכל לעשות שימוש באמצעות המרתה של המחרוזת למבנה אחר.</p>
-
-<p>על מנת לעשות זאת, אנחנו נעשה שימוש במתודה {{jsxref("String.prototype.split()","split()")}}. מתודה זו ממירה מחרוזת למערך ומקבלת פרמטר אחד - התו שהמתודה תחפש בתוך המחרוזת שנרצה להמיר למערך וכאשר היא תמצא את אותו תו בכל פעם, היא תפריד בין החלק במחרוזת שנמצא לפני תו זה לבין החלק במחרוזת שנמצא אחריו, וכך היא בעצם מחלקת את המחרוזת לאיברים במערך. התוצאה של מתודה זו מערך שהאיברים שלו הם המחרוזות משנה שהופרדו.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: מבחינה טכנית זוהי מתודה של מחרוזות ולא מתודה של מערכים.</p>
-</div>
-
-<ol>
- <li>בואו ננסה להבין כיצד מתודה הזו עובדת: צרו מחרוזת בקונסולה כגון זו:
- <pre class="brush: js">let myData = 'Manchester,London,Liverpool,Birmingham,Leeds,Carlisle';</pre>
- </li>
- <li>עכשיו הפרידו בין התווים במחרוזת באמצעות המתודה {{jsxref("String.prototype.split()","split()")}} כך שכל פעם שיופיע התו <code>,</code> תבוצע העברה של התווים שלפניו לאיבר חדש במערך שנקרא <code>myArray</code>:
- <pre class="brush: js">let myArray = myData.split(',');
-myArray;</pre>
- </li>
- <li>נסו למצוא את האורך של המערך החדש וכן לקבל את הערך של חלק מהאיברים שלו:
- <pre class="brush: js">myArray.length;
-myArray[0]; // the first item in the array
-myArray[1]; // the second item in the array
-myArray[myArray.length-1]; // the last item in the array</pre>
- </li>
- <li>ניתן כמובן גם <strong>להמיר מערך למחרוזת</strong> באמצעות שימוש במתודה {{jsxref("Array.prototype.join()","join()")}}. נסו את הקוד הבא:
- <pre class="brush: js">let myNewString = myArray.join(',');
-myNewString;</pre>
- </li>
- <li>דרך נוספת של <strong>המרת</strong> <strong>מערך למחרוזת</strong> נוכל לעשות באמצעות שימוש במתודה {{jsxref("Array.prototype.toString()","toString()")}}.</li>
- <li>המתודה <code>()toString</code> הרבה יותר פשוטה מאשר <code>()join</code> שכן היא לא מקבלת שום פרמטר/ארגומנט, אך יש לה מספר הגבלות. עם המתודה <code>()join</code> אנחנו יכולים להגדיר איזה תו אנחנו נרצה שיפריד בין התווים במחרוזת. נסו לדוגמא להריץ שוב את שורה מספר 4, אך עם תו מפריד אחד כמו <code>/</code> או <code>-</code>.
- <pre class="brush: js">let dogNames = ['Rocket','Flash','Bella','Slugger'];
-dogNames.toString(); //Rocket,Flash,Bella,Slugger</pre>
- </li>
-</ol>
-
-<h3 id="הוספה_והסרה_של_איברים_במערך">הוספה והסרה של איברים במערך</h3>
-
-<p>בחלק זה נלמד כיצד להוסיף ולהסיר איברים במערך. אנו נעשה שימוש במערך <code>myArray</code> שהוגדר למעלה. לנוחיותכם, הנה הוא שוב:</p>
-
-<pre class="brush: js">let myArray = ['Manchester', 'London', 'Liverpool', 'Birmingham', 'Leeds', 'Carlisle'];</pre>
-
-<p>על מנת להוסיף איבר לסוף של מערך אנחנו משתמשים במתודות {{jsxref("Array.prototype.push()","push()")}} ובמתודה {{jsxref("Array.prototype.pop()","pop()")}} להסיר איבר מסוף המערך.</p>
-
-<ol>
- <li>ננסה תחילה את המתודה <code>()push</code> — שימו לב שאנחנו צריכים לכלול איבר אחד או יותר כארגומנט/פרמטר למתודה זו, אשר אותו נרצה להכניס לסוף המערך:
-
- <pre class="brush: js">myArray.push('Cardiff');
-myArray;
-myArray.push('Bradford', 'Brighton');
-myArray;
-</pre>
- </li>
- <li>כשאנו מבצעים את המתודה הזו, אנו מקבלים כערך מוחזר את ה-<code>length</code> החדש של המערך, לאחר ההוספה. אם נרצה לשמור את ה-<code>length</code> החדש, אנחנו נצטרך לשמור אותו במשתנה חדש:
- <pre class="brush: js">let newLength = myArray.push('Bristol');
-myArray;
-newLength;</pre>
- </li>
- <li>הסרה של האיבר האחרון במערך מתבצע באמצעות המתודה <code>()pop</code> על המערך. נסו את הקוד הבא:
- <pre class="brush: js">myArray.pop();</pre>
- </li>
- <li>האיבר האחרון במערך הוסר, ו<strong>הערך המוחזר של המתודה זו היא האיבר האחרון שהוסר</strong>. על מנת לשמור את האיבר הזה במשתנה חדש, ניתן לרשום את הקוד הבא:
- <pre class="brush: js">let removedItem = myArray.pop();
-myArray;
-removedItem;</pre>
- </li>
-</ol>
-
-<p>{{jsxref("Array.prototype.unshift()","unshift()")}} וכן {{jsxref("Array.prototype.shift()","shift()")}} עובדות בדיוק אותו הדבר כמו ש-<code>()push</code> ו- <code>()pop</code>, בהתאמה, למעט העבודה שהן מוסיפות/מסירות איברים מ<strong>תחילת המערך ולא מסופו</strong>.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>:{{jsxref("Array.prototype.push()","push()")}} ו- {{jsxref("Array.prototype.pop()","pop()")}} המתודות <strong>משנות</strong> את מערך המקור.</p>
-</div>
-
-<ol>
- <li>מתודת <code>()unshift</code> — הזינו את הקוד הבא לקונסולה:
-
- <pre class="brush: js">myArray.unshift('Edinburgh');
-myArray;</pre>
- </li>
- <li>מתודת <code>()shift</code>— הזינו את הקוד הבא לקונסולה:
- <pre class="brush: js">let removedItem = myArray.shift();
-myArray;
-removedItem;</pre>
- </li>
-</ol>
-
-<h2 id="תרגול_עצמאי_הדפסת_המוצרים">תרגול עצמאי : הדפסת המוצרים</h2>
-
-<p>נחזור לדוגמא שנתנו בתחילת המאמר - הדפסת שמות המוצרים והמחירים שלהם על חשבונית, וכן חישוב של המחירים שלהם בתחתית החשבונית. בדוגמא הבאה יש שורות עם הערות המכילות מספרים (לדוגמא: <code>number 1</code>). כל שורה שכזו נועדה לציין בפניכם את המיקום שבו תצטרכו להוסיף קוד לקוד הקיים:</p>
-
-<ol>
- <li>מתחת להערה <code>number 1 //</code> יש מספר של מחרוזות, כאשר כל אחת כוללת שם של מוצר והמחיר שלו, מופרדים על ידי הסימן <code>;</code>. אנו נרצה שתהפכו את המחרוזות הללו למערך ותאחסנו אותו במשתנה שנקרא <code>products</code>.</li>
- <li>בשורה שבה נמצאת העקב <code>number 2 //</code> נמצאת לולאת ה-for שלנו. בשורה זו יש כרגע <code>i &lt;= 0</code>, שזהו מבחן תנאי אשר גורם ל-<a href="/he/Learn/JavaScript/First_steps/A_first_splash#Loops">for loop</a> לרוץ רק פעם אחת, מכיוון שבפועל הוא ״תפסיק לרוץ כאשר <code>i</code> לא קטן יותר או שווה ל-0״, ו-<code>i</code> מתחיל ב-0. אנו נרצה שתחליפו את התנאי זה בקוד אחר כך שהלולאה תפסיק לרוץ כאשר <code>i</code> לא יהיה קטן יותר מהאורך של <code>products</code>.</li>
- <li>מתחת להערה <code>number 3 //</code> אנו רוצים שתכתבו קוד שמפצל את האיבר הנוכחי במערך (<code>name:price</code>) ל-2 איברים נפרדים - אחד כולל את שם הפריט ואחד הכולל את מחירו. אם אתם לא בטוחים איך לבצע זאת, ראו <a href="/he/docs/Learn/JavaScript/First_steps/Useful_string_methods">מתודות שימושיות של מחרוזות</a> והעמיקו בחלק {{anch("המרה בין מחרוזות ומערכים")}} של מאמר זה.</li>
- <li>כחלק מהקוד למעלה, אולי גם נרצה להמיר את המחירים ממחרוזת למספר. אם אתם לא זוכרים כיצד לבצע זאת, קיראו את המאמר הבא, בחלק של <a href="/he/Learn/JavaScript/First_steps/Strings#Numbers_versus_strings">״מספרים מול מחרוזות״</a>.</li>
- <li>בראשית הקוד הנוכחי קיים משתנה שנקרא <code>total</code> אשר הוצהר והושם לו ערך של 0. בתוך הלולאה (מתחת <code>number 4 //</code>) אנו נרצה שתוסיפו שורת קוד שמוסיפה את האיבר שמייצג את המחיר הנוכחי למשתנה <code>total</code> בכל ריצה של הלולאה, כך שבסוף, המחיר הכולל (<code>total</code>)יודפס לחשבונית. אולי תרצו לחזור ולעיין ב-<a href="/he/Learn/JavaScript/First_steps/Math#Assignment_operators">אופרטורים להשמה</a> על מנת לעשות זאת.</li>
- <li>בנוסף, נרצה שתשנו את השורה שמתחת להערה <code>// number 5</code><code>//</code> כך שהמשתנה <code>itemText</code> יהיה בצורת כתיבה הזו לכל איבר ל-"<em>current item name — $current item price</em>", לדוגמא: "Shoes — $23.99" , כך שהמידע יוצג בתצורה הזו על גבי החשבונית. שימו לב שמדובר באיחוד של מחרוזות, לא משהו מורכב מדי שלא למדנו כבר.</li>
-</ol>
-
-<div class="hidden">
-<h6 id="Playable_code">Playable code</h6>
-
-<pre class="brush: html">&lt;h2&gt;Live output&lt;/h2&gt;
-
-&lt;div class="output" style="min-height: 150px;"&gt;
-
-&lt;ul&gt;
-
-&lt;/ul&gt;
-
-&lt;p&gt;&lt;/p&gt;
-
-&lt;/div&gt;
-
-&lt;h2&gt;Editable code&lt;/h2&gt;
-
-&lt;p class="a11y-label"&gt;Press Esc to move focus away from the code area (Tab inserts a tab character).&lt;/p&gt;
-
-&lt;textarea id="code" class="playable-code" style="height: 410px;width: 95%"&gt;
-var list = document.querySelector('.output ul');
-var totalBox = document.querySelector('.output p');
-var total = 0;
-list.innerHTML = '';
-totalBox.textContent = '';
-// number 1
- 'Underpants:6.99'
- 'Socks:5.99'
- 'T-shirt:14.99'
- 'Trousers:31.99'
- 'Shoes:23.99';
-
-for (var i = 0; i &lt;= 0; i++) { // number 2
- // number 3
-
- // number 4
-
- // number 5
- itemText = 0;
-
- var listItem = document.createElement('li');
- listItem.textContent = itemText;
- list.appendChild(listItem);
-}
-
-totalBox.textContent = 'Total: $' + total.toFixed(2);
-&lt;/textarea&gt;
-
-&lt;div class="playable-buttons"&gt;
- &lt;input id="reset" type="button" value="Reset"&gt;
- &lt;input id="solution" type="button" value="Show solution"&gt;
-&lt;/div&gt;
-</pre>
-
-<pre class="brush: js">var textarea = document.getElementById('code');
-var reset = document.getElementById('reset');
-var solution = document.getElementById('solution');
-var code = textarea.value;
-var userEntry = textarea.value;
-
-function updateCode() {
- eval(textarea.value);
-}
-
-reset.addEventListener('click', function() {
- textarea.value = code;
- userEntry = textarea.value;
- solutionEntry = jsSolution;
- solution.value = 'Show solution';
- updateCode();
-});
-
-solution.addEventListener('click', function() {
- if(solution.value === 'Show solution') {
- textarea.value = solutionEntry;
- solution.value = 'Hide solution';
- } else {
- textarea.value = userEntry;
- solution.value = 'Show solution';
- }
- updateCode();
-});
-
-var jsSolution = 'var list = document.querySelector(\'.output ul\');\nvar totalBox = document.querySelector(\'.output p\');\nvar total = 0;\nlist.innerHTML = \'\';\ntotalBox.textContent = \'\';\n\nvar products = [\'Underpants:6.99\',\n \'Socks:5.99\',\n \'T-shirt:14.99\',\n \'Trousers:31.99\',\n \'Shoes:23.99\'];\n\nfor(var i = 0; i &lt; products.length; i++) {\n var subArray = products[i].split(\':\');\n var name = subArray[0];\n var price = Number(subArray[1]);\n total += price;\n itemText = name + \' — $\' + price;\n\n var listItem = document.createElement(\'li\');\n listItem.textContent = itemText;\n list.appendChild(listItem);\n}\n\ntotalBox.textContent = \'Total: $\' + total.toFixed(2);';
-var solutionEntry = jsSolution;
-
-textarea.addEventListener('input', updateCode);
-window.addEventListener('load', updateCode);
-
-// stop tab key tabbing out of textarea and
-// make it write a tab at the caret position instead
-
-textarea.onkeydown = function(e){
- if (e.keyCode === 9) {
- e.preventDefault();
- insertAtCaret('\t');
- }
-
-
- if (e.keyCode === 27) {
- textarea.blur();
- }
-};
-
-function insertAtCaret(text) {
- var scrollPos = textarea.scrollTop;
- var caretPos = textarea.selectionStart;
-
- var front = (textarea.value).substring(0, caretPos);
- var back = (textarea.value).substring(textarea.selectionEnd, textarea.value.length);
- textarea.value = front + text + back;
- caretPos = caretPos + text.length;
- textarea.selectionStart = caretPos;
- textarea.selectionEnd = caretPos;
- textarea.focus();
- textarea.scrollTop = scrollPos;
-}
-
-// Update the saved userCode every time the user updates the text area code
-
-textarea.onkeyup = function(){
- // We only want to save the state when the user code is being shown,
- // not the solution, so that solution is not saved over the user code
- if(solution.value === 'Show solution') {
- userEntry = textarea.value;
- } else {
- solutionEntry = textarea.value;
- }
-
- updateCode();
-};</pre>
-
-<pre class="brush: css">html {
- font-family: sans-serif;
-}
-
-h2 {
- font-size: 16px;
-}
-
-.a11y-label {
- margin: 0;
- text-align: right;
- font-size: 0.7rem;
- width: 98%;
-}
-
-body {
- margin: 10px;
- background-color: #f5f9fa;
-}</pre>
-</div>
-
-<p>{{ EmbedLiveSample('Playable_code', '100%', 730, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<h2 id="למידה_עצמאית_5_החיפושים_האחרונים">למידה עצמאית: 5 החיפושים האחרונים</h2>
-
-<p>שימוש נפוץ שאנחנו עושים במתודות של מערכים כמו {{jsxref("Array.prototype.push()","push()")}} ו- {{jsxref("Array.prototype.pop()","pop()")}} הוא כאשר אנחנו שומרים רישום של מספר פריטים מסויימים כגון עשרת החיפושים האחרונים שביצע המשתמש או כאשר אנחנו משתמשים באנימציה המציגה כמות מסויימת של פריטים המוצגים על גבי המסך המתחלפים ביניהם, כך שכל פעם יהיה רק מספר מסויים של פריטים. בדוגמאות אלו אובייקטים חדשים נוצרים ומתווספים למערך ואילו ישנים נמחקים על מנת לשמור על המספר שרצינו.</p>
-
-<p>בדוגמאות הבאות אנחנו הולכים לעשות שימוש פשוט יחסית במתודות אלו - יש לנו אתר עם תיבת חיפוש. הרעיון הוא שכאשר ערכים מוכנסים לתיבת החיפוש, חמשת החיפושים הקודמים מוצגים ברשימה. כאשר כמות החיפושים הקודמים עולה על חמש, החיפוש הקודם ביותר נמחק מהרשימה ובמקומו נכנס החיפוש האחרון ביותר בתחילת הרשימה, כך שתמיד יוצגו לנו חמשת החיפושים האחרונים.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: ביישום חיפוש אמיתי, יתאפשר לנו רוב הסיכויים ללחוץ על החיפושים הקודמים ולחזור לאותם חיפושים. בדוגמא הבא נרצה להשאיר את הנושא פשוט.</p>
-</div>
-
-<p>על מנת להשלים את המשימה, הנכם נדרשים:</p>
-
-<ol>
- <li>להוסיף שורת מתחת להערה <code>number 1//</code> שמוסיפה את הערך הנוכחי שהוזן לתיבת החיפוש לתוך תחילת המערך. ניתן למצוא את הערך שהוזן לתיבת החיפוש באמצעות <code>searchInput.value</code>.</li>
- <li>הוסיפו מתחת להערה <code>number 2</code><code>//</code> שורת קוד שמסירה את הערך שנמצא כרגע בסוף המערך.</li>
-</ol>
-
-<div class="hidden">
-<h6 id="Playable_code_2">Playable code 2</h6>
-
-<pre class="brush: html">&lt;h2&gt;Live output&lt;/h2&gt;
-&lt;div class="output" style="min-height: 150px;"&gt;
-
-&lt;input type="text"&gt;&lt;button&gt;Search&lt;/button&gt;
-
-&lt;ul&gt;
-
-&lt;/ul&gt;
-
-&lt;/div&gt;
-
-&lt;h2&gt;Editable code&lt;/h2&gt;
-
-&lt;p class="a11y-label"&gt;Press Esc to move focus away from the code area (Tab inserts a tab character).&lt;/p&gt;
-
-
-&lt;textarea id="code" class="playable-code" style="height: 370px; width: 95%"&gt;
-var list = document.querySelector('.output ul');
-var searchInput = document.querySelector('.output input');
-var searchBtn = document.querySelector('.output button');
-
-list.innerHTML = '';
-
-var myHistory = [];
-
-searchBtn.onclick = function() {
- // we will only allow a term to be entered if the search input isn't empty
- if (searchInput.value !== '') {
- // number 1
-
- // empty the list so that we don't display duplicate entries
- // the display is regenerated every time a search term is entered.
- list.innerHTML = '';
-
- // loop through the array, and display all the search terms in the list
- for (var i = 0; i &lt; myHistory.length; i++) {
- itemText = myHistory[i];
- var listItem = document.createElement('li');
- listItem.textContent = itemText;
- list.appendChild(listItem);
- }
-
- // If the array length is 5 or more, remove the oldest search term
- if (myHistory.length &gt;= 5) {
- // number 2
-
- }
-
- // empty the search input and focus it, ready for the next term to be entered
- searchInput.value = '';
- searchInput.focus();
- }
-}
-&lt;/textarea&gt;
-
-&lt;div class="playable-buttons"&gt;
- &lt;input id="reset" type="button" value="Reset"&gt;
- &lt;input id="solution" type="button" value="Show solution"&gt;
-&lt;/div&gt;</pre>
-
-<pre class="brush: css">html {
- font-family: sans-serif;
-}
-
-h2 {
- font-size: 16px;
-}
-
-.a11y-label {
- margin: 0;
- text-align: right;
- font-size: 0.7rem;
- width: 98%;
-}
-
-body {
- margin: 10px;
- background: #f5f9fa;
-}</pre>
-
-<pre class="brush: js">var textarea = document.getElementById('code');
-var reset = document.getElementById('reset');
-var solution = document.getElementById('solution');
-var code = textarea.value;
-var userEntry = textarea.value;
-
-function updateCode() {
- eval(textarea.value);
-}
-
-reset.addEventListener('click', function() {
- textarea.value = code;
- userEntry = textarea.value;
- solutionEntry = jsSolution;
- solution.value = 'Show solution';
- updateCode();
-});
-
-solution.addEventListener('click', function() {
- if(solution.value === 'Show solution') {
- textarea.value = solutionEntry;
- solution.value = 'Hide solution';
- } else {
- textarea.value = userEntry;
- solution.value = 'Show solution';
- }
- updateCode();
-});
-
-var jsSolution = 'var list = document.querySelector(\'.output ul\');\nvar searchInput = document.querySelector(\'.output input\');\nvar searchBtn = document.querySelector(\'.output button\');\n\nlist.innerHTML = \'\';\n\nvar myHistory= [];\n\nsearchBtn.onclick = function() {\n if(searchInput.value !== \'\') {\n myHistory.unshift(searchInput.value);\n\n list.innerHTML = \'\';\n\n for(var i = 0; i &lt; myHistory.length; i++) {\n itemText = myHistory[i];\n var listItem = document.createElement(\'li\');\n listItem.textContent = itemText;\n list.appendChild(listItem);\n }\n\n if(myHistory.length &gt;= 5) {\n myHistory.pop();\n }\n\n searchInput.value = \'\';\n searchInput.focus();\n }\n}';
-var solutionEntry = jsSolution;
-
-textarea.addEventListener('input', updateCode);
-window.addEventListener('load', updateCode);
-
-// stop tab key tabbing out of textarea and
-// make it write a tab at the caret position instead
-
-textarea.onkeydown = function(e){
- if (e.keyCode === 9) {
- e.preventDefault();
- insertAtCaret('\t');
- }
-
- if (e.keyCode === 27) {
- textarea.blur();
- }
-};
-
-function insertAtCaret(text) {
- var scrollPos = textarea.scrollTop;
- var caretPos = textarea.selectionStart;
-
- var front = (textarea.value).substring(0, caretPos);
- var back = (textarea.value).substring(textarea.selectionEnd, textarea.value.length);
- textarea.value = front + text + back;
- caretPos = caretPos + text.length;
- textarea.selectionStart = caretPos;
- textarea.selectionEnd = caretPos;
- textarea.focus();
- textarea.scrollTop = scrollPos;
-}
-
-// Update the saved userCode every time the user updates the text area code
-
-textarea.onkeyup = function(){
- // We only want to save the state when the user code is being shown,
- // not the solution, so that solution is not saved over the user code
- if(solution.value === 'Show solution') {
- userEntry = textarea.value;
- } else {
- solutionEntry = textarea.value;
- }
-
- updateCode();
-};</pre>
-</div>
-
-<p>{{ EmbedLiveSample('Playable_code_2', '100%', 700, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>לאחר קריאה של מאמר זה, אתם ככל הנראה מבינים כמה מערכים הם שימושים עבורנו. אנחנו נראה אותם לאורך כל הדרך, בדרך כלל בצירוף לולאת <code>for</code> על מנת לבצע פעולה כלשהו על כל איבר במערך. אנחנו נלמד במודול הבא את הדברים השימושיים והבסיסיים שניתן לבצע עם לולאות מסוגים שונים, וביניהן לולאות <code>for</code>.</p>
-
-<p>כעת, בצעו את התרגול הנמצא במאמר הבא, המרכז את מרבית הנושאים שלמדנו במודול זה.</p>
-
-<h2 id="ראו_גם">ראו גם</h2>
-
-<ul>
- <li><a href="/en-US/docs/Web/JavaScript/Guide/Indexed_collections">Indexed collections</a> — מדריך מתקדם למערכים ודומיהם - כמו מערכים (typed arrays).</li>
- <li>{{jsxref("Array")}} — דף ההסבר המורחב באתר זה בנושא <code>Array</code> — להעמקה נוספת ולהסברים נוספים בנושא המאפיינים של מערכים.</li>
-</ul>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/First_steps/Useful_string_methods", "Learn/JavaScript/First_steps/Silly_story_generator", "Learn/JavaScript/First_steps")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/What_is_JavaScript">מה זה JavaScript?</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/A_first_splash">מבט ראשון ל- JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/What_went_wrong">מה השתבש? פתרון בעיות ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Variables">אחסון המידע שאנחנו צריכים - משתנים — Variables</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Math">מתמתיקה בסיסית ב-  JavaScript — מספרים ואופרטורים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Strings">התמודדות עם טקסט — מחרוזות (Strings) ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Useful_string_methods">מתודות שימושיות למחרוזות</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Arrays">מערכים - Arrays</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Silly_story_generator">תרגיל: Silly story generator</a></li>
-</ul>
diff --git a/files/he/learn/javascript/first_steps/index.html b/files/he/learn/javascript/first_steps/index.html
deleted file mode 100644
index 1cccf0cf39..0000000000
--- a/files/he/learn/javascript/first_steps/index.html
+++ /dev/null
@@ -1,64 +0,0 @@
----
-title: צעדים ראשונים ב - JavaScript
-slug: Learn/JavaScript/First_steps
-tags:
- - JavaScript
- - אופרטורים
- - מאמר
- - מדריך
- - מודול
- - מחרוזות
- - מספרים
- - מערכים
- - משימה
- - משתנים
- - מתחילים
-translation_of: Learn/JavaScript/First_steps
----
-<div>{{LearnSidebar}}</div>
-
-<p class="summary">במודול JavaScript הראשון שלנו, אנחנו קודם כל נענה על כמה שאלות בסיסיות כמו "מהי JavaScript?", "איך היא ניראת?", ו"מה היא יכולה לעשות?", לפני שנתקדם לניסיון הפרקטי הראשון בכתיבת JavaScript. לאחר מכן נדון בכמה תכונות מפתח של JavaScript בפירוט, כגון משתנים, מחרוזות, מספרים ומערכים.</p>
-
-<h2 id="דרישות_מוקדמות">דרישות מוקדמות</h2>
-
-<p>לפני שנתחיל מודול זה, אינכם צריכים כל ידע מוקדם בJavaScript, אבל יש לכם צורך בהיכרות עם  HTML ו-CSS. מומלץ לעבור על המודולים הבאים לפני תחילת הלימוד אודות JavaScript:</p>
-
-<ul>
- <li><a href="https://developer.mozilla.org/he/docs/Learn/Getting_started_with_the_web">הכרות ראשונית עם הרשת</a> (שכולל בתוכו בצורה מינימלית <a href="/he/docs/Learn/Getting_started_with_the_web/JavaScript_basics">מבוא בסיסי לJavaScript</a>).</li>
- <li><a href="/he/docs/Learn/HTML/Introduction_to_HTML">מבוא -HTML</a>.</li>
- <li><a href="https://developer.mozilla.org/יק/docs/Learn/CSS/Introduction_to_CSS">מבוא ל-CSS</a>.</li>
-</ul>
-
-<div class="note">
-<p><strong>הערה</strong>: אם אתם עובדים על מחשב\טבלט\מכשיר אחר שאין לכם אפשרות ליצור עליו קבצים אישיים, אתם יכולים לנסות את (רוב) דוגמאות הקוד על תוכנות קוד אינטרנטיות כמו <a href="http://jsbin.com/">JSBin</a> או <a href="https://thimble.mozilla.org/">Thimble</a>.</p>
-</div>
-
-<h2 id="מדריכים">מדריכים</h2>
-
-<dl>
- <dt><a href="/he/docs/Learn/JavaScript/First_steps/What_is_JavaScript">מה זה JavaScript?</a></dt>
- <dd>ברוכים הבאים לקורס JavaScript למתחילים של MDN! במאמר ראשון זה אנו נסתכל על  JavaScript מלמעלה, ונענה על שאלות כמו "מה זה?", ו-"מה זה עושה?", ונדאג שתרגישו בנוח עם המטרה של JavaScript.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/First_steps/A_first_splash">צלילה ראשונית לתוך JavaScript</a></dt>
- <dd>לאחר שלמדתם משהו על התאוריה של JavaScript, ומה אתם יכולים לעשות איתה, נמשיך לקורס מזורז על הפיצ'רים הבסיסיים של JavaScript באמצעות הדרכה מעשית בלבד. כאן נבנה משחק "נחש את המספר" פשוט, צעד אחר צעד.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/First_steps/What_went_wrong">מה השתבש? פתרון בעיות ב-JavaScript</a></dt>
- <dd>כשבניתם את משחק ״נחש את המספר״ במאמר הקודם, בטח שמתם לב שהוא לא עבד. אל חשש - המאמר הנוכחי נועד לחסוך לך זמן בפתרון הבעיה ולהעניק לך כמה טיפים פשוטים איך למצוא ולתקן שגיאות בתוכניות JavaScript.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/First_steps/Variables">אחסון האינפורמציה שאתם צריכים — משתנים</a></dt>
- <dd>לאחר קריאת המאמרים הקודמים אתם אמורים לדעת מה היא JavaScript, מהם היכולות שלה, איך להשתמש בה לצד טכנולוגיות אינטרנט אחרות, ואיך ניראים הפיצ'רים הראשיים שלה במבט מלמעלה. במאמר זה נקבל את הבסיס האמיתי, בהתבוננות על איך לעבוד עם אבני הבנין הבסיסיות ביותר של JavaScript — המשתנים.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/First_steps/Math">מתמתיקה בסיסית ב-JavaScript - מספרים ואופרטורים</a></dt>
- <dd>בחלק הזה של הקורס, נדון במתמתיקה של JavaScript - כיצד אנו יכולים לצרף אופרטורים שונים ואפשרויות נוספות על מנת לבצע מניפולציות שונות על מספרים לצרכים שלנו.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/First_steps/Strings">התמודדות עם טקסט - מחרוזות ב-JavaScript.</a></dt>
- <dd>במאמר זה נתמקד במחרוזות - כך טקסט נקרא בתכנות. נסכתל על הדברים הבסיסיים שצריך לדעת על מחרוזות כשלומדים תכנות בשפת JavaScript, כמו יצירת מחרוזות, חיבור מחרוזות וכיוצ״ב.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/First_steps/Useful_string_methods">מתודות שימושיות של מחרוזות</a></dt>
- <dd>לאחר שלמדנו את הבסיס של מחרוזות, נלמד מס׳ פעולות שימושיות שאנחנו יכולים לבצע על המחרוזות באמצעות מתודות מובנות, כגון מציאת האורך של מחרוזת טקס, חיבור ופיצול של מחרוזות, הוצאת תו אחד מתוך מחרוזת ועוד.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/First_steps/Arrays">מערכים</a></dt>
- <dd>במאמר האחרון של מודול זה, נסתכל על מערכים - דרך מסודרת לאחסכן רשימה של פריטי מידע, תחת משתנה אחד. נבין מדוע שימוש במערך הוא שימושי מאוד, ולאחר מכן נבין כיצד ליצור מערך, לאחזר מערך, להוסיף או להסיר איברים ממערך ועוד. </dd>
-</dl>
-
-<h2 id="בוחנים">בוחנים</h2>
-
-<p>הבחנים הבאים יבדקו את ההבנה שלכם בבסיס של JavaScript כפי שנלמד במדריך.</p>
-
-<dl>
- <dt><a href="/he/docs/Learn/JavaScript/First_steps/Silly_story_generator">יישום אינטרנט ליצירת סיפורים טיפשיים</a></dt>
- <dd>במשימה זו אתם תתבקשו לקחת את הידע שלמדתם במאמרים של המודול הזה, ולממש אותם בכך שתיצרו יישום שמייצר סיפורים טיפשיים באופן אקראי. בהצלחה!.</dd>
-</dl>
diff --git a/files/he/learn/javascript/first_steps/math/index.html b/files/he/learn/javascript/first_steps/math/index.html
deleted file mode 100644
index e5c22c141f..0000000000
--- a/files/he/learn/javascript/first_steps/math/index.html
+++ /dev/null
@@ -1,427 +0,0 @@
----
-title: מתמתיקה בסיסית ב-JavaScript - מספרים ואופרטורים
-slug: Learn/JavaScript/First_steps/Math
-translation_of: Learn/JavaScript/First_steps/Math
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/First_steps/Variables", "Learn/JavaScript/First_steps/Strings", "Learn/JavaScript/First_steps")}}</div>
-
-<p class="summary">בשלב זה של הקורס, נדון קצת במתמתיקה שבשפת JavaScript - איך אנחנו יכולים להשתמש ב - {{Glossary("Operator","operators")}} ועוד אפשרויות על מנת להצליח לבצע מניפולציות וחישובים שונים על מספרים לצרכים שלנו</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>הבנה בסיסית של מחשב, הבנה בסיסית של  HTML, CSS ו - JavaScript.</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>הכרות עם שימוש במתמתיקה באופן בסיסי ב-JavaScript.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="כולנו_אוהבים_מתמטיקה">כולנו אוהבים מתמטיקה</h2>
-
-<p>האמת לא ממש. חלקנו כן וחלקנו ממש לא. אך לא ניתן להכחיש את העובדה שמתמטיקה היא נדבך חשוב בחיים ובתכנות בפרט. הרבה ממה שאנחנו עושים מתבסס על עיבוד מידע מספרי, חישוב ערכים חדשים וכד׳ ולכן לא נופתע לדעת של-JavaScript יש סט מלא של פונקציות מתמתיטקיות מובנה בה.</p>
-
-<p>מאמר זה ידון רק בחלקים הבסיסים שאנחנו צריכים לדעת כרגע.</p>
-
-<h3 id="סוגי_מספרים">סוגי מספרים</h3>
-
-<p>בתכנות, אפילו המספר העשרוני שאנחנו מכירים, הוא יותר מורכב ממה שנאחנו חושבים. אנחנו מתשמשים במושגים שונים על מנת לתאר סוגים שונים של מספרים עשרוניים. לדוגמא:</p>
-
-<ul>
- <li><strong>Integers- מספרים שלמים - </strong>10, 400,5.</li>
- <li><strong>Floating point numbers - מספרים עשרוניים - </strong>12.5, 56.7786543.</li>
- <li><strong>Doubles - </strong>אלו מספרים עשרוניים בעלי רמת דיוק גבוהה יותר ממספרים עשרוניים רגילים. </li>
-</ul>
-
-<p>יש לנו אפילו כמה מערכות של מספרים! לדוגמא, מערכת מספרים דצימלית היא מבוססת על בסיס 10, כלומר, היא עושה שימוש בספרות 0-9 בכל עמודה. אבל יש עוד. לדוגמא:</p>
-
-<ul>
- <li><strong>Binary</strong> — השפה הנמוכה של מחשבים; 0 ו- 1.</li>
- <li><strong>Octal</strong> — בסיס 8, משתמש ב- 0–7 בכל עמודה.</li>
- <li><strong>Hexadecimal</strong> — בסיס 16, משתמש ב- 0–9 ואז ב- a–f בכל עמודה. נתקלנו בזה ב-<a href="/en-US/Learn/CSS/Introduction_to_CSS/Values_and_units#Hexadecimal_values">צבעים ב-CSS</a>.</li>
-</ul>
-
-<p><strong>לפני שאתם מתחילים לחשוש ולהתבלבל, תנשמו. נדיר שנשתמש במספרים שאינם מספרים דצימליים.</strong></p>
-
-<p>חדשות טובות נוספות הן שלא כמו בשפות תכנות אחרות, לשפת JavaScript יש רק סוג מידע אחד עבודה מספרים - {{jsxref("Number")}}. כלומר, לא משנה איזה סוג מספרים אנחנו נקבל/נזין בקוד, אנחנו נטפל בו בדיוק באותה צורה.</p>
-
-<h3 id="זה_הכל_מספרים">זה הכל מספרים</h3>
-
-<p>בוא נשחק קצת עם המספרים ונבין את הסינטקס הבסיסי שנצטרך. הכניסו את הקוד הבא לקונסולה:</p>
-
-<ol>
- <li>קודם כל, נצהיר על שני משתנים ונשים בהם ערכים. לאחר מכן נזין את שמות המשתנים בקונסולה לוודא שהערכים הושמו כראוי:
- <pre class="brush: js">let myInt = 5;
-let myFloat = 6.667;
-myInt;
-myFloat;</pre>
- </li>
- <li>מספרים אלו בעצם ערכים שנרשמים ללא גרשיים - נסו להזין מספרים עטופים בגרשיים וראו מה קורה.</li>
- <li>בוא נבדוק האם הערכים השונים שהזנו הם מאותו סוג. האופרטור שבודק את זה הוא {{jsxref("Operators/typeof", "typeof")}}. רשמו את הקוד הבא מתחת לקוד הנוכחי:
- <pre class="brush: js">typeof myInt;
-typeof myFloat;</pre>
- אתם אמורים לקבל <code>"number"</code> בשני המקרים. ברור לנו שעיסוק בסוג מספר אחד הרבה יותר קל מאשר עם כמה סוגים.</li>
-</ol>
-
-<h2 id="Arithmetic_operators_-_אופרטורים_מתמתטיים">Arithmetic operators - אופרטורים מתמתטיים</h2>
-
-<p>אופרטורים מתמטיים הם האופרטורים הבסיסים שאנחנו משתמשים בהם על מנת לבצע חישובים:</p>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">אופרטור</th>
- <th scope="col">שם</th>
- <th scope="col">מטרה</th>
- <th scope="col">דוגמא</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td><code>+</code></td>
- <td>חיבור</td>
- <td>חיבור</td>
- <td><code>6 + 9</code></td>
- </tr>
- <tr>
- <td><code>-</code></td>
- <td>חיסור</td>
- <td>חיסור</td>
- <td><code>20 - 15</code></td>
- </tr>
- <tr>
- <td><code>*</code></td>
- <td>כפל</td>
- <td>כפל</td>
- <td><code>3 * 7</code></td>
- </tr>
- <tr>
- <td><code>/</code></td>
- <td>חילוק</td>
- <td>חילוק</td>
- <td><code>10 / 5</code></td>
- </tr>
- <tr>
- <td><code>%</code></td>
- <td>שארית</td>
- <td>
- <p>השארית מחלוקת שני מספרים</p>
- </td>
- <td>
- <p><code>8 % 3</code> (מחזיר 2, שכן 3 נכנס ב- 8 פעמיים, והשארית היא 2,).</p>
- </td>
- </tr>
- <tr>
- <td><code>**</code></td>
- <td>חזקה</td>
- <td>מכפיל את ה-<code>base</code> ב-<code>מעריך</code> , לדוגמא, המספר שיהיה נקוב ב- <code>base</code> עם המספר שיהיה נקוב ב- <code>מעריך</code> יגרום להכפלה של המספר שבבסיס כפול המספר שבמעריך. הוצג לראשונה ב- EcmaScript 2016.</td>
- <td><code>5 ** 5</code> (מחזיר <code>3125</code>, שזה זהה ל- <code>5 * 5 * 5 * 5 * 5</code>).</td>
- </tr>
- </tbody>
-</table>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: לפעמים ניתקל במספרים המעורבים בחישובים כ- {{Glossary("Operand", "operands")}}.</p>
-</div>
-
-<div class="blockIndicator note">
-<p><strong>לתשומת לבד</strong>: לפעמים אנחנו נראה שמשתמשים במתודה הישנה {{jsxref("Math.pow()")}} אשר פועלת בדרך דומה. לדוגמא, בקוד <code>Math.pow(7, 3)</code>, <code>7</code> הבסיס הוא 7 ו-3 הוא המעריך בחזקה, והתוצאה תהיה <code>343</code>. <code>Math.pow(7, 3)</code> is שזה שווה ל- <code>7**3</code>.</p>
-</div>
-
-<p>כנראה לא צריך ללמד אתכם מתמתיקה בסיסית, אבל אנו רוצים לוודא את ההבנה שלכם לגבי הסינטקס. נסו להכניס את הדוגמאות הבאות לקונסולה על מנת להכיר את הסינטקס.</p>
-
-<ol>
- <li>הכניסו דומאות פשוטות כמו:
- <pre class="brush: js">10 + 7
-9 * 8
-60 % 3</pre>
- </li>
- <li>אתם גם יכולים לנסות להצהיר על משתנים להשים להם מספרים כערכים, ונסו לעשות עליהם חישובים - המשתנים יתנהגו בדיוק כמו שיתנהגו הערכים שהם מחזיקים בהם. כך לדוגמא:
- <pre class="brush: js">let num1 = 10;
-let num2 = 50;
-9 * num1;
-num1 ** 3;
-num2 / num1;</pre>
- </li>
- <li>נסו להזין קצת ביטויים יותר מורכבים, כמו:
- <pre class="brush: js">5 + 10 * 3;
-num2 % 9 * num1;
-num2 + num1 / 8 + 2;</pre>
- </li>
-</ol>
-
-<p>כפי ששמתם לב, חלק מהחישובים שביצענו מחזירים לנו תוצאה בהתאם לכללי הקדימות המתמטיים:</p>
-
-<h3 id="סדר_עדיפות_אופרטורים">סדר עדיפות אופרטורים</h3>
-
-<p>אם נסתכל על הדוגמא למעלה, נניח ש- <code>num2</code> הוא 50 ו- <code>num1</code> הוא 10 :</p>
-
-<pre class="brush: js">num2 + num1 / 8 + 2;</pre>
-
-<p>בני אדם רגילים עלולים להניח ש- <em>"50 ועוד 10 שווה 60"</em>, ואז <em>"8 ועוד 2 שווה 10"</em>, ואז <em>"60 חלקי 10 שווה 6"</em>.</p>
-
-<p>אבל הדפדפן הולך לפי כללי החישוב המתמטים <em>"10 חלקי 8 שווה 1.25"</em>, ואז <em>"50 עוד 1.25 ועוד 2 שווה 53.25"</em>.</p>
-
-<p>זהו מה שנקרא <strong>סדר עדיפות בין אופרטורים</strong> — חלק מהאופרטורים יבוצעו או יחולו לפני אופרטורים אחרים כשהדפדפן ינסה לחשב את התוצאה של החישוב. סדר עדיפות בין אופרטורים בשפה הוא בהתאם למה שלמנו בשיעורי מתמתיקה - כפל וחילוק תמיד ראשונים, ואז חיבור וחיסור, כאשר החישוב מתבצע מצד שמאל לימין.</p>
-
-<p>אם נרצה לעקוף זאת, נצטרך לעשות שימוש בסוגריים רגילות סביב לחלקים שנרצה לבצע קודם. כך, על נת לקבל את התוצאה של 6, נצטרף לרשום את הקוד בצורה כזאת:</p>
-
-<pre class="brush: js">(num2 + num1) / (8 + 2);</pre>
-
-<p>נסו כדי לראות.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: רשימה מלאה של האופטורים ב- JavaScript וסדר העדיפות שלהם ניתן למצוא ב<a href="/en-US/docs/Web/JavaScript/Guide/Expressions_and_Operators#Operator_precedence">ביטויים ואופרטורים</a>.</p>
-</div>
-
-<h2 id="אופרטים_להעלאההורדה_-_Increment_and_decrement_operators">אופרטים להעלאה/הורדה - Increment and decrement operators</h2>
-
-<p>לפעמים אנחנו רוצים להוסיף לערך או להוריד ממנו מספר אחד. ניתן לבצע זאת בקלות באמצעות שימוש באופרטור (<code>++</code>) לצורך העלאה ב-1 ובאופרטור (<code>--</code>) לצורך הורדה ב-1. השתמשנו באופרטור <code>++</code> במשחק שלנו  "Guess the number" ב-<a href="/en-US/docs/Learn/JavaScript/Introduction_to_JavaScript_1/A_first_splash">מבט ראשוני ל- JavaScript</a> כאשר הוספנו אחד למשתנה <code>guessCount</code> על מנת לעקוב אחר מספר הניחושים שביצע המשתשמש.</p>
-
-<pre class="brush: js">guessCount++;</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אופרטורים אלו נמצאים בדרך כלל ב<a href="/en-US/docs/Web/JavaScript/Guide/Loops_and_iteration">לולאות</a>, עליהן נלמד בהמשך הקורס. לדוגמא, אם אנחנו רוצים לעבור על רשימה של מחירים, ולהוסיף מס על כל אחד מהם, אנחנו יכולים להשתמש בלולאה על מנת לעבור על כל ערך ברשימה, ולעשות את החישוב המתאים של הוספת מס. האופטרטור הוספה ישמש להעביר אותנו לערך הבא כשנצטרך. ראה לדוגמא כיצד זה מבוצע <a href="https://mdn.github.io/learning-area/javascript/introduction-to-js-1/maths/loop.html">בדף האינטרנט </a>וגם ב<a href="https://github.com/mdn/learning-area/blob/master/javascript/introduction-to-js-1/maths/loop.html">קוד המקור</a>. בדקו האם אתם מזהים את האופרטורים שמשמשים להוספה/הורדה בתוך הלולאה, נדון בהם בהמשך.</p>
-</div>
-
-<p>ננסה לשחק קצת בקונסולה. על מנת להתחיל, שימו לב שאתם לא יכול החיל אותם ישר על מספר כלשהו, למרות שזה נראה מוזר, אבל בפועל, כשאנחנו מעלים את הערך, אנחנו לא מבצעים חישוב כלשהו, אלא אנחנו משימים את החדש, לאחר החישוב, בתוך המשתנה. הפעולה הבאה תחזיר לדוגמא שגיאה:</p>
-
-<pre class="brush: js">3++;</pre>
-
-<p>כלומר, אנחנו יכולים רק להעלות משתנה קיים ב-1. נסו להזין את הקוד הבא:</p>
-
-<pre class="brush: js">let num1 = 4;
-num1++;</pre>
-
-<p>משהו מוזר נוסף. כשאנחנו עושים זאת, הערך 4 מוחזר לנו בקונסולה. זה מכיוון שהדפדפן מחזיר את הערך הנוכחי ורק אז מעלה את הערך של המשתנה. ניתן לראות שהערך של המשתנה הועלה ב-1 אם נזין שוב את השם של המשתנה בקונסולה.</p>
-
-<pre class="brush: js">num1;</pre>
-
-<p>אותו הדבר לגבי <code>--</code>  נסו את הקוד הבא:</p>
-
-<pre class="brush: js">let num2 = 6;
-num2--;
-num2;</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אנו יכולים לגרום לדפדפן לבצע זאת בצורה אחרת - כלומר, להעלות את המשתנה ב-1 ורק אז להחזיר לנו את הערך החדש של המשתנה באמצעות הוספת האופרטור <em> לפני</em> המשתנה ולא בסופו. נסו להזין את הקוד הבא <code>++num1</code> ואז <code>--num2</code>.</p>
-</div>
-
-<h2 id="Assignment_operators_-_אופרטורים_להשמה">Assignment operators - אופרטורים להשמה</h2>
-
-<p>אופרטורים להשמה אלו אופרטים שמשימים ערך לתוך משתנה. ראינו זאת עם הבסיסי שבה: <code>=</code>- הוא פשוט משים את הערך מצד שמאל, למשתנה שמצויין מצד ימין.</p>
-
-<pre class="brush: js">let x = 3; // x contains the value 3
-let y = 4; // y contains the value 4
-x = y; // x now contains the same value y contains, 4</pre>
-
-<p>אך יש כאלה מורכבים יותר, שיכולים לתת לנו קיצורי דרך על מנת לרשום את הקוד שלנו נקי ויעיל יותר. הנפוצים הם:</p>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">אופרטור</th>
- <th scope="col">שם</th>
- <th scope="col">מטרה</th>
- <th scope="col">דגומא</th>
- <th scope="col">קיצור עבור</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td><code>+=</code></td>
- <td>חיבור והשמה</td>
- <td>מוסיף את הערך מצד ימין לערך שבמשתנה מצד שמאל, ואז מחזיר את הערך של המשתנה החדש</td>
- <td><code>x = 3;<br>
- x += 4;</code></td>
- <td><code>x = 3;<br>
- x = x + 4;</code></td>
- </tr>
- <tr>
- <td><code>-=</code></td>
- <td>חיסור והשמה</td>
- <td>מחסיר את הערך מצד ימין מתוך הערך שנמצא בתוך המשתנה מצד שמאל, ואז מחזיר את הערך של המשתנה החדש</td>
- <td><code>x = 6;<br>
- x -= 3;</code></td>
- <td><code>x = 6;<br>
- x = x - 3;</code></td>
- </tr>
- <tr>
- <td><code>*=</code></td>
- <td>כפל והשמה</td>
- <td>מכפיל את הערך מצד ימין עם הערך שנמצא במשתנה מצד שמאל, ואז מחזיר את הערך של המשתנה החדש</td>
- <td><code>x = 2;<br>
- x *= 3;</code></td>
- <td><code>x = 2;<br>
- x = x * 3;</code></td>
- </tr>
- <tr>
- <td><code>/=</code></td>
- <td>חילוק והשמה</td>
- <td>מחלק את הערך מצד ימין בערך שנמצא במשתנה מצד שמאל, ואז מחזיר את הערך של המשתנה החדש</td>
- <td><code>x = 10;<br>
- x /= 5;</code></td>
- <td><code>x = 10;<br>
- x = x / 5;</code></td>
- </tr>
- </tbody>
-</table>
-
-<p>נסו להזין חלק מהדוגמאות הרשומות למעלה לתוך הקונסולה, על מנת להבין את הרעיון. בכל מקרה, נסו לראות אם אתם מצליחים לדעת מה הערך שיוחזר לפני החישוב וההשמה.</p>
-
-<p>כמובן שגם ניתן לבצע את החישובים וההשמות גם כאשר נמצאים משתנים משני צידי הסימן. לדוגמא:</p>
-
-<pre class="brush: js">let x = 3; // x contains the value 3
-let y = 4; // y contains the value 4
-x *= y; // x now contains the value 12</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: יש הרבה <a href="/en-US/docs/Web/JavaScript/Guide/Expressions_and_Operators#Assignment_operators">אופרטורים להשמה נוספים</a>, אבל אלו הבסיסיים שאתם צריכים לדעת לעת עתה.</p>
-</div>
-
-<h2 id="למידה_אקטיבית_שינוי_גודל_של_canvas_box">למידה אקטיבית: שינוי גודל של canvas box</h2>
-
-<p>בתרגיל זה נלמד כיצד לבצע מניפולציות על מספרים ואופרטורים, על מנת לשנות גודל של קופסא. הקופסא מצויירת באמצעות browser API אשר נקרא {{domxref("Canvas API", "", "", "true")}}. אין מה לדאוג לגבי איך הוא עובד, רק התרכזו בחישובים עצמם. הגובה והרוחב של הקופסא בפיקסלים יוגדרו על ידי המשתנים <code>x</code> ו- <code>y</code>, אשר קיבלו ערך התחלתי של 50.</p>
-
-<p>{{EmbedGHLiveSample("learning-area/javascript/introduction-to-js-1/maths/editable_canvas.html", '100%', 620)}}</p>
-
-<p><strong><a href="https://mdn.github.io/learning-area/javascript/introduction-to-js-1/maths/editable_canvas.html">Open in new window</a></strong></p>
-
-<p>בבריבוע למעלה יש שתי שורות שמסומנות עם הערה - אלו השורות שאתם צריכים לעדכן על מנת להגדיל/להקטין את הקופסא, באמצעות שימוש באופרטורים השונים ו/או ערכים שונים. נסו את הדברים הבאים:</p>
-
-<ul>
- <li>Change the line that calculates x so the box is still 50px wide, but the 50 is calculated using the numbers 43 and 7 and an arithmetic operator.</li>
- <li>Change the line that calculates y so the box is 75px high, but the 75 is calculated using the numbers 25 and 3 and an arithmetic operator.</li>
- <li>Change the line that calculates x so the box is 250px wide, but the 250 is calculated using two numbers and the remainder (modulo) operator.</li>
- <li>Change the line that calculates y so the box is 150px high, but the 150 is calculated using three numbers and the subtraction and division operators.</li>
- <li>Change the line that calculates x so the box is 200px wide, but the 200 is calculated using the number 4 and an assignment operator.</li>
- <li>Change the line that calculates y so the box is 200px high, but the 200 is calculated using the numbers 50 and 3, the multiplication operator, and the addition assignment operator.</li>
-</ul>
-
-<p>אל תדאגו אם אתם הורסים את הקוד לחלוטין. פשוט לחצו על הכפתור לאתחל את הכל.</p>
-
-<h2 id="Comparison_operators_-_אופרטורים_להשוואה">Comparison operators - אופרטורים להשוואה</h2>
-
-<p>לפעמים נרצה לבצע מבחני אמת/שקר, ואז להריץ פעולות מסוימות בהתאם לתוצאת המבחן - בשביל זה נועדו <strong>אופרטורים להשוואה</strong>.</p>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">אופרטור</th>
- <th scope="col">שם</th>
- <th scope="col">מטרה</th>
- <th scope="col">דוגמא</th>
- </tr>
- <tr>
- <td><code>===</code></td>
- <td>השוואה מוחלטת</td>
- <td>אופרטור זה בודק הא הערכים מצד ימין וצד שמאל זהים לחלוטין</td>
- <td><code>5 === 2 + 4</code></td>
- </tr>
- <tr>
- <td><code>!==</code></td>
- <td>שונים לחלוטין</td>
- <td>בודק האם הערך מצד ימין<strong>לא זהה</strong> לערך מצד שמאל</td>
- <td><code>5 !== 2 + 3</code></td>
- </tr>
- <tr>
- <td><code>&lt;</code></td>
- <td>קטן מ-</td>
- <td>בודק האם הערך בצד שמאל קטן מהערך בצד ימין.</td>
- <td><code>10 &lt; 6</code></td>
- </tr>
- <tr>
- <td><code>&gt;</code></td>
- <td>גדול מ-</td>
- <td>בודק האם הערך בצד שמאל גדול מהערך בצד ימין.</td>
- <td><code>10 &gt; 20</code></td>
- </tr>
- <tr>
- <td><code>&lt;=</code></td>
- <td>קטן מ- או שווה ל-</td>
- <td>בודק האם הערך בצד שמאל קטן מהערך בצד ימין או שווה לו.</td>
- <td><code>3 &lt;= 2</code></td>
- </tr>
- <tr>
- <td><code>&gt;=</code></td>
- <td>גדול מ- או שווה ל-</td>
- <td>בודק האם הערך בצד שמאל גדול מהערך בצד ימין או שווה לו.</td>
- <td><code>5 &gt;= 4</code></td>
- </tr>
- </thead>
-</table>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: לפעמים תראו אנשים שמשתמשים באופרטור <code>==</code> או <code>!=</code> במבחני בדיקת זהות/שונות שלהם. אלו אופרטורים תקינים לחלוטין בשפה, אבל הם שונים מ - <code>===</code>/<code>!==</code>. הראשונים מבצעים בדיקה האם הערכים בצד ימין ובצד שמאל זהים מבחינת הערך עצמו, אך ״אדישים״ לגבי הזהות מבחינת סוג הערך. ואילו האחרונים מבצעים בדיקה של זהות/שונות מוחלטת - גם ערכים וגם סוג הערך. שימוש בבדיקת זהות/שונות מוחלטת נוטה להציג פחות שגיאות, אז המלצתנו היא להשתמש בהם.</p>
-</div>
-
-<p>אם תנסו להכניס כמה מהערכים הללו לקונסולה את תראה בחזרה ערכי <code>true</code>/<code>false</code> - אלו ערכים בולאינים, כפי שהזכרנו במאמר קודם. ערכים אלו מאוד שימושיים מכיוון שהם מאפשרים לבצע החלטות בקוד שלנו, ואנחנו משתמשים בהם בכל פעם שאנרצה לקבל החלטה מסוג כלשהו. בוליאנים יכולים לשמש עבור:</p>
-
-<ul>
- <li>הצגת תיבת הטקסט הנכונה על גבי כפתור בהתאם לאפשרויות השונות.</li>
- <li>הצגת הודעה אם המשחק נגמר או שהמשתמש ניצח במשחק.</li>
- <li>הצגת הברכה המתאימה בהתאם לחג בתאריך מסויים.</li>
- <li>להתמקד במפה או להתרחק ממנה בהתאם לקוארדיניטות שהזין המשתמש.</li>
-</ul>
-
-<p>אנו נסתכל על דרך לכתוב קוד באמצעות שימוש בלוגיקה כשנלמד על משפטי תנאי במאמרים הבאים. לבינתיים, ראו דוגמא:</p>
-
-<pre class="brush: html">&lt;button&gt;Start machine&lt;/button&gt;
-&lt;p&gt;The machine is stopped.&lt;/p&gt;
-</pre>
-
-<pre class="brush: js">const btn = document.querySelector('button');
-const txt = document.querySelector('p');
-
-btn.addEventListener('click', updateBtn);
-
-function updateBtn() {
- if (btn.textContent === 'Start machine') {
- btn.textContent = 'Stop machine';
- txt.textContent = 'The machine has started!';
- } else {
- btn.textContent = 'Start machine';
- txt.textContent = 'The machine is stopped.';
- }
-}</pre>
-
-<p>{{EmbedGHLiveSample("learning-area/javascript/introduction-to-js-1/maths/conditional.html", '100%', 100)}}</p>
-
-<p><strong><a href="https://mdn.github.io/learning-area/javascript/introduction-to-js-1/maths/conditional.html">פתח בחלון חדש</a></strong></p>
-
-<p>אתם יכולים לראות את האופרטור להשוואה מתקיים בתוך פונקציית <code>()updateBtn</code> . במקרה זה, אנחנו לא בודקים האם שני ביטויים מתמידים הם בעלי ערך זהה, אלא אנחנו בודקים האם תוכן הטקסט של הכפתור כולל בתוכו מחרוזת מסויימת - אבל עדיין מדובר באותו עקרון שלמדנו עליו. אם הכפתור כולל בתוכו מחרוזת "Start machine" כשלוחצים עליו, אזי נשנה את השם שלו בהתאם. אם הוא כולל מחרוזת "Stop machine" אזי נבצע החלפה שוב.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אפשרות כזו להחליף בין שני מצבים נקראת <strong>toggle</strong>. הוא מחליף פשוט בין מצב אחד למצב שני.</p>
-</div>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>במאמר זה כיסינו את הידע החשוב והכרחי שאתם צריכים לדעת על מספרים בשפה. לבינתיים. אתם תראו מספרים דיי הרבה פעמים, לכל אורך הלימוד, אז זה רעיון טוב שתתחילו להתרגל אליהם ולהבין אותם. אל תפחדו מהם.</p>
-
-<p>במאמר הבא נבין איך השפה מאפשרת לנו לבצע מניפולציות שונות על מחרוזות וטקסטים ויצד נוכל לבצע בהם שימוש.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אם אתם מעוניינים להרחיב את הידיעות בנושא, ראו את הדפים שלנו בנושא  <a href="/en-US/docs/Web/JavaScript/Guide/Numbers_and_dates">Numbers and dates</a> ו-<a href="/en-US/docs/Web/JavaScript/Guide/Expressions_and_Operators">Expressions and operators</a>.</p>
-</div>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/First_steps/Variables", "Learn/JavaScript/First_steps/Strings", "Learn/JavaScript/First_steps")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/What_is_JavaScript">מה זה JavaScript?</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/A_first_splash">מבט ראשון ל- JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/What_went_wrong">מה השתבש? פתרון בעיות ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Variables">אחסון המידע שאנחנו צריכים - משתנים — Variables</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Math">מתמתיקה בסיסית ב-  JavaScript — מספרים ואופרטורים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Strings">התמודדות עם טקסט — מחרוזות (Strings) ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Useful_string_methods">מתודות שימושיות למחרוזות</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Arrays">מערכים - Arrays</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Silly_story_generator">תרגיל: Silly story generator</a></li>
-</ul>
diff --git a/files/he/learn/javascript/first_steps/silly_story_generator/index.html b/files/he/learn/javascript/first_steps/silly_story_generator/index.html
deleted file mode 100644
index 8c4ca6772a..0000000000
--- a/files/he/learn/javascript/first_steps/silly_story_generator/index.html
+++ /dev/null
@@ -1,139 +0,0 @@
----
-title: Silly story generator
-slug: Learn/JavaScript/First_steps/Silly_story_generator
-translation_of: Learn/JavaScript/First_steps/Silly_story_generator
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenu("Learn/JavaScript/First_steps/Arrays", "Learn/JavaScript/First_steps")}}</div>
-
-<p class="summary">בתרגול זה, תתבקשו ליישם את מה שלמדתם בכל המאמרים האחרונים במודול הנוכחי על מנת ליצור יישום קטן שמייצר סיפורים טיפשיים באופן רנדומלי. </p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>אנא וודאו כי עברתם על כל המאמרים במודול זה בטרם ביצוע התרגול.</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>לוודא הבנה של יסודות שפת JavaScript ושימוש במשתנים, מספרים,אופרטורים, מחרוזות ומערכים. </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="נקודת_התחלה">נקודת התחלה</h2>
-
-<p>על מנת להתחיל:</p>
-
-<ul>
- <li>הורידו את <a href="https://github.com/mdn/learning-area/blob/master/javascript/introduction-to-js-1/assessment-start/index.html">הקובץ זה</a> לצורך התרגול ושמרו אותו בשם <code>index.html</code> בתיקיה במחשב שלכם. קובץ זה מכיר גם CSS על מנת לעצב את הדוגמא שנמצאת בתוכו.</li>
- <li>גשו ל <a href="https://github.com/mdn/learning-area/blob/master/javascript/introduction-to-js-1/assessment-start/raw-text.txt">דף המכיל מידע גולמי</a> והשאירו אותו פתוח בלשונית חדשה בדפדפן שלכם. אתם תצטרכו אותו אחר כך.</li>
-</ul>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: לחילופין, אתם יכולים לעשות שימוש ב- <a class="external external-icon" href="http://jsbin.com/">JSBin</a> או <a class="external external-icon" href="https://thimble.mozilla.org/">Thimble</a> על מנת להשלים את התרול. אתם יכולים להדביק לתוכם את ה HTML, CSS ואת JavaScript.</p>
-</div>
-
-<h2 id="תקציר_הפרוייקט">תקציר הפרוייקט</h2>
-
-<p>קיבלתם לידיכם HTML/CSS גולמי ומס׳ מחרווזת טקסט וכן מס׳ פונקציות של JavaScript. הנכם נדרשים לכתוב את הקוד הרלוונטי על מנת להפוך אותם לתוכנית שעושה את הדברים הבאים:</p>
-
-<ul>
- <li>יוצרת סיפור חדש כאשר הכפתור "Generate random story" נלחץ.</li>
- <li>מחליפה את שם ברירת המחדל "Bob" אשר נמצא בסיפור, בשם אחר, רק אם השם האחר הוכנס לתוך תיבת הטקסט "Enter custom name" לפני שכפתור יצירת הסיפור נלחץ.</li>
- <li>ממירה את שיטת המשקלים והטמפרטורות משיטה אמריקאית לשיטה בריטית אם הכפתור uk מסומן לפני שנלחץ על כפתור יצירת הסיפור.</li>
- <li>נייצר סיפור אקראי בכל פעם אם תלחץ על הכפתור שוב (ושוב...)</li>
-</ul>
-
-<p>צילום המסך הבא יסייע לכם להבין כיצד זה אמור להיראות:</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/16178/Screen_Shot_2018-09-19_at_10.01.38_AM.png" style="border-style: solid; border-width: 1px; display: block; height: 404px; margin: 0px auto; width: 500px;"></p>
-
-<p>לתת לכם קצת יותר הכוונה, <a href="http://mdn.github.io/learning-area/javascript/introduction-to-js-1/assessment-finished/">הסתכלו בפתרון העובד</a> (אך אל תסתכלו על קוד המקור, אלא אם ממש נתקעתם)</p>
-
-<h2 id="פעולות_נדרשות">פעולות נדרשות</h2>
-
-<p>אלו הפעולות שתידשו לבצע על מנת להשלים את התרגול בהצלחה</p>
-
-<p>התקנה בסיסית:</p>
-
-<ol>
- <li>צרו קובץ חדש שנקרא בשם <code>main.js</code>, באותה תיקיה שבה נמצא קובץ <code>index.html</code> שלכם</li>
- <li>החילו את קובץ ה-JavaScript לתוך קובץ ה-HTML כפי שלמדנו באמצעות {{htmlelement("script")}} עם קישור ל-<code>main.js</code>. שימו אותו לפני תגית הסיום של <code>&lt;/body&gt;</code>.</li>
-</ol>
-
-<p>אתחול משתנים ופונקציות:</p>
-
-<ol>
- <li>בקובץ הטקסט הגולמי העתיקו את כל הקוד שמופיע תחת הכותרת "1. COMPLETE VARIABLE AND FUNCTION DEFINITIONS" והדביקו אותו בחלקו העליון של הקובץ <code>main.js</code>.זה נותן שלשה משתנים שמכילים הפניות לשדה הטקסט "Enter custom name" (המשתנה: <code>customName</code>) ולכפתור "Generate random story" (המשתנה:<code>randomize</code>) ולאלמנט {{htmlelement("p")}} (המשתנה:<code>story</code>) שבתחתית חלק ה HTML שאליו יועתק הסיפור בהתאמה. בנוסף יש לך פונקציה שנקראת <code>randomValueFromArray()</code> שלוקחת מערך, ומחזירה אחד מהפריטים המאוחסנים בתוך המערך באופן אקראי</li>
- <li>כעת התבוננו בקטע השני שבקובץ הטקסט הגולמי "2. RAW TEXT STRINGS" זה מכיל מחרוזות טקסט   that will act as input into our program. We'd like you to contain these inside variables inside <code>main.js</code>:
- <ol>
- <li>Store the third set of three strings inside an array called <code>insertZ</code>.</li>
- <li>Store the second set of three strings inside an array called <code>insertY</code>.</li>
- <li>Store the first set of three strings inside an array called <code>insertX</code>.</li>
- <li>Store the first, big long, string of text inside a variable called <code>storyText</code>.</li>
- </ol>
- </li>
-</ol>
-
-<p>Placing the event handler and incomplete function:</p>
-
-<ol>
- <li>Now return to the raw text file.</li>
- <li>Copy the code found underneath the heading "3. EVENT LISTENER AND PARTIAL FUNCTION DEFINITION" and paste it into the bottom of your <code>main.js</code> file. This:
- <ul>
- <li>Adds a click event listener to the <code>randomize</code> variable so that when the button it represents is clicked, the <code>result()</code> function is run.</li>
- <li>Adds a partially-completed <code>result()</code> function definiton to your code. For the remainder of the assessment, you'll be filling in lines inside this function to complete it and make it work properly.</li>
- </ul>
- </li>
-</ol>
-
-<p>Completing the <code>result()</code> function:</p>
-
-<ol>
- <li>Create a new variable called <code>newStory</code>, and set it's value to equal <code>storyText</code>. This is needed so we can create a new random story each time the button is pressed and the function is run. If we made changes directly to <code>storyText</code>, we'd only be able to generate a new story once.</li>
- <li>Create three new variables called <code>xItem</code>, <code>yItem</code>, and <code>zItem</code>, and make them equal to the result of calling <code>randomValueFromArray()</code> on your three arrays (the result in each case will be a random item out of each array it is called on). For example you can call the function and get it to return one random string out of <code>insertX</code> by writing <code>randomValueFromArray(insertX)</code>.</li>
- <li>Next we want to replace the three placeholders in the <code>newStory</code> string — <code>:insertx:</code>, <code>:inserty:</code>, and <code>:insertz:</code> — with the strings stored in <code>xItem</code>, <code>yItem</code>, and <code>zItem</code>. There is a particular string method that will help you here — in each case, make the call to the method equal to <code>newStory</code>, so each time it is called, <code>newStory</code> is made equal to itself, but with substitutions made. So each time the button is pressed, these placeholders are each replaced with a random silly string. As a further hint, the method in question only replaces the first instance of the substring it finds, so you might need to make one of the calls twice.</li>
- <li>Inside the first <code>if</code> block, add another string replacement method call to replace the name 'Bob' found in the <code>newStory</code> string with the <code>name</code> variable. In this block we are saying "If a value has been entered into the <code>customName</code> text input, replace Bob in the story with that custom name."</li>
- <li>Inside the second <code>if</code> block, we are checking to see if the <code>uk</code> radio button has been selected. If so, we want to convert the weight and temperature values in the story from pounds and Fahrenheit into stones and centigrade. What you need to do is as follows:
- <ol>
- <li>Look up the formulae for converting pounds to stone, and Fahrenheit to centigrade.</li>
- <li>Inside the line that defines the <code>weight</code> variable, replace 300 with a calculation that converts 300 pounds into stones. Concatenate <code>' stone'</code> onto the end of the result of the overall <code>Math.round()</code> call.</li>
- <li>Inside the line that defines the <code>temperature</code> variable, replace 94 with a calculation that converts 94 Fahrenheit into centigrade. Concatenate <code>' centigrade'</code> onto the end of the result of the overall <code>Math.round()</code> call.</li>
- <li>Just under the two variable definitions, add two more string replacement lines that replace '94 fahrenheit' with the contents of the <code>temperature</code> variable, and '300 pounds' with the contents of the <code>weight</code> variable.</li>
- </ol>
- </li>
- <li>Finally, in the second-to-last line of the function, make the <code>textContent</code> property of the <code>story</code> variable (which references the paragraph) equal to <code>newStory</code>.</li>
-</ol>
-
-<h2 id="רמזים_וטיפים">רמזים וטיפים</h2>
-
-<ul>
- <li>You don't need to edit the HTML in any way, except to apply the JavaScript to your HTML.</li>
- <li>If you are unsure whether the JavaScript is applied to your HTML properly, try removing everything else from the JavaScript file temporarily, adding in a simple bit of JavaScript that you know will create an obvious effect, then saving and refreshing. The following for example turns the background of the {{htmlelement("html")}} element red — so the entire browser window should go red if the JavaScript is applied properly:
- <pre class="brush: js notranslate">document.querySelector('html').style.backgroundColor = 'red';</pre>
- </li>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/round">Math.round()</a> is a built-in JavaScript method that simply rounds the result of a calculation to the nearest whole number.</li>
- <li>There are three instances of strings that need to be replaced. You may repeat the <code>replace()</code> method multiple times, or you can use regular expressions. For instance, <code>var text = 'I am the biggest lover, I love my love'; text.replace(/love/g,'like');</code> will replace all instances of 'love' to 'like'. Remember, Strings are immutable!</li>
-</ul>
-
-<h2 id="Assessment">Assessment</h2>
-
-<p>If you are following this assessment as part of an organized course, you should be able to give your work to your teacher/mentor for marking. If you are self-learning, then you can get the marking guide fairly easily by asking on the <a href="https://discourse.mozilla.org/t/silly-story-generator-assessment/24686">discussion thread for this exercise</a>, or in the <a href="irc://irc.mozilla.org/mdn">#mdn</a> IRC channel on <a href="https://wiki.mozilla.org/IRC">Mozilla IRC</a>. Try the exercise first — there is nothing to be gained by cheating!</p>
-
-<p>{{PreviousMenu("Learn/JavaScript/First_steps/Arrays", "Learn/JavaScript/First_steps")}}</p>
-
-<h2 id="In_this_module">In this module</h2>
-
-<ul>
- <li><a href="/en-US/docs/Learn/JavaScript/First_steps/What_is_JavaScript">What is JavaScript?</a></li>
- <li><a href="/en-US/docs/Learn/JavaScript/First_steps/A_first_splash">A first splash into JavaScript</a></li>
- <li><a href="/en-US/docs/Learn/JavaScript/First_steps/What_went_wrong">What went wrong? Troubleshooting JavaScript</a></li>
- <li><a href="/en-US/docs/Learn/JavaScript/First_steps/Variables">Storing the information you need — Variables</a></li>
- <li><a href="/en-US/docs/Learn/JavaScript/First_steps/Math">Basic math in JavaScript — numbers and operators</a></li>
- <li><a href="/en-US/docs/Learn/JavaScript/First_steps/Strings">Handling text — strings in JavaScript</a></li>
- <li><a href="/en-US/docs/Learn/JavaScript/First_steps/Useful_string_methods">Useful string methods</a></li>
- <li><a href="/en-US/docs/Learn/JavaScript/First_steps/Arrays">Arrays</a></li>
- <li><a href="/en-US/docs/Learn/JavaScript/First_steps/Silly_story_generator">Assessment: Silly story generator</a></li>
-</ul>
diff --git a/files/he/learn/javascript/first_steps/strings/index.html b/files/he/learn/javascript/first_steps/strings/index.html
deleted file mode 100644
index 8523f144ac..0000000000
--- a/files/he/learn/javascript/first_steps/strings/index.html
+++ /dev/null
@@ -1,172 +0,0 @@
----
-title: "התמודדות עם טקסט\_— מחרוזות (Strings) ב-JavaScript"
-slug: Learn/JavaScript/First_steps/Strings
-translation_of: Learn/JavaScript/First_steps/Strings
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/First_steps/Math", "Learn/JavaScript/First_steps/Useful_string_methods", "Learn/JavaScript/First_steps")}}</div>
-
-<p class="summary">כעת, אנו נשים את הפוקוס על מחרוזות - כך נקראים חלקים של טקסט בתכנות. במאמר זה אנחנו נסתכל על הדברים המשותפים שאנחנו חייבים לדעת על מחרוזות כשלומדים JavaScript, כמו יצירת מחרוזות, חיבור מחרוזות וכד׳.</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>הבנה בסיסית של מחשב, הבנה בסיסית של  HTML, CSS ו - JavaScript.</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>הכרות עם הבסיס של מחרוזות וטקסט ב-JavaScript.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="כוחן_של_מילים">כוחן של מילים</h2>
-
-<p>מילים הן אחד הדברים החשובים לבני אדם - זוהי הדרך שמרבית מאיתנו מתקשרים אחד עם השני. מאחר ורשת האינטרנט היא בעיקרה מדיה המבוססת על טקסט המאפשרת לבני אדם להחליף ביניהם מידע, זה מאוד שימוש עבורנו לקבל שליטה על הדרך שבה מילים מוצגות ברשת האינטרנט. {{glossary("HTML")}} מעניק לנו את המבנה ואת המשמעות מאחורי הטקסט שלנו, {{glossary("CSS")}} מאפשר לנו לעצב אותו ואילו JavaScript מכילה מספר אפשרויות וכללים לבצע מניפולציות שונות על מחרוזות, ליצור הודעות/התראות שונות, להראות את הטקסט הנכון כשצריך ועוד.</p>
-
-<p>כמעט כל התוכניות שעברנו עליהם בקורס עד כה כללו מניפולציה כלשהי על מחרוזות.</p>
-
-<h2 id="Strings_—_מחרוזות_-_הבסיס">Strings — מחרוזות - הבסיס</h2>
-
-<p>אנו נעבוד עם מחרוזות בדיוק כמו שעבדנו עם מספרים, אך עם מספר הבדלים: נתחיל בכך שנפתח את הקונסולה ונזין מספר שורות קוד:</p>
-
-<h3 id="יצירת_מחרוזת">יצירת מחרוזת</h3>
-
-<ol>
- <li>על מנת להתחיל, הזן את השורות הבאות בקונסולה:
- <pre class="brush: js">let string = 'The revolution will not be televised.';
-string;</pre>
- בדיוק כמו שעשינו עם מספרים, אנחנו מכריזים פה על משתנה ומשימים לו ערך של מחרוזת ואז מקבלים את הערך של המשתנה. ההבדל היחיד הוא שכאשר אנחנו כותבים מחרוזת, אנחנו צריכים להשתמש במרכאות כפולות <code>""</code> או במרכאות בודדות - גרש מכל צד - <code>''</code>.</li>
- <li>אם לא נעשה זאת, או שנחסיר אותן בצד ימין או שמאל, אנחנו נקבל שגיאה. נסו להזין את השורות הבאות:
- <pre class="brush: js example-bad">let badString = This is a test;
-let badString = 'This is a test;
-let badString = This is a test';</pre>
- שורות קוד אלו לא יעבדו מכיוון שכל טקסט שאינו מוקף במלואו במרכאות נחשב כשם של משתנה או שם של מאפיין או מילה שמורה וכד׳. אם הדפדפן לא מוצא את אותה מילה, הוא מחזיר שגיאה. לדוגמא: "missing; before statement". אם הדפדפן יכול לראות מתי מתחילה מחרוזת, אבל לא מתי היא מסתיימת, מכיוון שחסר מרכאות בצד כלשהו, הוא יחזיר שגיאה כגון: "unterminated string literal". אם התוכנית שלנו מעלה שגיאות כאלו, צריך לחזור ולבדוק את כל המחרוזות ולוודא שלא שכחנו מרכאות.</li>
- <li>הקוד הבא יעבוד אם הגדרנו לפני את המשתנה <code>string</code>:
- <pre class="brush: js">let badString = string;
-badString;</pre>
- <code>badString</code> כעת הוגדר לקבל את אותו ערך כמו של <code>string</code>.</li>
-</ol>
-
-<h3 id="מרכאות_כפולות_או_בודדות">מרכאות כפולות או בודדות</h3>
-
-<ol>
- <li>ב-JavaScript, אנחנו יכולים לבחור האם להשתמש במרכאות כפולות או במרכאות בודדות לשם עטיפת המחרוזת שלנו. שניהם יעבדו מצויין ובדיוק אותו דבר:
- <pre class="brush: js">let sgl = 'Single quotes.';
-let dbl = "Double quotes";
-sgl;
-dbl;</pre>
- </li>
- <li>יש מעט מאוד הבדלים ביניהם, וזה תלוי בכם במה להתשמש. אתם צריכים לבחור סוג אחד ואיתו להמשיך. צריך לזכור שלא ניתן להשתמש בשניהם במקביל כך שמצד אחד של מחרוזת יהיו מרכאות כפולות ומצד שני יהיו מרכאות בודדות, שכן זה יחזיר לנו שגיאה:
- <pre class="brush: js example-bad">let badQuotes = 'What on earth?";</pre>
- </li>
- <li>הדפדפן יחשוב שהמחרוזת לא נסגרה מכיוון שכשאנחנו משתמשים בסוג אחד של מרכאות על מנת לעטוף טקסט, אנחנו יכולים להשתמש בסוג השני של המרכאות בתוך הטקסט עצמו. לדוגמא, השורות הקוד הבאות הן תקינות לחלוטין:
- <pre class="brush: js">let sglDbl = 'Would you eat a "fish supper"?';
-let dblSgl = "I'm feeling blue.";
-sglDbl;
-dblSgl;</pre>
- </li>
- <li>יחד עם זאת, צריך לזכור שאנחנו לא יכולים לכלול בתוך הטקסט את סוג המרכאות שאיתו אנחנו משתמשים על מנת לעטוף את אותו הטקסט. הדוגמא הבאה תציג לנו שגיאה, שכן הדפדפן לא יודע מתי המחרוזת מסתיימת:
- <pre class="brush: js example-bad">let bigmouth = 'I've got no right to take my place...';</pre>
- וזה מה שמוביל אותנו לנושא הבא. תווים לבריחה ממחרוזות.</li>
-</ol>
-
-<h3 id="תווים_לבריחה_ממחרוזת">תווים לבריחה ממחרוזת</h3>
-
-<p>על מנת לתקן את הבעיה בקוד הקודם, אנחנו צריכים לברוח מסימן המרכאות אשר עוטף את הטקסט. תווי בריחה שכאלו משמעותם שאנחנו עושים משהו על מנת לוודא שהם ייקראו כטקסט רגיל ולא כחלק מהקוד שלנו. ב-JavaScript, אנחנו עושים את זה באמצעות שימוש בסימן <code>\</code>נסו את זה:</p>
-
-<pre class="brush: js">let bigmouth = 'I\'ve got no right to take my place...';
-bigmouth;</pre>
-
-<p>זה עובד מצוין. אנחנו יכולים גם לברוח מתווים אחרים באותה צורה. לדוגמא: <code>"\</code>,  ויש עוד. ראו <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/String#Escape_notation">Escape notation</a> לפרטים נוספים.</p>
-
-<h2 id="Concatenating_strings_-_שרשור_מחרוזות">Concatenating strings - שרשור מחרוזות</h2>
-
-<ol>
- <li>שרשור נשמעת כמו מילה מורכבת שמשמעותה הפשוטה הוא חיבור ביחד. חיבור מחרוזות יחד ב-JavaScript מתבצע באמצעות האופרטור (+), באותה צורה כשהשתמשנו בו לביצוע חיבור בין מספרים, אבל בהקשר שלנו הוא מבצע משהו אחר. נסו את הקוד הבא בקונסולה:
- <pre class="brush: js">let one = 'Hello, ';
-let two = 'how are you?';
-let joined = one + two;
-joined;</pre>
- התוצאה של המשתנה שנקרא <code>joined</code> תכיל את הערך של "Hello, how are you?"</li>
- <li>במשתנה השלישי, פשוט חיברנו שתי מחרוזות יחד, אך אנחנו יכולים לחבר כמה מחרוזות שנרצה, כל עוד אנחנו כוללים את סימן <code>+</code> בין כל אחת מהמחרוזות. נסו לדוגמא:
- <pre class="brush: js">let multiple = one + one + one + one + two;
-multiple;</pre>
- </li>
- <li>אתם גם יכולים לערבב בין משתנים לבין מחרוזות בפועל. נסו את הבא:
- <pre class="brush: js">let response = one + 'I am fine — ' + two;
-response;</pre>
- </li>
-</ol>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: כשאנחנו מכניסים מחרוזת טקסט ממשית לתוך הקוד שלנו, כשהיא עטופה במרכאות (כפולות או בודדות), זה נקרא <strong>string literal</strong>.</p>
-</div>
-
-<h3 id="Concatenation_in_context_-_שרשור_בתוכן">Concatenation in context - שרשור בתוכן</h3>
-
-<p>בוא נסתכל על שרשור בפועל - הנה דוגמא ממאמרים קודמים בקורס:</p>
-
-<pre class="brush: html">&lt;button&gt;Press me&lt;/button&gt;</pre>
-
-<pre class="brush: js">const button = document.querySelector('button');
-
-button.onclick = function() {
- let name = prompt('What is your name?');
- alert('Hello ' + name + ', nice to see you!');
-}</pre>
-
-<p>{{ EmbedLiveSample('Concatenation_in_context', '100%', 50, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<p>כאן אנחנו משתמשים ב- {{domxref("window.prompt()", "window.prompt()")}} פונקציה בשורה 4, אשר מבקשת מהמשתמש לענות לשאלה באמצעות חלון קופץ, ולאחר מכן מאחסנת את הטקסט שהמשתמש הכניס לתוך משתנה נתון - במקרה הזה - המשתנה <code>name</code>.</p>
-
-<p>לאחר מכן אנחנו משתמשים ב-{{domxref("window.alert()", "window.alert()")}} בשורה 5, על מנת להציג למשתמש חלון קופץ נוסף המיכל מחרוזת שהרכבנו משתי מחרוזות בנויות ומהמשתנה <code>name</code>, באמצעות שרשור של המחרוזות.</p>
-
-<h3 id="מספרים_vs._מחרוזות">מספרים vs. מחרוזות</h3>
-
-<ol>
- <li>מה יקרה כאשר אנחנו ננסה לחבר (לשרשר) בין מחרוזת לבין מספר? נזין את הקוד הבא בקונסולה:
- <pre class="brush: js">'Front ' + 242;
-</pre>
- היינו מצפים שניסיון כזה יחזיר לנו שגיאה, אך זה עובד בצורה מצויינת. נסיון להציג מחרוזת כמספר לא עושה הגיון, אבל הצגת מספר כמחרוזת כן, ולכן הדפדפן ממיר את המספר למחרוזת ומאחד בין שתי המחרוזות.</li>
- <li>ניתן אפילו לעשות זאת עם שני מספרים - אנחנו יכולים להכריח מספר להפוך למחרוזת על ידי עטיפה שלו במרכאות. נסו את הקוד הבא. שימו לב שאנחנו משתמשים באופרטור <code>typeof</code> על מנת לבדוק האם הערך של המשתנה הוא מספר או מחרוזת:
- <pre class="brush: js">let myDate = '19' + '67';
-typeof myDate;</pre>
- </li>
- <li>אם יש לנו משתנה שיש לו ערך של מספר ואנחנו רוצים להמירו למחרוזת ללא ביצוע שינוי נוסף בו, או יש לנו משתנה שיש לו ערך שהוא מחרוזת ואנחנו רוצים להמירו למספר ולא לעשות בו שינוי נוסף, אנחנו יכולים להשתמש במתודות הבאות:
- <ul>
- <li>האובייקט {{jsxref("Number")}} יהפוך כל דבר שמועבר אליו למספר, אם הוא יכול. נסו את הקוד הבא:
- <pre class="brush: js">let myString = '123';
-let myNum = Number(myString);
-typeof myNum;</pre>
- </li>
- <li>מצד שני, לכל מספר יש מתודה שנקראת <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number/toString">()toString</a></code> שתמיר כל מספר למחרוזת תואמת. נסו לדוגמא את הקוד הבא:
- <pre class="brush: js">let myNum = 123;
-let myString = myNum.toString();
-typeof myString;</pre>
- </li>
- </ul>
- אלו יכולים להיות מאוד שימושיים בסיטואציות שונות. לדומא, אם משתמש מכניס מספר לתוך שדה טקסט בטופס, זה תמיד יהיה מחרוזת, גם אם הוא הזין מספרים. לעומת זאת, אם אנחנו רוצים להוסיף את המספר שהמשתמש הזין למשהו, זה חייב להיות מספר, ולכן אנחנו נצטרך להעביר את הקלט הזה דרך <code>()Number</code>. עשינו זאת בדיוק, בדוגמא שלנו ב-<a href="https://github.com/mdn/learning-area/blob/master/javascript/introduction-to-js-1/first-splash/number-guessing-game.html#L54">משחק ״נחש את הזיכרון״, בשורה 54</a>.</li>
-</ol>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>זה היה הבסיס של מחרוזת ב-JavaScript. במאמר הבא אנחנו נסתכל על מתודות מובנות הזמינות למחרוזות בשפה זו ונלמד כיצד אנחנו יכולים להשתמש בהם על מנת לבצע מניפולציות למחרוזות שלנו או לשנות את המבנה שלהן.</p>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/First_steps/Math", "Learn/JavaScript/First_steps/Useful_string_methods", "Learn/JavaScript/First_steps")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/What_is_JavaScript">מה זה JavaScript?</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/A_first_splash">מבט ראשון ל- JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/What_went_wrong">מה השתבש? פתרון בעיות ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Variables">אחסון המידע שאנחנו צריכים - משתנים — Variables</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Math">מתמתיקה בסיסית ב-  JavaScript — מספרים ואופרטורים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Strings">התמודדות עם טקסט — מחרוזות (Strings) ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Useful_string_methods">מתודות שימושיות למחרוזות</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Arrays">מערכים - Arrays</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Silly_story_generator">תרגיל: Silly story generator</a></li>
-</ul>
diff --git a/files/he/learn/javascript/first_steps/useful_string_methods/index.html b/files/he/learn/javascript/first_steps/useful_string_methods/index.html
deleted file mode 100644
index 8315262c35..0000000000
--- a/files/he/learn/javascript/first_steps/useful_string_methods/index.html
+++ /dev/null
@@ -1,673 +0,0 @@
----
-title: מתודות שימושיות של מחרוזות
-slug: Learn/JavaScript/First_steps/Useful_string_methods
-tags:
- - JavaScript
- - אובייקט
- - חילוץ וחיבור מחרוזות
- - מחרוזות
- - מחרוזות ב-JavaScript
- - מציאת האורך של מחרוזת
- - מציאת חלק ממחרוזת
-translation_of: Learn/JavaScript/First_steps/Useful_string_methods
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/First_steps/Strings", "Learn/JavaScript/First_steps/Arrays", "Learn/JavaScript/First_steps")}}</div>
-
-<p class="summary">לאחר שלמדנו את הבסיס של מחרוזות, נתקדם הלאה ונלמד אילו פעולות אנחנו יכולים לבצע על מחרוזות תוך שימוש במתודות מובנות, כגון מציאת אורך המחרוזת, חיבור ופיצול של מחרוזות, הפרדת תו בודד במחרוזת ועוד.</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>הבנה בסיסית של מחשב, הבנה בסיסית של  HTML, CSS ו - JavaScript.</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>
- <p>הבנה כי מחרוזות הן בעצם סוג של אובייקט, ולמידה כיצד להשתמש במתודות בסיסיות הזמינות עבור אובייקט מסוג שכזה וכיצד לבצע מניפלוציות במחרוזות.</p>
- </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="מחרוזות_הן_בעצם_סוג_של_אובייקט">מחרוזות הן בעצם סוג של אובייקט</h2>
-
-<p id="Useful_string_methods">רוב הדברים ב-JavaScript הן בעצם אובייקט. כאשר אנחנו יוצרים מחרוזת כזו לדוגמא:</p>
-
-<pre class="brush: js">let string = 'This is my string';</pre>
-
-<p>המשתנה שלנו בעצם הופך למעין מופע של אובייקט מחרוזת (a string object instance), וכתוצאה מכך לא מעט מתודות ומאפיינים הופכים לזמינים עבור המשתנה. </p>
-
-<p>ניתן לראות את רשימת המתודות ומאפיינים אלו בדף בנושא  {{jsxref("String")}} - ראו את הכמות הלא מבוטלת הזו של מתודות ומאפיינים. </p>
-
-<p><strong>לפני שאתם נלחצים - אנחנו לא באמת צריכים לזכור את כל המתודות והמאפיינים הללו, לפחות לא בתחילת דרכנו. </strong>אך יש כאלו שנרצה לזכור ולתרגל שכן אנחנו נשתמש בהן לעיתים תכופות. </p>
-
-<p>נתחיל בתרגול על ידי הכנסת הדוגמאות הבאות ל<a href="/en-US/docs/Learn/Common_questions/What_are_browser_developer_tools">קונסולה</a>:</p>
-
-<h3 id="מציאת_האורך_של_מחרוזת">מציאת האורך של מחרוזת</h3>
-
-<p>זהו מאפיין המאפשר לנו למצוא את האורך של המחרוזת - אנחנו פשוט משתמשים במאפיין {{jsxref("String.prototype.length", "length")}}. נסו להכניס את הקוד הבא בקונסולה:</p>
-
-<pre class="brush: js">let browserType = 'mozilla';
-browserType.length;</pre>
-
-<p>זה אמור להחזיר לכם את המספר 7, מכיוון שהמחרוזת ״mozilla״ מורכבת מ-7 תווים. זה מאוד שימושי מסיבות רבות: לדוגמא, לפעמים נרצה למצוא את האורך של כל שם ברשימה של שמות ואז להציג אותם לפי האורך שלהם, או לתת למשתמש הודעה ששם המשתמש שהוא הכניס הוא ארוך מדי אם הוא עבר אורך מסויים.</p>
-
-<h3 id="אחזור_של_תו_ספציפי_במחרוזת">אחזור של תו ספציפי במחרוזת</h3>
-
-<p>בהקשר זה, אנחנו יכולים לקבל תו ספציפי במחרוזת, על ידי שימוש ב - <strong>סוגריים מרובעות</strong> בסוף המחרוזת שלנו - כלומר, אנחנו צריכים לכלול (<code>[]</code>) בסוף שם המשתנה שלנו.</p>
-
-<p>בתוך הסוגריים המרובעות אנחנו צריכים להכניס את מס׳ התו שאנחנו רוצים לקבל בחזרה, כך שאם נרצה את התו הראשון במחרוזת, נזין את הקוד הבא:</p>
-
-<pre class="brush: js">browserType[0];</pre>
-
-<p>שימו לב שמחשבים מתחילים לספור מ-0 ולא מ-1. על מנת לקבל את התו האחרון של <em>כל</em> מחרוזת, אנחנו יכולים להשתמש בקוד הבא המבצע שימוש גם במאפיין <code>length</code> שלמדנו למעלה.</p>
-
-<pre class="brush: js">browserType[browserType.length-1];</pre>
-
-<p>האורך של "mozilla" הוא 7 תווים, אך מכיוון שהמונה (או יותר נכון - אינדקס) מתחיל לספור מ-0, אז המיקום של התו 6 בעצם הוא המיקום של התו האחרון במחרוזת, ולכן אנחנו צריכים את הקוד <code>length-1</code>. אנחנו יכולים להשתמש בזה לדוגמא על מנת למצוא את האות הראשון בסדרה של מחרוזות ולסדר המחרוזות לפי סדר האלפבית.</p>
-
-<h3 id="מציאת_חלק_ממחרוזת_וחילוצו">מציאת חלק ממחרוזת וחילוצו</h3>
-
-<ol>
- <li>לפעמים נרצה לבדוק האם מחרוזת מסויימת בת מספר תווים נמצאת בתוך מחרוזת גדולה יותר. (באופן כללי אנחנו בודקים <em>האם מחרוזת המשנה קיימת בתוך המחרוזת</em>). ניתן לבצע זאת באמצעות מתודת {{jsxref("String.prototype.indexOf()", "indexOf()")}} אשר מקבלת {{glossary("parameter")}} אחד — את מחרוזת המשנה שאנחנו נרצה לחפש בתוך המחרוזת הגדולה יותר. נסו להזין את הקוד הבא:
-
- <pre class="brush: js">browserType.indexOf('zilla');</pre>
- קיבלנו בחזרה את הערך 2 שמציין שמחרוזת-המשנה "zilla" מתחילה במיקום 2 בתוך המחרוזת "mozilla". קוד שכזה יכול לעזור לנו לסנן מחרוזות. לדוגמא, אם יש לנו רשימה של כתובות אינטרנט, ונרצה לסנן רק את אלו המכילים את המחרוזת "zilla".</li>
-</ol>
-
-<ol start="2">
- <li>שימו לב שניתן לבצע סינון זאת גם על דרך השלילה אשר תהיה כמובן יעילה יותר. נסו את הקוד הבא:
- <pre class="brush: js">browserType.indexOf('vanilla');</pre>
- קוד זה יחזיר  לנו את התוצאה <code>1-</code> אשר משמעותה היא כי מחרוזת המשנה שהזנו למתודה לא קיימת במחרוזת הראשית. כאן לדוגמא, המחרוזת 'vanilla' לא נמצאה במחרוזת הראשית.<br>
- <br>
- אנו יכולים לעשות בזה שימוש למצוא את כל המופעים של מחרוזות <strong>שכן</strong> מכילים את מחרוזת המשנה 'mozilla' או <strong>שאינם מכילים,</strong> אם אנחנו משתמשים באופרטור שלילה כפי שמצויין למטה.
-
- <pre class="brush: js">if(browserType.indexOf('mozilla') !== -1) {
- // do stuff with the string
-}</pre>
- </li>
- <li>כשאנחנו יודעים היכן מחרוזת המשנה שלנו מתחילה בתוך מחרוזת ראשית, ואנחנו יודעים באיזה תו אנחנו רוצים שמחרוזת המשנה תסתיים, אנחנו יכולים להשתמש ב - {{jsxref("String.prototype.slice()", "slice()")}} נסו להזין את הקוד הבא:
- <pre class="brush: js">browserType.slice(0,3);</pre>
- קוד זה יחזיר לנו כתוצאה "moz" - הארגומנט הראשון שהזנו - 0 - הוא המיקום של התו הראשון במחרוזת המשנה שנרצה לחלץ, והארגומנט השני שהזנו - 3 - יהיה התו שאחרי התו האחרון במחרוזת שנרצה לחלץ. זאת אומרת, החיתוך של המחרוזת מתרחש החל מהתו הראשון ועד, אך לא כולל, התו הרביעי. להזכירכם - מחשבים מתחילים לספור מ-0 ולא מ-1.<br>
-  </li>
- <li>בנוסף, אם נרצה לחלץ את כל התווים אחרי תו מסויים, אנחנו יכולים להשמיט את הארגומנט השני. כלומר אנחנו ניתן למתודה רק את מיקום התו שאיתו נתחיל את החילוץ. ראו את הקוד הבא:
- <pre class="brush: js">browserType.slice(2);</pre>
- קוד זה מחזיר את הערך "zilla" - מכיוון שהאות שבמיקום 2 היא האות z ומכיוון שהשמטנו את הארגומנט השני, המתודה חילצה את כל התווים עד סוף המחרוזת <code>browserType</code>.</li>
-</ol>
-
-<div class="note">
-<p><strong>להזכירכם</strong>: הפרמטר השני של <code>()slice</code> הוא אופציונלי: אם נשמיט אותו, החיתוך יסתיים בסוף המחרוזת המקורית. יש גם אופציות נוספות. ראו בדף בנושא {{jsxref("String.prototype.slice()", "slice()")}} ללמוד על הנושא יותר.</p>
-</div>
-
-<div class="note">
-<p><strong>להזכירכם</strong>: מתודות ומאפיינים אלו לא שומרות את התוצאה של המניפולציה או החישוב שהן ביצעו. על מנת לשמור את התוצאה, אנחנו צריכים לשמור אותה במשתנה חדש. כמו כן, שימו לב שמתודות ומאפיינים אלו לא שינו את מחרוזת המקור שעליה ביצענו את החישובים/מניפולציות השונות.</p>
-</div>
-
-<h3 id="שינוי_אות_גדולה_לאות_קטנה_וההיפך">שינוי אות גדולה לאות קטנה, וההיפך</h3>
-
-<p>המתודות של מחרוזת {{jsxref("String.prototype.toLowerCase()", "toLowerCase()")}} ו- {{jsxref("String.prototype.toUpperCase()", "toUpperCase()")}} מאפשרות להמיר מחרוזת <strong>בשלמותה</strong> לאותיות גדולות או לאותיות קטנות, בהתאמה. זה יכול להיות מאוד שימוש כשנרצה לנרמל את כל הערכים שהמשתמש מכניס לפני שנעביר לשרת. להזכירכם - JavaScript היא case sensitive.</p>
-
-<p>נסו להכניס את הקוד הבא וראו מה התוצאה:</p>
-
-<pre class="brush: js">let radData = 'My NaMe Is MuD';
-radData.toLowerCase();
-radData.toUpperCase();</pre>
-
-<p>נסו לבדוק מה הערך של המשתנה <code>radData</code> והאם מתודות אלו שמרו בו את התוצאה של הפעלתן.</p>
-
-<h3 id="עדכון_חלקים_של_מחרוזת">עדכון חלקים של מחרוזת</h3>
-
-<p>אנחנו יכולים להחליף מחרוזת אחת במחרוזת אחרת באמצעות המתודה {{jsxref("String.prototype.replace()", "replace()")}}. מתודה זו עובדת בצורה פשוטה וברורה, למרות שניתן לבצע איתה דברים מורכבים יותר, אך לא ניכנס אליהם במדריך זה.</p>
-
-<p>מתודה זו מקבלת 2 ארגומנטים/פרמטרים - הראשון הוא המחרוזת שאנחנו רוצים להחליף והשני הוא המחרוזת שתיכנס במקום. נסו את הדוגמא הבאה:</p>
-
-<pre class="brush: js">browserType.replace('moz','van');</pre>
-
-<p>שימו לב שגם הפעם הערך שמוחזר לנו הוא המחרוזת החדשה שבוצעה בה ההחלפה, אך הערך הזה לא נשמר במחרוזת שעליה עשינו את ההחלפה. על מנת לקבל את המחרוזת החדשה במשתנה שלנו <code>browserType</code> אנחנו נצטרך לקבוע שהערך שלו יהיה התוצאה של ההפעלה של מתודה זו. כלומר - <code>browserType = browserType.replace('moz','van');</code></p>
-
-<h2 id="דוגמאות_ללמידה_עצמאית">דוגמאות ללמידה עצמאית</h2>
-
-<p>בחלק זה אנחנו נדריך אתכם לבצע כמה מניפוליות וחישובים על מחרוזות. בכל תרגיל המפורט למטה, יש לנו כמה מערכים של מחרוזות, ולולאה שמחשבת את הערך של כל איבר במערך ומציגה אותו ברשימה. אתם לא צריכים להבין כרגע מערכים או לולאות - אלו יוסברו בהמשך המדריך. אתם צריכים לכתוב בכל תרגיל קוד שיציג את התוצאה של המחרוזות הללו, בהתאם לתרגיל.</p>
-
-<p>כל דוגמא מגיע עם כפתור "Reset" על מנת לאתחל את הקוד במידה והוא השתבש וכן כפתור "Show solution" על מנת להציג את פתרון אפשרי במקרה ונתקעתם.</p>
-
-<h3 id="סינון_של_הודעות">סינון של הודעות</h3>
-
-<p>בתרגיל זה אנחנו מתחיל בתרגיל פשוט - יש לנו מערך של הודעה ברכה, אבל אנחנו רוצים למיין ולסנן רק את אלו שמכילות הודעה ברכה בהקשר של כריסמס. אנחנו רוצים שתכתוב משפט תנאי בתוך הקוד <code>( ... )if</code> אשר יבדוק כל מחרוזת וידפיס אותה לרשימה רק אם היא מכילה ברכה של כריסמס.</p>
-
-<ol>
- <li>חשבו תחילה איך אנחנו יכולים לבדוק האם ההודעה בכל פעם היא הודעה הקשורה לכריסמס. איזה מחרוזת מוצגת בכל ההודעות האלו ואיזו מתודה יכולה לבדוק האם המחרוזת נמצאת בתוך ההודעה הזו (אשר גם היא מחרוזת).</li>
- <li>אנחנו נלמד לכתוב משפט תנאי בתצורת <em>operand1 operator operand2</em>. האם הערך הנמצא מצד שמאל שווה לערך הנמצא מצד ימין? האם תוצאת הפעלת המתודה מצד שמאל, תהא שווה לערך בצד ימין לצד ימין? רמז - במקרה הנוכחי יהיה עדיף לבדוק האם תוצאת הפעלת המתודה בצד שמאל שונה מהערך בצד ימין.</li>
-</ol>
-
-<div class="hidden">
-<h6 id="קוד_לתרגול">קוד לתרגול</h6>
-
-<pre class="brush: html">&lt;h2&gt;Live output&lt;/h2&gt;
-
-&lt;div class="output" style="min-height: 125px;"&gt;
-
-&lt;ul&gt;
-
-&lt;/ul&gt;
-
-&lt;/div&gt;
-
-&lt;h2&gt;Editable code&lt;/h2&gt;
-&lt;p class="a11y-label"&gt;Press Esc to move focus away from the code area (Tab inserts a tab character).&lt;/p&gt;
-
-&lt;textarea id="code" class="playable-code" style="height: 290px; width: 95%"&gt;
-const list = document.querySelector('.output ul');
-list.innerHTML = '';
-let greetings = ['Happy Birthday!',
- 'Merry Christmas my love',
- 'A happy Christmas to all the family',
- 'You\'re all I want for Christmas',
- 'Get well soon'];
-
-for (let i = 0; i &lt; greetings.length; i++) {
- let input = greetings[i];
- // Your conditional test needs to go inside the parentheses - הכניסו את הקוד שלכם כאן - בין הסוגריים המסולסלות של הלולאה
- // in the line below, replacing what's currently there - בשורה מתחת - החליפו את מה שנמצא שם כרגע
- if (greetings[i]) {
- let listItem = document.createElement('li');
- listItem.textContent = input;
- list.appendChild(listItem);
- }
-}
-&lt;/textarea&gt;
-
-&lt;div class="playable-buttons"&gt;
- &lt;input id="reset" type="button" value="Reset"&gt;
- &lt;input id="solution" type="button" value="Show solution"&gt;
-&lt;/div&gt;
-</pre>
-
-<pre class="brush: css">html {
- font-family: sans-serif;
-}
-
-h2 {
- font-size: 16px;
-}
-
-.a11y-label {
- margin: 0;
- text-align: right;
- font-size: 0.7rem;
- width: 98%;
-}
-
-body {
- margin: 10px;
- background: #f5f9fa;
-}</pre>
-
-<pre class="brush: js">var textarea = document.getElementById('code');
-var reset = document.getElementById('reset');
-var solution = document.getElementById('solution');
-var code = textarea.value;
-var userEntry = textarea.value;
-
-function updateCode() {
- eval(textarea.value);
-}
-
-reset.addEventListener('click', function() {
- textarea.value = code;
- userEntry = textarea.value;
- solutionEntry = jsSolution;
- solution.value = 'Show solution';
- updateCode();
-});
-
-solution.addEventListener('click', function() {
- if(solution.value === 'Show solution') {
- textarea.value = solutionEntry;
- solution.value = 'Hide solution';
- } else {
- textarea.value = userEntry;
- solution.value = 'Show solution';
- }
- updateCode();
-});
-
-var jsSolution = 'const list = document.querySelector(\'.output ul\');' +
-'\nlist.innerHTML = \'\';' +
-'\nlet greetings = [\'Happy Birthday!\',' +
-'\n                 \'Merry Christmas my love\',' +
-'\n                 \'A happy Christmas to all the family\',' +
-'\n                 \'You\\\'re all I want for Christmas\',' +
-'\n                 \'Get well soon\'];' +
-'\n' +
-'\nfor (let i = 0; i &lt; greetings.length; i++) {' +
-'\n  let input = greetings[i];' +
-'\n  if (greetings[i].indexOf(\'Christmas\') !== -1) {' +
-'\n    let result = input;' +
-'\n    let listItem = document.createElement(\'li\');' +
-'\n    listItem.textContent = result;' +
-'\n    list.appendChild(listItem);' +
-'\n  }' +
-'\n}';
-
-var solutionEntry = jsSolution;
-
-textarea.addEventListener('input', updateCode);
-window.addEventListener('load', updateCode);
-
-// stop tab key tabbing out of textarea and
-// make it write a tab at the caret position instead
-
-textarea.onkeydown = function(e){
- if (e.keyCode === 9) {
- e.preventDefault();
- insertAtCaret('\t');
- }
-
- if (e.keyCode === 27) {
- textarea.blur();
- }
-};
-
-function insertAtCaret(text) {
- var scrollPos = textarea.scrollTop;
- var caretPos = textarea.selectionStart;
-
- var front = (textarea.value).substring(0, caretPos);
- var back = (textarea.value).substring(textarea.selectionEnd, textarea.value.length);
- textarea.value = front + text + back;
- caretPos = caretPos + text.length;
- textarea.selectionStart = caretPos;
- textarea.selectionEnd = caretPos;
- textarea.focus();
- textarea.scrollTop = scrollPos;
-}
-
-// Update the saved userCode every time the user updates the text area code
-
-textarea.onkeyup = function(){
- // We only want to save the state when the user code is being shown,
- // not the solution, so that solution is not saved over the user code
- if(solution.value === 'Show solution') {
- userEntry = textarea.value;
- } else {
- solutionEntry = textarea.value;
- }
-
- updateCode();
-};</pre>
-</div>
-
-<p>{{ EmbedLiveSample('Playable_code', '100%', 590, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<h3 id="שינוי_אותיות_גדולות_וקטנות">שינוי אותיות גדולות וקטנות</h3>
-
-<p>בתרגיל זה יש לנו שמות של ערים בבריטניה, אך יש ערבוב של אותיות גדולות וקטנות בשמות הערים. אנחנו רוצים שתשנו את המחרוזות כך שכולן יהיו עם אותיות קטנות, למעט האות הראשונה שתהיה אות גדולה. דרך מומלצת לעשות זאת:</p>
-
-<ol>
- <li>החליפו את כל המחרוזת שנמצאת משתנה <code>input</code> למחרוזת עם אותיות קטנות ואחסנו את התוצאה במשתנה חדש.</li>
- <li>נסו לקבל את האות הראשונה של המחרוזת המאוחסנת במשתנה החדש שיצרתם ואחסנו את האות הראשונה במשתנה חדש נוסף.</li>
- <li>השתמשו במשתנה זה כמשתנה המכיל את מחרוזת המשנה והחליפו את האות הראשונה לאות גדולה. אחסנו את התוצאה של ההחלפה במשתנה חדש.</li>
- <li>שנו את הערך של המשתנה <code>result</code> כך שייה שווה לתוצאה הסופית ולא <code>input</code>.</li>
-</ol>
-
-<div class="note">
-<p><strong>רמז</strong>: הפרמטרים של מתודות של מחרוזות לא חייבים להיות מחרוזות מפורשות אלא הם יכולים להיות גם משתנים וגם משתנים שמופעלים עליהן מתודות נוספות.</p>
-</div>
-
-<div class="hidden">
-<h6 id="Playable_code_2">Playable code 2</h6>
-
-<pre class="brush: html">&lt;h2&gt;Live output&lt;/h2&gt;
-
-&lt;div class="output" style="min-height: 125px;"&gt;
-
-&lt;ul&gt;
-
-&lt;/ul&gt;
-
-&lt;/div&gt;
-
-&lt;h2&gt;Editable code&lt;/h2&gt;
-&lt;p class="a11y-label"&gt;Press Esc to move focus away from the code area (Tab inserts a tab character).&lt;/p&gt;
-
-&lt;textarea id="code" class="playable-code" style="height: 250px; width: 95%"&gt;
-const list = document.querySelector('.output ul');
-list.innerHTML = '';
-let cities = ['lonDon', 'ManCHESTer', 'BiRmiNGHAM', 'liVERpoOL'];
-
-for (let i = 0; i &lt; cities.length; i++) {
- let input = cities[i];
- // write your code just below here
-
- let result = input;
- let listItem = document.createElement('li');
- listItem.textContent = result;
- list.appendChild(listItem);
-}
-&lt;/textarea&gt;
-
-&lt;div class="playable-buttons"&gt;
- &lt;input id="reset" type="button" value="Reset"&gt;
- &lt;input id="solution" type="button" value="Show solution"&gt;
-&lt;/div&gt;
-</pre>
-
-<pre class="brush: css">html {
- font-family: sans-serif;
-}
-
-h2 {
- font-size: 16px;
-}
-
-.a11y-label {
- margin: 0;
- text-align: right;
- font-size: 0.7rem;
- width: 98%;
-}
-
-body {
- margin: 10px;
- background: #f5f9fa;
-}</pre>
-
-<pre class="brush: js">var textarea = document.getElementById('code');
-var reset = document.getElementById('reset');
-var solution = document.getElementById('solution');
-var code = textarea.value;
-var userEntry = textarea.value;
-
-function updateCode() {
- eval(textarea.value);
-}
-
-reset.addEventListener('click', function() {
- textarea.value = code;
- userEntry = textarea.value;
- solutionEntry = jsSolution;
- solution.value = 'Show solution';
- updateCode();
-});
-
-solution.addEventListener('click', function() {
- if(solution.value === 'Show solution') {
- textarea.value = solutionEntry;
- solution.value = 'Hide solution';
- } else {
- textarea.value = userEntry;
- solution.value = 'Show solution';
- }
- updateCode();
-});
-
-var jsSolution = 'const list = document.querySelector(\'.output ul\');' +
-'\nlist.innerHTML = \'\';' +
-'\nlet cities = [\'lonDon\', \'ManCHESTer\', \'BiRmiNGHAM\', \'liVERpoOL\'];' +
-'\n' +
-'\nfor (let i = 0; i &lt; cities.length; i++) {' +
-'\n  let input = cities[i];' +
-'\n  let lower = input.toLowerCase();' +
-'\n  let firstLetter = lower.slice(0,1);' +
-'\n  let capitalized = lower.replace(firstLetter,firstLetter.toUpperCase());' +
-'\n  let result = capitalized;' +
-'\n  let listItem = document.createElement(\'li\');' +
-'\n  listItem.textContent = result;' +
-'\n  list.appendChild(listItem);' +
-'\n' +
-'\n}';
-
-var solutionEntry = jsSolution;
-
-textarea.addEventListener('input', updateCode);
-window.addEventListener('load', updateCode);
-
-// stop tab key tabbing out of textarea and
-// make it write a tab at the caret position instead
-
-textarea.onkeydown = function(e){
- if (e.keyCode === 9) {
- e.preventDefault();
- insertAtCaret('\t');
- }
-
- if (e.keyCode === 27) {
- textarea.blur();
- }
-};
-
-function insertAtCaret(text) {
- var scrollPos = textarea.scrollTop;
- var caretPos = textarea.selectionStart;
-
- var front = (textarea.value).substring(0, caretPos);
- var back = (textarea.value).substring(textarea.selectionEnd, textarea.value.length);
- textarea.value = front + text + back;
- caretPos = caretPos + text.length;
- textarea.selectionStart = caretPos;
- textarea.selectionEnd = caretPos;
- textarea.focus();
- textarea.scrollTop = scrollPos;
-}
-
-// Update the saved userCode every time the user updates the text area code
-
-textarea.onkeyup = function(){
- // We only want to save the state when the user code is being shown,
- // not the solution, so that solution is not saved over the user code
- if(solution.value === 'Show solution') {
- userEntry = textarea.value;
- } else {
- solutionEntry = textarea.value;
- }
-
- updateCode();
-};</pre>
-</div>
-
-<p>{{ EmbedLiveSample('Playable_code_2', '100%', 550, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<h3 id="חילוץ_וחיבור_מחרוזות">חילוץ וחיבור מחרוזות</h3>
-
-<p>בתרגיל זה, יש לנו מערך שכולל מס׳ מחרוזות המכילות מידע על תחנות רכבת באנגליה. המחרוזות הן פריטי מידע המכילים 3 אותיות עם קוד התחנה, לאחר מכן מידע ממוחשב כלשהו ולאחריו הסימן <code>;</code> ולאחר מכן שם התחנה. לדוגמא:</p>
-
-<pre>MAN675847583748sjt567654;Manchester Piccadilly</pre>
-
-<p>אנו רוצים שתחלצו את קוד התחנה ואת שם התחנה, ותאחסנו אותה במחרוזת חדשה במבנה הבא:</p>
-
-<pre>MAN: Manchester Piccadilly</pre>
-
-<p>אנו ממליצים לכם לבצע זאת בצורה הבאה:</p>
-
-<ol>
- <li>חלצו את שלושת האותיות שהן קוד התחנה ואחסנו אותן במשתנה חדש.</li>
- <li>מצאו את האינדקס (מיקום) של התו <code>;</code>.</li>
- <li>חלצו את שם התחנה באמצעות האינדקס של תו <code>;</code> כנקודת התחלה ואחסנו את התוצאה במשתנה חדש.</li>
- <li>אחדו בין שני המשתנים ביחד עם מחרוזת רגילה למחרוזת אחת שלמה.</li>
- <li>שנו את הערך של משתנה  <code>result</code> שיהיה שווה לערך של המחרוזת החדשה ולא של <code>input</code>.</li>
-</ol>
-
-<div class="hidden">
-<h6 id="קוד_נוסף_לתרגול">קוד נוסף לתרגול</h6>
-
-<pre class="brush: html">&lt;h2&gt;Live output&lt;/h2&gt;
-
-&lt;div class="output" style="min-height: 125px;"&gt;
-
-&lt;ul&gt;
-
-&lt;/ul&gt;
-
-&lt;/div&gt;
-
-&lt;h2&gt;Editable code&lt;/h2&gt;
-&lt;p class="a11y-label"&gt;Press Esc to move focus away from the code area (Tab inserts a tab character).&lt;/p&gt;
-
-&lt;textarea id="code" class="playable-code" style="height: 285px; width: 95%"&gt;
-const list = document.querySelector('.output ul');
-list.innerHTML = '';
-let stations = ['MAN675847583748sjt567654;Manchester Piccadilly',
- 'GNF576746573fhdg4737dh4;Greenfield',
- 'LIV5hg65hd737456236dch46dg4;Liverpool Lime Street',
- 'SYB4f65hf75f736463;Stalybridge',
- 'HUD5767ghtyfyr4536dh45dg45dg3;Huddersfield'];
-
-for (let i = 0; i &lt; stations.length; i++) {
- let input = stations[i];
- // write your code just below here
-
- let result = input;
- let listItem = document.createElement('li');
- listItem.textContent = result;
- list.appendChild(listItem);
-}
-&lt;/textarea&gt;
-
-&lt;div class="playable-buttons"&gt;
- &lt;input id="reset" type="button" value="Reset"&gt;
- &lt;input id="solution" type="button" value="Show solution"&gt;
-&lt;/div&gt;
-</pre>
-
-<pre class="brush: css">html {
- font-family: sans-serif;
-}
-
-h2 {
- font-size: 16px;
-}
-
-.a11y-label {
- margin: 0;
- text-align: right;
- font-size: 0.7rem;
- width: 98%;
-}
-
-body {
- margin: 10px;
- background: #f5f9fa;
-}
-</pre>
-
-<pre class="brush: js">var textarea = document.getElementById('code');
-var reset = document.getElementById('reset');
-var solution = document.getElementById('solution');
-var code = textarea.value;
-var userEntry = textarea.value;
-
-function updateCode() {
- eval(textarea.value);
-}
-
-reset.addEventListener('click', function() {
- textarea.value = code;
- userEntry = textarea.value;
- solutionEntry = jsSolution;
- solution.value = 'Show solution';
- updateCode();
-});
-
-solution.addEventListener('click', function() {
- if(solution.value === 'Show solution') {
- textarea.value = solutionEntry;
- solution.value = 'Hide solution';
- } else {
- textarea.value = userEntry;
- solution.value = 'Show solution';
- }
- updateCode();
-});
-
-var jsSolution = 'const list = document.querySelector(\'.output ul\');' +
-'\nlist.innerHTML = \'\';' +
-'\nlet stations = [\'MAN675847583748sjt567654;Manchester Piccadilly\',' +
-'\n                \'GNF576746573fhdg4737dh4;Greenfield\',' +
-'\n                \'LIV5hg65hd737456236dch46dg4;Liverpool Lime Street\',' +
-'\n                \'SYB4f65hf75f736463;Stalybridge\',' +
-'\n                \'HUD5767ghtyfyr4536dh45dg45dg3;Huddersfield\'];' +
-'\n' +
-'\nfor (let i = 0; i &lt; stations.length; i++) {' +
-'\n let input = stations[i];' +
-'\n let code = input.slice(0,3);' +
-'\n let semiC = input.indexOf(\';\');' +
-'\n let name = input.slice(semiC + 1);' +
-'\n let result = code + \': \' + name;' +
-'\n let listItem = document.createElement(\'li\');' +
-'\n listItem.textContent = result;' +
-'\n list.appendChild(listItem);' +
-'\n}';
-
-var solutionEntry = jsSolution;
-
-textarea.addEventListener('input', updateCode);
-window.addEventListener('load', updateCode);
-
-// stop tab key tabbing out of textarea and
-// make it write a tab at the caret position instead
-
-textarea.onkeydown = function(e){
- if (e.keyCode === 9) {
- e.preventDefault();
- insertAtCaret('\t');
- }
-
- if (e.keyCode === 27) {
- textarea.blur();
- }
-};
-
-function insertAtCaret(text) {
- var scrollPos = textarea.scrollTop;
- var caretPos = textarea.selectionStart;
-
- var front = (textarea.value).substring(0, caretPos);
- var back = (textarea.value).substring(textarea.selectionEnd, textarea.value.length);
- textarea.value = front + text + back;
- caretPos = caretPos + text.length;
- textarea.selectionStart = caretPos;
- textarea.selectionEnd = caretPos;
- textarea.focus();
- textarea.scrollTop = scrollPos;
-}
-
-// Update the saved userCode every time the user updates the text area code
-
-textarea.onkeyup = function(){
- // We only want to save the state when the user code is being shown,
- // not the solution, so that solution is not saved over the user code
- if(solution.value === 'Show solution') {
- userEntry = textarea.value;
- } else {
- solutionEntry = textarea.value;
- }
-
- updateCode();
-};</pre>
-</div>
-
-<p>{{ EmbedLiveSample('Playable_code_3', '100%', 585, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>היכולת שלנו לטפל בטקסט בדרכים שונות במהלך כתיבת הקוד שלנו היא חשובה מאוד וחשוב לשלוט בה - במיוחד ב - JavaScript שכן אתרי האינטרנט ויישומי האינטרנט נועדו לתקשורת בין אנשים. מאמר זה נועד להעניק לכם את הבסיס שאתם צריכים לדעת על מניפולציות של מחרוזת לעת עתה ויסייע לכם כשניכנס לדברים קצת יותר מורכבים. המאמר הבא יעסוק בסוג האחרון מבין סוגי המידע שנעבור עליהם כרגע - מערכים.</p>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/First_steps/Strings", "Learn/JavaScript/First_steps/Arrays", "Learn/JavaScript/First_steps")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/What_is_JavaScript">מה זה JavaScript?</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/A_first_splash">מבט ראשון ל- JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/What_went_wrong">מה השתבש? פתרון בעיות ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Variables">אחסון המידע שאנחנו צריכים - משתנים — Variables</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Math">מתמתיקה בסיסית ב-  JavaScript — מספרים ואופרטורים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Strings">התמודדות עם טקסט — מחרוזות (Strings) ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Useful_string_methods">מתודות שימושיות למחרוזות</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Arrays">מערכים - Arrays</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Silly_story_generator">תרגיל: Silly story generator</a></li>
-</ul>
diff --git a/files/he/learn/javascript/first_steps/variables/index.html b/files/he/learn/javascript/first_steps/variables/index.html
deleted file mode 100644
index 3bed3e5bb3..0000000000
--- a/files/he/learn/javascript/first_steps/variables/index.html
+++ /dev/null
@@ -1,333 +0,0 @@
----
-title: אחסון המידע שאנחנו צריכים - משתנים וקבועים
-slug: Learn/JavaScript/First_steps/Variables
-translation_of: Learn/JavaScript/First_steps/Variables
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/First_steps/What_went_wrong", "Learn/JavaScript/First_steps/Math", "Learn/JavaScript/First_steps")}}</div>
-
-<p class="summary">לאחר קריאת המאמרים הקודמים, אתם אמורים לדעת כבה מהי JavaScript ומה היא יכולה לעשות עבורנו, כיצד אנו משתמשים ביחד עם טכנולוגיות web אחרות ומה המאפיינים העיקריים שלה ממעוף הציפור. במאמר זה אנחנו ניכנס לעומק של הבסיס של השפה ונסתכל על אחד מאבני הבניין של השפה - משתנים.</p>
-
-<table class="learn-box">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>הבנה בסיסית של מחשב, הבנה בסיסית של  HTML, CSS ו - JavaScript.</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>לקבל הכרות עם הבסיס של המשתנים.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="כלים_נדרשים">כלים נדרשים</h2>
-
-<p>לאורך מאמר זה, תתבקשו להזין מספר שורות קוד בקונסולה על מנת לבדוק את ההבנה שלכם. אם אתם משתמשים בדפדפן במחשב, הדרך הכי טובה לבדוק את הקוד היא באמצעות הקונסולה של JavaScript. לפרטים נוספים אודות הקונסולה ראה <a href="/en-US/docs/Learn/Common_questions/What_are_browser_developer_tools">What are browser developer tools</a>.</p>
-
-<h2 id="מהו_משתנה">מהו משתנה?</h2>
-
-<p>משתנה הוא קופסאת אחסון או קונטיינר, לערך מסויים. כמו שאנחנו עשויים להשתמש במספר על מנת לסכום, או במחרוזת על מנת להציג טקסט. משהו מיוחד בנוגע למשתנים הוא שהערכים שלהם יכולים להשתנות. נסתכל על הדוגמא הבאה:</p>
-
-<pre class="brush: html">&lt;button&gt;Press me&lt;/button&gt;</pre>
-
-<pre class="brush: js">const button = document.querySelector('button');
-
-button.onclick = function() {
- let name = prompt('What is your name?');
- alert('Hello ' + name + ', nice to see you!');
-}</pre>
-
-<p>{{ EmbedLiveSample('What_is_a_variable', '100%', 50, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<p>בדוגמא זו, לחיצה על הכפתור תריץ מספר שורות קוד. הקוד בשורה 4 מקפיץ הודעה על גבי המסך של המשתמש ומבקש ממנו להכניס את שמו ומאחסן את הערך שהוזן במשתנה שעונה לשם <code>name</code>. הקוד בשורה 5 מקפיץ לנו הודעה נוספת עם שמו של המשתמש, שנלקח מהערך של המשתנה <code>name</code>.</p>
-
-<p>על מנת להבין מדוע זה שימושי כל כך, נסו לחשוב על דרך לרשום את הדוגמא הזו, מבלי להשתמש במשתנה. זה עלול להיראות כמו הקוד הבא:</p>
-
-<pre class="example-bad">let name = prompt('What is your name?');
-
-if (name === 'Adam') {
- alert('Hello Adam, nice to see you!');
-} else if (name === 'Alan') {
- alert('Hello Alan, nice to see you!');
-} else if (name === 'Bella') {
- alert('Hello Bella, nice to see you!');
-} else if (name === 'Bianca') {
- alert('Hello Bianca, nice to see you!');
-} else if (name === 'Chris') {
- alert('Hello Chris, nice to see you!');
-}
-
-// ... and so on ...</pre>
-
-<p>אתם אולי לא מבינים עדיין את הסינטקס להצהרה על משתנה, אבל אתם מבינים את הרעיון - אם לא היו לנו משתנים, היינו צריכים לרשום כמויות עצומות של קוד, על מנת לבדוק האם השם אשר הוכנס על ידי המשתמש תואם למה שהגדרנו ואז להציג את ההודעה המתאימה. ברור ששימוש באופציה זו אינו יעיל בשום צורה ופשוט לא יעבוד שכן לא ניתן להכניס את האפשרויות בעולם.</p>
-
-<p>קיומם של משתנים הוא הגיוני ונדרש, וככל שנלמד יותר לעומק JavaScript אנחנו נתרגל לשימוש בהם באופן טבעי.</p>
-
-<p>דבר מיוחד נוסף לגבי משתנים הוא העובדה שהם יכולים להכיל כל דבר - לא רק מחרוזת או מספרים. משתנים יכולים להכיל גם מידע מורכב ואפילו פונקציות שלמות. נלמד על כך בהמשך.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אנחנו אומרים שמשתנים מכילים ערכים. זוהי אבחנה שחשוב לשים אליה. משתנים אינם ערכים בעצמם; הם רק קופסאות אחסון - קונטיינרים, בעבור ערכים. ניתן לדמיין זאת באמצעות התמונה הבאה:</p>
-</div>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/13506/boxes.png" style="display: block; height: 436px; margin: 0px auto; width: 1052px;"></p>
-
-<h2 id="Declaring_a_variable_-_הצהרה_על_משתנה">Declaring a variable - הצהרה על משתנה</h2>
-
-<p>על מנת לעשות שימוש במשתנה, אנחנו קודם כל צריכים ליצור אותו, או יותר מדוייק, אנחנו צריכים להצהיר עליו. על מנת להצהיר על משתנה אנחנו צריכים להשתמש במילה השמורה <code>var</code> <strong>או</strong> במילה השמורה <code>let</code> ולאחריהן השם שנרצה לתת למשתנה:</p>
-
-<pre class="brush: js">let myName;
-let myAge;</pre>
-
-<p>כאן הצהרנו על שני משתנים שנקראים <code>myName</code> ו- <code>myAge</code>. נסו להזין את השורות האלו בקונסולה. לאחר מכן, נסו ליצור משתנה אחד או שניים בעצמכם.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: ב- JavaScript, כל הוראת קוד (לא כל שורת קוד) צריכה להסתיים עם הסימן <code>;</code> - אם לא נכניס סימן זה, הקוד רוב הסיכויים יעבוד, אבל אם נכניס מספר שורות קוד ביחד, כנראה שלא. אנא התרגלו להוסיף <code>;</code> בעת שאתם כותבים את הקוד שלכם.</p>
-</div>
-
-<p>אתם יכולים לבדוק האם הערכים האלו קיימים בסביבת ההרצה על ידי הדפסה של שמות המשתנים לקונסולה כפי שמתואר להלן:</p>
-
-<pre class="brush: js">myName;
-myAge;</pre>
-
-<p>כרגע למשתנים אלו אין כל ערך. אנחנו רק הצהרנו עליהם ובכך הם נוצרו, אך הם כרגע מעין ״קופסאות ריקות״. כשאנחנו מזינים את שמות המשתנים בקונסולה, קיבלנו בקונסולה <code>undefined</code>. אם לא היינו מצהירים עליהם, היינו מקבלים הודעת שגיאה אחרת. נסו להבין מה ההבדל ביניהם.</p>
-
-<pre class="brush: js">scoobyDoo;</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אל תבלבלו בין משתנה שקיים אך לא מכיל ערך לבין משתנה שלא קיים כלל. אם נחשוב עליהם כקופסאות אחסון, משתנה שהוצהר אך לא נתנו לו ערך יצר לנו קופסא לאחסון, אך לא אחסנו בו כלום. כלומר הקופסא קיימת אך ריקה. במקרה כזה נקבל את הערך <code>undefined</code>.</p>
-
-<p>לעומת זאת, משתנה שלא הוצהר, זה כאילו לא יצרנו את קופסת האחסון מלכתחילה ולכן הודעת השגיאה שנקבל היא שהדפדפן לא מוצא את המשתנה, כלומר, הוא לא מוצא את קופסאת האחסון (כי לא יצרנו אותה).</p>
-</div>
-
-<h2 id="השמת_ערך_למשתנה">השמת ערך למשתנה</h2>
-
-<p>ברגע שהצהרנו על משתנה, אנחנו יכולים לאתחל אותו עם ערך שנשים לו. אנחנו עושים זאת על ידי סימן ה-״שווה״ - <code>=</code>, ולאחריו הערך שאנחנו נרצה לשים במשתנה. לדוגמא:</p>
-
-<pre class="brush: js">myName = 'Chris';
-myAge = 37;</pre>
-
-<p>נסו להזין בקונסולה את הקוד הבא. אתם אמורים להראות שהערכים שהשמנו למשתנים מוחזרים לנו בקונסולה. שוב, אנחנו יכולים לקבל את הערך של משתנה על ידי הזנת שמו לקונסולה. ננסה זאת שוב:</p>
-
-<pre class="brush: js">myName;
-myAge;</pre>
-
-<p>ניתן להצהיר על משתנה וכן להשים לו ערך באותו זמן:</p>
-
-<pre class="brush: js">let myDog = 'Rover';</pre>
-
-<p>זו ככל הנראה תהיה הדרך שבה נרשום משתנים - הצהרה והשמה באותה שורה שכן זוהי דרך מהירה יותר מאשר לרשום הצהרה בשורה אחת והשמה של ערך בשורה אחרת.</p>
-
-<h2 id="ההבדלים_בין_var_לבין_let">ההבדלים בין var לבין let</h2>
-
-<p>בשלב זה אתם בטח שואלים ״מדוע צריכים שתי מילים שמורות על מנת להגדיר משתנים?״ או ״למה יש לנו גם את <code>let</code> וגם את <code>var</code>?״</p>
-
-<p>הסיבות הן בעיקר היסטוריות. כאשר JavaScript רק נוצרה, היה קיים רק <code>var</code>. זה עבד במרבית המקרים, אבל היו לו סוגיות שונות בצורה ובדרך שבה הוא עבד. ההתנהגות שלו הייתה יכולה להיות מבלבלת וקצת מעצבנת. לכן, <code>let</code> נוצר בגרסאות מודרניות יותר של JavaScript, והציג מילה שמורה חדשה ליצירת משתנים, אשר פועלת בצורה אחרת מהמילה השמורה <code>var</code> ומתקנת את הסוגיות שהיו עם דרך ההגדרה הקודמת. סתם לידיעה - דרך זו של שימוש במילה השמורה <code>let</code> החלה בגרסת העדכון החשובה של JavaScript שנקראת ES2015 (ES6).</p>
-
-<p>אנו נגע במספר הבדלים פשוטים ביניהם, אך לא ניגע בכולם כרגע. אנו נבין את ההבדלים ביניהם בהמשך ככל שניכנס יותר לעומק של השפה. אם תרצו להרחיב בנושא - היכנסו לקישור <a href="/en-US/docs/Web/JavaScript/Reference/Statements/let">let reference page</a>.</p>
-
-<p>נתחיל בכך שאם נרשום מספר שורות קוד שבהן נצהיר על משתנה ונשים בו ערך. אנחנו יכולים להצהיר על משתנה באמצעות שימוש במילה <code>var</code> גם לאחר שהשמנו בו ערך והתוכנית עדיין תעבוד. כלומר, המשתנה יהיה מוכר לדפדפן. לדוגמא:</p>
-
-<pre class="brush: js">myName = 'Chris';
-
-function logName() {
- console.log(myName);
-}
-
-logName();
-
-var myName;</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: קוד זה לא יעבוד כשננסה להכניס אותו שורה אחר שורה בקונסולה אלא רק כשנכניס את כל שורות קוד באמצעות JavaScript.</p>
-</div>
-
-<p>זה עובד בגלל מנגנון שנקרא <strong>Hoisting. </strong>אם תרצו להרחיב על כך, ראו <a href="/en-US/docs/Web/JavaScript/Reference/Statements/var#var_hoisting">קישור</a> לפרטים נוספים על הנושא. בקצרה המשמעות שלו היא שב-JavaScript הצהרות על משתנים (והצהרות בכללי) מבוצעות לפני שיתר הקוד רץ, כלומר, הצהרה על משתנה במקום מסויים בקוד תהיה זהה להצהרה שלו בתחילת הקוד. יחד עם זאת, חשוב לשים לב שמנגנון זה משפיע רק על הצהרה של משתנים ולא על השמה של ערכים אליהם. הערכים שלהם יושמו אליהם בהתאם לסדר ריצת הקוד. </p>
-
-<p>Hoisting לא מתבצע יותר עם המילה השמורה <code>let</code>. אם נשנה את <code>var</code> ל- <code>let</code> בדוגמא למעלה, זה יציג לנו שגיאה. זה דבר טוב כמובן - הצהרה על משתנה לאחר שאנחנו משימים לו ערך גורמת לבלבול ולקושי בקריאה והבנה של הקוד.</p>
-
-<p>בנוסף, כשאנחנו משתמשים ב- <code>var</code>, אנחנו יכולים להצהיר על המשתנה שיצרנו באמצעותו כמה פעמים שנרצה ואילו בעת שימוש ב- <code>let</code> אנחנו לא יכולים. הקוד הבא לדוגמא, יעבוד:</p>
-
-<pre class="brush: js">var myName = 'Chris';
-var myName = 'Bob';</pre>
-
-<p>אבל הקוד הבא יקפיץ לנו שגיאה בשורה השנייה:</p>
-
-<pre class="brush: js">let myName = 'Chris';
-let myName = 'Bob';</pre>
-
-<p>ולכן נצטרך לרשום אותו בצורה הבאה:</p>
-
-<pre class="brush: js">let myName = 'Chris';
-myName = 'Bob';</pre>
-
-<p>שוב, מדובר בכלל חשוב אשר נועד למנוע הצהרה חוזרת של משתנה. אנו ממליצים לבצע שימוש כמה שיותר ב- <code>let</code> מאשר ב-<code>var</code> . אין שום סיבה שנרצה להשתמש ב- <code>var</code>, אלא אם אנחנו צריכים לתמוך בגרסאות ישנות של אינטרנט אקספלורר (גרסאות ישנות אלו לא תומכות ב- <code>let</code> אלא רק החל מגרסה 11; הדפדפן אדג׳ לעומת זאת תומך במלואו ב-<code>let</code>).</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אנחנו בשלבים של עדכון הדוגמאות בקורס זה לשימוש ב- <code>let</code> במקום <code>var</code>.</p>
-</div>
-
-<h2 id="עדכון_משתנה">עדכון משתנה</h2>
-
-<p>ברגע שמשתנה הוצהר והושם לו ערך, אנחנו יכולים לשנות (או לעדכן) את הערך שנמצא באותו משתנה, פשוט על ידי השמה של ערך אחר. נסו להזין את הקוד הבא בקונסולה:</p>
-
-<pre class="brush: js">myName = 'Bob';
-myAge = 40;</pre>
-
-<h3 id="מס׳_כללים_בנוגע_לשמות_משתנים">מס׳ כללים בנוגע לשמות משתנים</h3>
-
-<p>אנחנו יכולים לקרוא למשתנים שלנו כמעט בכל שם שנרצה, אבל ישנן מס׳ הגבלות. באופן כללי, היצמדו לשימוש באותיות לועזיות (0-9, a-z, A-Z) ולתו מסוג קו תחתון.</p>
-
-<ul>
- <li>אל תשתמשו בתווים אחרים מכיוון שהם עלולים לגרום לשגיאות או שיהיה קשה להבין אותם - דמיינו שמתכנת צרפתי קורא למשתנים בשפה הצרפתית ומתכנת בריטי מנסה להבין מה פשר המשתנה.</li>
- <li>אל תשימו קו תחתון בתחילת שמו של המשתנה - קו תחתון זה משמש במספר מבנים של JavaScript על מנת להצביע על דברים ספציפיים וזה עשוי לגרום לבלבול.</li>
- <li>אל תשתמשו במספרים בתחילת השם של המשתנה. זה יגרום לשגיאה.</li>
- <li>מוסכמה מקובלת היא להשתמש ב-<a href="https://en.wikipedia.org/wiki/CamelCase#Variations_and_synonyms">״lower camel case"</a> - כאשר אנו קוראים למשתנה בשם המכיל מס׳ מילים, המילה הראשונה תתחיל באות קטנה, ואילו יתר המילים לאחר יתחילו באות גדולה.</li>
- <li>אנא תנו למשתנים שלכם שמות הגיוניים ואינטואטיביים, על מנת לנסות לתאר כמה שניתן איזה מידע הם מכילים. אל תשתמשו באותיות או במספרים לבד. מצד שני, אל תקראו למשתנים בשמות ארוכים מדי.</li>
- <li>משתנים הם case sensitive — כך לדוגמא המשתנה <code>myage</code> הוא משתנה שונה מהמשתנה <code>myAge</code>.</li>
- <li>נסו להימנע משימוש במילים השמורים של JavaScript בתור שמות למשתנים. מילים שמורות אלו אותן מילים שמרכיבות את הסינטקס של השפה. כלומר, אנחנו לא יכולים להשתמש במילים כגון: <code>var</code>, <code>function</code>, <code>let</code>, וכן גם <code>for</code> כשמות למשתנים שלנו. הדפדפן יזהה אותם כרכיבי קוד אחרים, מה שעלול לגרום רוב הסיכויים לשגיאה.</li>
-</ul>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: ניתן למצוא את רשימת המילים השמורות של השפה ב- <a href="/en-US/docs/Web/JavaScript/Reference/Lexical_grammar#Keywords">Lexical grammar — keywords</a>.</p>
-</div>
-
-<p>דוגמא למתן שמות למשתני בצורה נכונה:</p>
-
-<pre class="example-good">age
-myAge
-init
-initialColor
-finalOutputValue
-audio1
-audio2</pre>
-
-<p>דוגמא למתן שמות למשתני בצורה לא נכונה:</p>
-
-<pre class="example-bad">1
-a
-_12
-myage
-MYAGE
-var
-Document
-skjfndskjfnbdskjfb
-thisisareallylongstupidvariablenameman</pre>
-
-<p>מילים שמורות:</p>
-
-<pre class="example-invalid">var
-Document
-</pre>
-
-<p>נסו ליצור מספר משתנים חדשים בהתאם לכללים שציינו למעלה.</p>
-
-<h2 id="סוגי_משתנים">סוגי משתנים</h2>
-
-<p>ישנם מס׳ סוגים של מידע שנוכל לאחסן במשתנים. בחלק הזה אנחנו נתאר אותם בקצרה. במאמרים הבאים אנו נלמד אותם לעומק.</p>
-
-<h3 id="Numbers_-_מספרים">Numbers - מספרים</h3>
-
-<p>אנחנו יכולים לאחסן מספרים כמשתנים, בין אם הם מספר שלם, כמו 30, או בין אם הם מספר עשרוני, כמו 2.456. ב- JavaScript אנחנו לא צריכים להצהיר על סוג המשתנה, בשונה מכמה שפות תכנות אחרות. כשאנחנו נותנים למשתנה ערך מסוג מספר, אנחנו <strong>לא</strong> משימים את הערך בין גרשיים. לדוגמא:</p>
-
-<pre class="brush: js">let myAge = 17;</pre>
-
-<h3 id="Strings_-_מחרוזות">Strings - מחרוזות</h3>
-
-<p>מחרוזות אלו חלקים של טקסט. כאשר אנחנו נותנים למשתנה ערך של מחרוזת, אנחנו צריכים לעטוף את המחרוזת בגרשיים כפולות <code>" "</code> או בגרש בודד <code>' '</code> אחרת JavaScript עלולה לנסות לפרש את הקוד כשם נוסף למשתנה. לדוגמא:</p>
-
-<pre class="brush: js">let dolphinGoodbye = 'So long and thanks for all the fish';</pre>
-
-<h3 id="Booleans_-_בוליאנים">Booleans - בוליאנים</h3>
-
-<p>בוליאנים אלו ערכי אמת או שקר. משתנים שמכילים ערך בוליאני יכולים לקבל 2 ערכים: או ערך אמת <code>true</code> או ערך שקר <code>false</code>. לדוגמא:</p>
-
-<pre class="brush: js">let iAmAlive = true;</pre>
-
-<p>בפועל, אנחנו נשתמש במשתנה מסוג בוליאני בדרך הבאה:</p>
-
-<pre class="brush: js">let test = 6 &lt; 3;</pre>
-
-<p>כאן ביצענו שימוש באופרטור ״קטן מ-״ (<code>&lt;</code>) על מנת לבדוק האם 6 קטן מ-3. כפי שניתן לצפות, זה יחזיר לנו <code>false</code> מכיוון ש-6 לא קטן מ-3. נלמד יותר לעומק על אופרטורים אלו בהמשך הקורס.</p>
-
-<h3 id="Arrays_-_מערכים">Arrays - מערכים</h3>
-
-<p>מערך הוא בעצם אובייקט יחיד, המכיל מספר ערכים המתוחמים בתוך סוגריים מרובעות. נסו להכניס את הקוד הבא לתוך הקונסולה:</p>
-
-<pre class="brush: js">let myNameArray = ['Chris', 'Bob', 'Jim'];
-let myNumberArray = [10, 15, 40];</pre>
-
-<p>ברגע שהמערכים האלו מוצהרים, אנחנו יכולים לגשת לכל איבר במערך באמצעות ציון המיקום שלו במערך. נסו את הקוד הבא:</p>
-
-<pre class="brush: js">myNameArray[0]; // should return 'Chris'
-myNumberArray[2]; // should return 40</pre>
-
-<p>הסוגרים המרובעות מצביעות על האינדקס המתאים למיקום של האיבר שאנחנו רוצים שיוחזר. שימו לב שהמיקומים במערך מתחילים מ-0. כלומר, האיבר הראשון במערך הוא באינדקס 0.</p>
-
-<p>נרחיב על מערכים ב<a href="/en-US/docs/Learn/JavaScript/First_steps/Arrays">מאמר בהמשך הקורס</a>.</p>
-
-<h3 id="Objects_-_אובייקטים">Objects - אובייקטים</h3>
-
-<p>בתכנות, אובייקט הוא מבנה של קוד שמדמה אובייקט בעולם האמיתי. הוא מייצג מעין קופסא המכילה מידע על הגובה שלו, הרוחב שלו, האורך שלו או מאפיינים נוספים. אנחנו יכולים לדוגמא לייצר אובייקט שידמה אדם, ואובייקט זה יכיל מידע על שמו, גובה, משקל, שפה מדוברת וכד׳.</p>
-
-<p>הכניסו את הקוד הבא בקונסולה:</p>
-
-<pre class="brush: js">let dog = { name : 'Spot', breed : 'Dalmatian' };</pre>
-
-<p>על מנת לאחזר מידע המאוחסן באובייקט, השתמשו בקוד הבא:</p>
-
-<pre class="brush: js">dog.name</pre>
-
-<p>אנו לא נעמיק בנושא אובייקטים כעת - אנו נלמד לעומק את הנושא ב<a href="/en-US/docs/Learn/JavaScript/Objects">מאמר</a> בהמשך.</p>
-
-<h2 id="השמת_משתנים_דינאמית">השמת משתנים דינאמית</h2>
-
-<p>JavaScript היא שפה דינאמית. שלא כמו שפות אחרת, ב- JavaScript אנחנו לא צריכים לציין איזה סוג של מידע יאוסן בתוך המשתנה (מספרים, מחרוזות, מערכים וכד׳).</p>
-
-<p>לדוגמא, אם אנחנו מצהירים על משתנה ונותנים לו ערך שעטוף בגרשיים, הדפדפן יתייחס אליו כמחרוזת:</p>
-
-<pre class="brush: js">let myString = 'Hello';</pre>
-
-<p>אם נכניס מספרים בתוך הגרשיים, הוא עדיין יהיה מחרוזת!</p>
-
-<pre class="brush: js">let myNumber = '500'; // oops, this is still a string
-typeof myNumber;
-myNumber = 500; // much better — now this is a number
-typeof myNumber;</pre>
-
-<p>נסו להכניס את הקוד שלמעלה לקונסולה שורה אחר שורה, וראו התוצאות. אתם תשימו לב שאתם משתמשים באופטור מיוחד שנקרא <a href="/en-US/docs/Web/JavaScript/Reference/Operators/typeof">typeof</a> - אופרטור זה מחזיר לנו את סוג הערך המאוחסן במשתנה שהעברנו לו. הפעם הראשונה שהרצנו את האופרטור הזה, הוא החזיר <code>string</code>, שכן באותה נקודה, המשתנה <code>myNumber</code> מכיל מחרוזת, <code>'500'</code>. בדקו מה הקונסולה תחזיר כשנזין את שתי השורות האחרונות.</p>
-
-<h2 id="Constants_-_קבועים">Constants - קבועים</h2>
-
-<p>להרבה שפות תכנות יש את הקונספט של <em>constant</em> או <em>קבוע</em> — משתנה שברגע שהכנסו לו ערך, אותו ערך לא משתנה. ישנן הרבה סיבות מדוע נרצה להשתמש בהם, מסיבות אבטחה - (אם סקריפט של אתר אחר מנסה לשנות את הערכים זה עלול ליצור בעיות) עד לפתרון שגיאות של הקוד והבנה שלו (קשה יותר לשנות בטעות ערכים שלא אמורים להשתנות).</p>
-
-<p>בשלביה המוקדים של השפה, קבועים לא היו קיימים. כעת יש בשפה קבועים ואנו משתמשים במילה השמורה <code>const</code>, על מנת להצהיר עליהם ולהשים בערך ערך שלא ישתנה:</p>
-
-<pre class="brush: js">const daysInWeek = 7<span class="message-body-wrapper"><span class="message-flex-body"><span class="devtools-monospace message-body"><span class="objectBox objectBox-number">;
-const hoursInDay = 24;</span></span></span></span></pre>
-
-<p><span class="message-body-wrapper"><span class="message-flex-body"><span class="devtools-monospace message-body"><span class="objectBox objectBox-number"><code>const</code> עובד בדיוק כמו <code>let</code>, למעט העובדה שאנחנו לא יכולים לתת ל- <code>const</code> ערך חדש. בדוגמא הבאה, השורה השנייה תציג לנו שגיאה בקונסולה:</span></span></span></span></p>
-
-<pre class="brush: js">const daysInWeek = 7<span class="message-body-wrapper"><span class="message-flex-body"><span class="devtools-monospace message-body"><span class="objectBox objectBox-number">;
-daysInWeek = 8;</span></span></span></span></pre>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>במאמר זה למדנו אודות משתנים - מהם, כיצד ליצור אותם ומה ההבדל בינם לקבועים. במאמר הבא אנחנו נלמד אודות מתמתיקה בסיסית ב-JavaScript.</p>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/First_steps/What_went_wrong", "Learn/JavaScript/First_steps/Maths", "Learn/JavaScript/First_steps")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/What_is_JavaScript">מה זה JavaScript?</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/A_first_splash">מבט ראשון ל- JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/What_went_wrong">מה השתבש? פתרון בעיות ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Variables">אחסון המידע שאנחנו צריכים - משתנים — Variables</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Math">מתמתיקה בסיסית ב-  JavaScript — מספרים ואופרטורים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Strings">התמודדות עם טקסט — מחרוזות (Strings) ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Useful_string_methods">מתודות שימושיות למחרוזות</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Arrays">מערכים - Arrays</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Silly_story_generator">תרגיל: Silly story generator</a></li>
-</ul>
diff --git a/files/he/learn/javascript/first_steps/what_is_javascript/index.html b/files/he/learn/javascript/first_steps/what_is_javascript/index.html
deleted file mode 100644
index 4ad34985e7..0000000000
--- a/files/he/learn/javascript/first_steps/what_is_javascript/index.html
+++ /dev/null
@@ -1,447 +0,0 @@
----
-title: מה זה JavaScript?
-slug: Learn/JavaScript/First_steps/What_is_JavaScript
-tags:
- - API
- - JavaScript
- - דרכים להוסיף JavaScript לדף
- - הסבר על JavaScript
- - מדריך
- - מה זה JavaScript?
- - מתחילים
-translation_of: Learn/JavaScript/First_steps/What_is_JavaScript
----
-<div>{{LearnSidebar}} </div>
-
-<div>{{NextMenu("Learn/JavaScript/First_steps/A_first_splash", "Learn/JavaScript/First_steps")}}</div>
-
-<p class="summary">ברוך הבא לקורס JavaScript למתחילים של MDN. במאמר זה נסתכל על JavaScript ממעוף הציפור, ונענה על שאלות כגון ״מה זה JavaScript?״ ״מה ניתן לבצע איתה?״ ונוודא שאתם מרגישים בנוח עם מטרתה. </p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">Prerequisites:</th>
- <td>ידע בסיסי בשימוש במחשב וכן הבנה בסיסית של HTML ו-CSS.</td>
- </tr>
- <tr>
- <th scope="row">Objective:</th>
- <td>להכיר מעט את JavaScript, מה היא יכולה לעשות, ואיך היא קשורה לאתר אינטרנט.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="הגדרה_ממבט_על">הגדרה ממבט על</h2>
-
-<p>JavaScript היא שפת תכנות (שפת סקריפט) אשר מאפשרת לכם ליישם דברים מורכבים על גבי דפי האינטרנט - בכל פעם שדף אינטרנט מבצע משהו דינאמי כגון עדכון תכנים באופן עיתי, הצגת מפה אינטרקאטיבית, אנימציות שונות דו ותלת מימדיות וכד׳ (בניגוד לדף אינטרנט סטטי שרק מציג תוכן ללא שינוי כלשהו בדף), ניתן להיות בטוח ש JavaScript לוקחת בכך חלק. JavaScript היא החלק השלישי ב-״עוגת״ טכנולוגיות ה-web כאשר את שתי הטכנולוגיות האחרות למדנו בחלקים אחרים של איזור הלמידה (<a href="/en-US/docs/Learn/HTML">HTML</a> and <a href="/en-US/docs/Learn/CSS">CSS</a>).   </p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/13502/cake.png" style="display: block; margin: 0 auto;"></p>
-
-<ul>
- <li>{{glossary("HTML")}} היא שפת סימון תגיות (ואינה שפת תכנות) שאנו משתמשים בה על מנת לבנות את תוכן הדף ולהעניק לו משמעות, לדוגמא, הגדרת פסקאות, כותרות, טבלאות מידע, סרגל ניווט וכן הטמעת תמונות ווידאו באתר.</li>
- <li>{{glossary("CSS")}} היא בעצם סט של כללים המאפשר לנו להחיל כללי עיצוב שונים על תוכן דף ה-HTML בדרכים שונות כגון: רקע, גופן, צורת הפריסה של התוכן על גבי הדף, וכד׳. </li>
- <li>{{glossary("JavaScript")}} היא שפת התכנות אשר מאפשרת לנו ליצור באופן דינאמי תוכן, לעדכן תוכן באופן דינאמי, לשלוט במולטימדיה, להנפיש תמונות, ועוד ועוד. </li>
-</ul>
-
-<p>שלושת השפות בנויות כשכבות אחת על גבי השנייה, כפי שניתן לראות באיור למעלה. ננסה להבין זאת באמצעות טקסט פשוט. נסמן את הטקסט באמצעות HTML, על מנת לתת לו מבנה ומטרה. בדוגמא הנוכחית למטה, סימנו את הטקסט באלמנט מסוג פסקה <code>&lt;p&gt;</code>.</p>
-
-<pre class="brush: html">&lt;p&gt;Player 1: Chris&lt;/p&gt;</pre>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/13422/just-html.png" style="height: 28px; width: 108px;"></p>
-
-<p>לאחר מכן, נוסיף כמה כללי CSS  על מנת לעצב את האלמנט בצורה מסויימת:</p>
-
-<pre class="brush: css">p {
- font-family: 'helvetica neue', helvetica, sans-serif;
- letter-spacing: 1px;
- text-transform: uppercase;
- text-align: center;
- border: 2px solid rgba(0,0,200,0.6);
- background: rgba(0,0,200,0.3);
- color: rgba(0,0,200,0.6);
- box-shadow: 1px 1px 2px rgba(0,0,200,0.4);
- border-radius: 10px;
- padding: 3px 10px;
- display: inline-block;
- cursor: pointer;
-}</pre>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/13424/html-and-css.png" style="height: 48px; width: 187px;"></p>
-
-<p>לבסוף, נוסיף קוד JavaScript על מנת להעניק דינאמיות והתנהגות מסוימת:</p>
-
-<pre class="brush: js">const para = document.querySelector('p');
-
-para.addEventListener('click', updateName);
-
-function updateName() {
- let name = prompt('Enter a new name');
- para.textContent = 'Player 1: ' + name;
-}
-</pre>
-
-<p>{{ EmbedLiveSample('A_high-level_definition', '100%', 80, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<p>נסו ללחוץ על הגרסה האחרונה של הטקסט וראו מה קורה.אתם יכולים למצוא את קוד המקור <a href="https://github.com/mdn/learning-area/blob/master/javascript/introduction-to-js-1/what-is-js/javascript-label.html">כאן</a>, או <a href="http://mdn.github.io/learning-area/javascript/introduction-to-js-1/what-is-js/javascript-label.html">דף אינטרנט</a>.</p>
-
-<p>JavaScript יכולה לבצע הרבה יותר - נעמיק בכך בהמשך הלמידה.</p>
-
-<h2 id="אז_מה_ניתן_לבצע_עם_JavaScript">אז מה ניתן לבצע עם JavaScript?</h2>
-
-<p>הבסיס של JavaScipt מכיל כמה ממאפייני התכנות הנפוצים, אשר מאפשרים לנו לבצע פעולות כגון: </p>
-
-<ul>
- <li><strong>אחסון ערכים במשתנים</strong> - בדוגמא לעיל, ביקשנו מהמשתמש שיכניס את שמו ולאחר מכן, אחסנו את השם שהמשתמש הזין במשתנה בשם <code>name</code>.</li>
- <li><strong>ביצוע פעולות שונות על טקסט (ובתכנות ״מחרוזת״) </strong>- בדוגמא לעיל, לקנו את המחרוזת ״:Player 1״ ועליה וחיברנו אותה (שורה 8) למשתנה  <code>name</code>.</li>
- <li><strong>הרצת קוד כתגובה לאירועים מסויימים המתרחשים על גבי דף האינטרנט </strong>- השתמשו באירוע (Event) מסוג  {{Event("click")}} על מנת לאתר התרחשות של לחיצת עכבר, ובתגובה להתרחשות אירוע זה, הרצנו קוד אשר מעדכן את תוכן הטקסט.</li>
- <li><strong>ועוד הרבה יותר. </strong></li>
-</ul>
-
-<p>דבר מעניין נוסף הוא הפונקציונליות אשר בנויה על גבי הבסיס של שפת JavaScript. אותם API (<strong>Application Programming Interfaces</strong> ) מעניקים לנו אפשרויות משמעותיות אשר נוכל להשתמש בהם כאשר אנו כותבים את קוד ה-JavaScript שלנו. API בתרגום לעברית זה ״ממשק תכנות יישומים״.  </p>
-
-<p>API אלו חלקי קוד מוכנים אשר מאפשרים לנו כמפתחים להטמיע תוכניות אשר בצורה אחרת היה קשה מאוד להטמיע או אף בלתי אפשרי. הם מאפשרים לנו את הנוחות בתכנות, כפי שרהיטים מוכנים להרכבה (לדוגמא: איקאה) מאפשרים את הנוחות (המסויימת) בעיצוב דירה. הרבה יותר נוח לקחת סט מוכן להרכבה של מדף המכיל פלטת עץ מוכנה, עם ברגים ומעמד על מנת ליצור מדף קיר, מאשר להתחיל מהבסיס: למצוא את העץ המתאים, לחתוך אותו לגודל המתאים, למצוא את הברגים המתאימים ועוד. </p>
-
-<p>באופן כללי, API מחולקים לשתי קטגוריות:</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/13508/browser.png" style="display: block; height: 511px; margin: 0px auto; width: 815px;"></p>
-
-<p><strong>API של הדפדפן</strong> (<strong>Browser APIs</strong>) - אלו API מובנים בתוך דפדפן האינטרנט, ומאפשרים לקבל מידע/נתונים מסביבת העבודה של המשתמש או לבצע דברים שימושים מורכבים. לדוגמא: </p>
-
-<ul>
- <li>The {{domxref("Document_Object_Model","DOM (Document Object Model) API")}} מאפשר לנו לבצע מניפולציות ופעולות שונות על HTML ו-CSS כגון יצירה, שינוי, מחיקה, עיצוב של דף האינטרנט באופן דינאמי וכד׳. כך, בכל פעם שאנו רואים חלונית קופצת על גבי דף, או תוכן חדש שמוצג בדף האינטרנט, זו פעולה של ה-DOM.</li>
- <li>The {{domxref("Geolocation","Geolocation API")}}מאפשר לנו לקבל מידע גיאוגרפי. כך בעצם  <a href="https://www.google.com/maps">Google Maps</a> מאתר את המיקום שלנו ומציג אותו על גבי המפה.</li>
- <li>The {{domxref("Canvas_API","Canvas")}} and {{domxref("WebGL_API","WebGL")}} APIs מאפשרים לנו ליצור גרפיקות מונפשות ואנימציות, דו מימדיות ותלת מימדיות. ניתן לראות דוגמאות מדהימות שאנשים יצרו באמצעותו.  technologies —see <a href="https://www.chromeexperiments.com">Chrome Experiments</a> and <a href="http://webglsamples.org/">webglsamples</a>.</li>
- <li><a href="https://developer.mozilla.org/en-US/Apps/Fundamentals/Audio_and_video_delivery">Audio and Video APIs</a> כמו {{domxref("HTMLMediaElement")}} and {{domxref("WebRTC API", "WebRTC")}}  מאפשרים לנו לבצע דברים מעניינים עם מולטימדיה, כגון להפעיל וידאו ואודיו בדף עצמו, או ליצור וידאו באמצעות שימוש במצלמה של המשתמש (או של משתמש אחר) ועוד.  ראו דוגמא פשוטה על מנת להבין את הרעיון ב-<a href="http://chrisdavidmills.github.io/snapshot/">Snapshot demo</a>.</li>
-</ul>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: הרבה מהדוגמאות אשר הובאו למעלה, לא יעבדו בדפדפנים ישנים - במהלך הניסוי והטעיה במהלך הקורס, אנו נצטרך לעשות שימוש בדפדפנים מתקדמים על מנת לעשות שימוש בדוגמאות אלו. דפדפנים אלו יכולים להיות כרום, פיירפוקס, אדג׳, אופרה.</p>
-
-<p>כמו כן, ככל ונתקדם בשלבי הפיתוח של הקוד, נצטרך לקחת בחשבון <a href="/en-US/docs/Learn/Tools_and_testing/Cross_browser_testing">בדיקת תאימות לדפדפנים השונים</a> יותר לעומק, על מנת שנוכל לאפשר ללקוח להשתמש בכל הפונקציונליות שהגדרנו. </p>
-</div>
-
-<p><strong>API של צד שלישי</strong> לא בנויים בתוך הדפדפן כברירת מחדל, ובעיקרון אנחנו נצטרך לקבל את הקוד והמידע שלהם ממקום אחר באינטרט. לדוגמא:</p>
-
-<ul>
- <li><a href="https://dev.twitter.com/overview/documentation">Twitter API</a> מאפשר לנו לדוגמא להציג את הציוצים האחרונים שלנו באתר שלנו.</li>
- <li><a href="https://developers.google.com/maps/">Google Maps API</a> וכן <a href="https://wiki.openstreetmap.org/wiki/API">OpenStreetMap API</a> מאפשרים לנו להטמיע מפות באתר שלנו וכן מתן הגדרות מסויימות למפות אלו.</li>
-</ul>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: APIs אלו הם נושאים מתקדמים יחסית, ואנחנו לא נגע בהם במודול זה. ניתן למצוא מידע נוסף ב- <a href="/en-US/docs/Learn/JavaScript/Client-side_web_APIs">Client-side web APIs module</a>.</p>
-</div>
-
-<p>כמובן שיש עוד המון אפשרויות!, יחד עם זאת, כנראה שלאחר למידה כה קצרה של JavaScript, עדיין לא ניצור את פייסבוק או גוגל הבאים, אך ככל שנתקדם במדריך ונבין לעומק הבסיס, נתקדם בדרך הנכונה. </p>
-
-<h2 id="מה_JavaScript_עושה_על_גבי_דף_האינטרנט">מה JavaScript עושה על גבי דף האינטרנט?</h2>
-
-<p>כאן אנו נתחיל להסתכל על קוד, ובזמן שנעשה זאת, ננסה להבין מה קורה בפועל, כאשר JavaScript רצה בדף האינטרנט.</p>
-
-<p>בוא נחזור בקצרה על מה בפועל קורה כשאנו מעלים דף אינטרנט בדפדפן. (דיברנו על כך במאמר <a href="/en-US/Learn/CSS/Introduction_to_CSS/How_CSS_works#How_does_CSS_actually_work">כיצד CSS עובד</a>).  </p>
-
-<p>כאשר אנו מעלים דף אינטרנט בדפדפן, אנו מריצים את הקוד (HTML, CSS ו-JavaScript) בתוך סביבת הריצה (לשונית הדפדפן). ניתן לדמות את זה למפעל אשר מקבל אליו את חומרי הגלם (הקוד) ומייצר מכך מוצר מסויים (דף האינטרנט).</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/13504/execution.png" style="display: block; margin: 0 auto;"></p>
-
-<p>JavaScript מורצת על ידי מנוע JavaScript של הדפדפן עצמו, <u><strong>לאחר</strong></u> שה-HTML וה-CSS הורכבו והושמו בדף האינטרנט שלנו. דבר זה מאפשר לנו להבטיח שהמבנה והעיצוב של דף האינטרנט הושלם ונמצא במקומו בזמן ש-JavaScript תחל לרוץ. </p>
-
-<p>מכיוון ששימוש נפוץ ועיקרי ב-JavaScript הוא האפשרות להעניק דינאמיות ולשנות HTML ו-CSS באמצעות Document Object Model API, מדובר בדבר הכרחי על מנת לאפשר זאת, שכן אם JavaScript תרוץ לפני שרכיבי ה-HTML וכללי העיצוב של CSS נטענו במלואם, עלולים להתרחש שגיאות באותה דינאמיות שביקשנו להעניק באמצעות JavaScript.</p>
-
-<h3 id="אבטחה_בדפדפן">אבטחה בדפדפן</h3>
-
-<p>לכל לשונית בדפדפן יש מעין ״סל״ או מתחם נפרד להרצת הקוד - בשפה מקצועית סלים או מתחמים אלו נקראים ״סביבות הרצה״ - זאת אומרת, שברוב המקרים, קוד בכל לשונית ירוץ באופן נפרד לחלוטין מלשוניות אחרות בדפדפן, ולא יוכל לגשת או להשפיע על הקוד בלשונית אחרת. דבר זה הינו דבר חשוב בהיבטי אבטחה - שכן אחרת, זה היה פותח אפשרות נוספות להאקרים לפרוץ לאתרים או לגנוב מידע. </p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: יש דרכים להעביר קוד ומידע בין אתרים/לשוניות שונות בצורה בטוחה, אך נושאים אלו הינם מתקדמים ולא נדון בהם בקורס זה.</p>
-</div>
-
-<h3 id="סדר_הריצה_של_JavaScript">סדר הריצה של JavaScript </h3>
-
-<p>כאשר הדפדפן נתקל בבלוק של קוד JavaScript, באופן כללי הוא יריץ את הקוד מלמעלה למטה. המשמעות היא שצריך לשים לב לסדר שבו אנו רושמים את הקוד. לדוגמא, בוא נחזור לבלוק הקוד שראינו בדוגמא הקודמת:</p>
-
-<pre class="brush: js">const para = document.querySelector('p');
-
-para.addEventListener('click', updateName);
-
-function updateName() {
- let name = prompt('Enter a new name');
- para.textContent = 'Player 1: ' + name;
-}</pre>
-
-<p><u>שורה 1</u>: בקוד זה אנחנו בעצם מגדירים משתנה מסוג <code>const</code> (נרחיב עליו בהמשך) וקוראים לו בשם <code>para</code>, ובאמצעות ה-DOM אנחנו בוחרים את האלמנט HTML הראשון מסוג <code>p</code>.</p>
-
-<p><u>שורה 2:</u> אנו מצמידים למשתנה שהגדרנו מתודה בשם <code>event listener</code> (נרחיב על כך בהמשך) שבעצם ״תקשיב״ כאשר יתרחש אירוע מסוג לחיצה על ה-<code>para</code>, כלומר, על האלמנט <code>p</code>, קוד בלוק שנקרא <code>updateName</code> ירוץ. בלוק קוד זה הניתן לשימוש חוזר נקרא ״פונקציה״ והוא מוגדר בשורות 5-8. </p>
-
-<p>שורות 5-8: הגדרה של הפונקציה<code>updateName.</code> פונקציה זו מבקשת מהמשתמש להכניס את שמו ומשנה את התוכן של <code>para</code> לשמו של המשתמש ביחד עם המחרוזת ״:Player 1״. </p>
-
-<p>אם נשנה את הסדר של שורות הקוד, לדוגמא, נחליף בין שורות 1 ו-3, אנו נקבל שגיאה ב<a href="/en-US/docs/Learn/Common_questions/What_are_browser_developer_tools">קונסולה של הדפדפן</a> מסוג:  <code>TypeError: para is undefined</code>. זה אומר שכאשר אנו מבצעים להוסיף את  <code>event listener</code>- האובייקט <code>para</code> עדין לא קיים ולכן לא נוכל להוסיף לו <code>event listener</code>.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: זוהי שגיאה מאוד נפוצה - חשוב לשים לב שהאובייקטים שאנו מנסים לגשת אליהם קיימים בטרם אנו מנסים לעשות איתם פעולות כלשהן. </p>
-</div>
-
-<h3 id="קוד_מהודר_מול_קוד_מפורש">קוד מהודר מול קוד מפורש</h3>
-
-<p>יכול להיות שנתקלתם במושגים כגון <strong>שפה מפורשת</strong> או <strong>שפה מקומפלת/מהודרת</strong> בהקשר של תכנות ופיתוח תוכנה.</p>
-
-<p>בשפות שהינן שפות ״<strong>מפורשות</strong>״, הקוד רץ מלמעלה למטה, והתוצאה של הרצת הקוד תוחזר במיידי, אנו לא צריכים לעשות טרנספורמציה כלשהי לקוד או שינוי שלו לתבנית אחרת לפני שהדפדפן יריץ אותו. </p>
-
-<p>לעומת זאת, שפות ״<strong>מקומפלות</strong>״ או שפות ״<strong>מהודרות״</strong> נדרשות לבצע שינוי כלשהו לתבנית אחרת לפני שהן יוכלו לרוץ על ידי המחשב. לדוגמא,  C/C++ מקומפלות לשפת assembly לפני הרצה על ידי המחשב. </p>
-
-<p>JavaScript היא שפה קלת-משקל ומעין מפורשת (בפועל, כן מבוצע קימפול, אך לא נרחיב על הנושא). לשני סוגי השפות יש יתרונות, אך לא נדון בהם כרגע. </p>
-
-<h3 id="קוד_צד-לקוח_מול_קוד_צד-שרת">קוד צד-לקוח מול קוד צד-שרת</h3>
-
-<p>ככל הנראה נתקלת במושגים קוד צד-לקוח (<strong>client-side</strong>) וקוד צד-שרת (<strong>server-side</strong>), במיוחד בהקשר של פיתוח Web. קוד צד-לקוח הוא קוד שרץ על גבי המחשב של המשתמש - כאשר צופים בדף אינטרנט, קוד צד-לקוח של דף האינטרנט יורד, מורץ ומוצג על ידי הדפדפן. במודול זה אנו נגע בעיקר ב- <strong>JavaScript של צד-לקוח.</strong></p>
-
-<p><strong>קוד צד-שרת</strong> מצד שני, ​​רץ על גבי השרת, והתוצאה שלו מורדת ומוצגת בדפדפן. דוגמאות לשפות פיתוח קוד צד-שרת כוללות בין היתר את PHP, Python, Ruby, ASP.NET וגם...JavaScript. כן, JavaScript יכולה לשמש גם כשפת פיתוח עבור צד-שרת. לדוגמא, בסביבת הפיתוח הפופולרית Node.js. ניתן להרחיב את הלמידה על JavaScript כשפת קוד-שרת בנושא הייעודי שלנו <a href="/en-US/docs/Learn/Server-side">Dynamic Websites – Server-side programming</a>. </p>
-
-<h3 id="קוד_דינאמי_מול_קוד_סטאטי">קוד דינאמי מול קוד סטאטי</h3>
-
-<p>המושג <strong>דינאמיות</strong> (<strong>dynamic</strong>) משמש הן לתיאור קוד צד-לקוח והן לתיאור קוד צד-שרת והוא מתייחס לאפשרות לעדכן את התצוגה של דף אינטרנט או יישום אינטרנט כך שיוצגו דברים אחרים בנסיבות אחרות ויווצר תוכן חדש ככל שנדרש. </p>
-
-<p>קוד צד-שרת יוצר באופן דינאמי תוכן חדש על גבי השרת, לדוגמא, מייצא מידע מתוך מאגר הנתונים, ואילו קוד צד-לקוח מייצר תוכן חדש בתוך הדפדפן של המשתמש, לדוגמא, יוצר טבלת HTML חדשה וממלא אותה בנתונים שביקשנו מהשרת, ואז מציג למשתמש את הטבלה על גבי דף האינטרנט.</p>
-
-<p>המשמעות של דינאמיות היא מעט שונה בין צד לקוח לצד שרת, אך הן קשורות אחת לשנייה, ובדרך כלל, הן עובדות יחד. </p>
-
-<p>דף אינטרנט שאין לו שום דינאמיות או עדכוני תוכן מכונה כדף <strong>סטאטי</strong> - הוא מציג למשתמש את אותו תוכן כל הזמן.  </p>
-
-<h2 id="כיצד_נוסיף_JavaScript_לדף_האינטרנט_שלנו">כיצד נוסיף JavaScript לדף האינטרנט שלנו?</h2>
-
-<p>JavaScript מוחלת על דף ה-HTML בדרך דומה לדרך שבה אנו מחילים את כללי ה-CSS.</p>
-
-<p>בעוד ש-CSS משתמש באלמנט {{htmlelement("link")}} על מנת להחיל גיליונות עיצוב חיצוניים ובאלמנט {{htmlelement("style")}} על מנת להחיל גיליונות עיצוב פנימיים, JavaScript צריכה אלמנט אחד - {{htmlelement("script")}}. נבין לעומק כיצד זה עובד: </p>
-
-<h3 id="Internal_JavaScript_(כאלמנט_בתוך_קובץ_ה-HTML)">Internal JavaScript (כאלמנט בתוך קובץ ה-HTML)</h3>
-
-<ol>
- <li>אנא צרו העתק על גבי המחשב שלך של קובץ הדוגמא שלנו:  <a href="https://github.com/mdn/learning-area/blob/master/javascript/introduction-to-js-1/what-is-js/apply-javascript.html">apply-javascript.html</a>.</li>
- <li>פתחו את הקובץ בדפדפן ובעורך הקוד. אתם תראו ש-HTML יצר דף אינטרנט פשוט המכיל כפתור שניתן ללחוץ עליו.</li>
- <li>בעורך הקוד - הוסיפו את הקוד הבא בתוך ה-head, לפני התגית <code>&lt;/head&gt;</code>:</li>
- <li>
- <pre class="brush: html">&lt;script&gt;
-
- // JavaScript goes here
-
-&lt;/script&gt;</pre>
- </li>
- <li>כעת, נוסיף קצת קוד JavaScript בתוך האלמנט {{htmlelement("script")}} על מנת שהדף יבצע משהו מעניין. לשם כך, הוסיפו את הקוד הבא מתחת לכיתוב:  " :JavaScript goes here line //״</li>
- <li>
- <pre class="brush: js">document.addEventListener("DOMContentLoaded", function() {
- function createParagraph() {
- let para = document.createElement('p');
- para.textContent = 'You clicked the button!';
- document.body.appendChild(para);
- }
-
- const buttons = document.querySelectorAll('button');
-
- for(let i = 0; i &lt; buttons.length ; i++) {
- buttons[i].addEventListener('click', createParagraph);
- }
-});</pre>
- </li>
- <li>שמרו את הקובץ ורעננו את הדפדפן - כעת אתם אמורים להבחין שכאשר אתם לוחצים על הכפתור, נוצרת כל פעם פסקה חדשה מתחת לפסקה הקודמת. </li>
-</ol>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אם הדוגמא לעיל לא עובדת לכם, בדקו האם שמרתם את הקובץ בשם הנכון, האם יש לו סיומת <code>html</code>? האם הוספתם את האלמנט  {{htmlelement("script")}}  ישר לפני תגית הסגירה <code>&lt;/head&gt;</code> ? להזכירכם, <strong>JavaScript היא case sensitive, וזה יכול להיות מאוד מסתכל. שימו לב לדקויות</strong><strong>.</strong></p>
-</div>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: תוכלו לראות את הגרסה הזו גם ב- GitHub בקישור  <a href="https://github.com/mdn/learning-area/blob/master/javascript/introduction-to-js-1/what-is-js/apply-javascript-internal.html">apply-javascript-internal.html</a>  או <a href="http://mdn.github.io/learning-area/javascript/introduction-to-js-1/what-is-js/apply-javascript-internal.html">כדף אינטרנט</a>.</p>
-</div>
-
-<h3 id="External_JavaScript_(קישור_קובץ_JavaScript_חיצוני)">External JavaScript (קישור קובץ JavaScript חיצוני)</h3>
-
-<p>הכנסת JavaScript בתוך קובץ ה-HTML עובד בסדר גמור, אך מה אם נרצה לשים את קוד ה-JavaScript בקובץ אחר? נראה כיצד עושים זאת. </p>
-
-<ol>
- <li>ראשית, צרו קובץ חדש באותה תיקיה שבו נמצא ה-HTML בשם <code>script.js</code> - וודאו שיש לו את סיומת הקובץ js על מנת שהוא יזוהה כ-JavaScript.</li>
- <li>החליפו את האלמנט {{htmlelement("script")}}  עם האלמנט  {{htmlelement("script")}} :
- <pre class="brush: html">&lt;script src="script.js" defer&gt;&lt;/script&gt;</pre>
- </li>
- <li>בתוך קובץ <code>script.js</code>, הוסיפו את הקוד הבא:
- <pre class="brush: js">function createParagraph() {
- let para = document.createElement('p');
- para.textContent = 'You clicked the button!';
- document.body.appendChild(para);
-}
-
-const buttons = document.querySelectorAll('button');
-
-for(let i = 0; i &lt; buttons.length ; i++) {
- buttons[i].addEventListener('click', createParagraph);
-}</pre>
- </li>
- <li>שמרו ורעננו את הדפדפן. זה עובד בדיוק אותו דבר כמו JavaScript פנימי, רק שכעת JavaScript נמצאת בקובץ חיצוני. באופן כללי, שמירת קוד JavaScript בקובץ חיצוני עדיפה בהיבט ארגון הקוד ושימוש חוזר שלו בכמה קבצי HTML. בנוסף, זה מאפשר לנו לקרוא את ה-HTML בצורה ברורה יותר.</li>
-</ol>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: ניתן לראות את הגרסה הזו של הקוד בקישור  <a href="https://github.com/mdn/learning-area/blob/master/javascript/introduction-to-js-1/what-is-js/apply-javascript-external.html">apply-javascript-external.html</a> וכ-<a href="http://mdn.github.io/learning-area/javascript/introduction-to-js-1/what-is-js/apply-javascript-external.html">דף אינטרנט</a>.</p>
-</div>
-
-<h3 id="Inline_JavaScript_handlers_(בתוך_אלמנט_ספציפי_בקובץ_ה-HTML)">Inline JavaScript handlers (בתוך אלמנט ספציפי בקובץ ה-HTML)</h3>
-
-<p>תשומת לב כי לפעמים אנחנו ניתקל בקוד JavaScript שכתוב בתוך אלמנט ספציפי בקובץ ה-HTML.  זה נראה כך: </p>
-
-<div id="inline_js_example">
-<pre class="brush: js example-bad">function createParagraph() {
- let para = document.createElement('p');
- para.textContent = 'You clicked the button!';
- document.body.appendChild(para);
-}</pre>
-
-<pre class="brush: html example-bad">&lt;button onclick="createParagraph()"&gt;Click me!&lt;/button&gt;</pre>
-</div>
-
-<p>ניתן את את הקוד הבא:</p>
-
-<p>{{ EmbedLiveSample('inline_js_example', '100%', 150, "", "", "hide-codepen-jsfiddle") }}</p>
-
-<p>לקוד זה יש את פונקציונליות זהה לקוד בשני החלקים הקודמים, כלומר, הוא מבצע בדיוק את אותו דבר, רק שאלמנט הכפתור - {{htmlelement("button")}}  מכיל בתוכו <code>onclick</code>  על מנת לאפשר לפונקציה לרוץ כשהכפתור נלחץ.</p>
-
-<p><strong>בבקשה לא לבצע שימוש בשיטה זו. </strong>זה נחשב ל-bad practice ״לזהם״ את קובץ HTML יחד עם JavaScript ולא יעיל, שכן בשיטה זו צריך להוסיף <code>()onclick=״createParagraph״ </code>לכל אחד מהכפתורים שיהיו בדף. </p>
-
-<p>לעומת זאת, שימוש ב-JavaScript בלבד, מאפשר לנו לבחור את כל הכפתורים באמצעות קוד פשוט וקצר. לדוגמא: </p>
-
-<pre class="brush: js">const buttons = document.querySelectorAll('button');
-
-for(let i = 0; i &lt; buttons.length ; i++) {
- buttons[i].addEventListener('click', createParagraph);
-}</pre>
-
-<p>ממבט ראשון זה אומנם נראה ארוך יותר מהאפשרות הראשונה, אך זה יעבוד לכל הכפתורים בדף, בכל כמות שהיא.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: נסו לשנות קצת את הגרסה של  <code>apply-javascript.html</code> והוסיפו עוד כפתורים לקובץ. כשתרעננו את הדף, תראו שכל כפתור שנלחץ, יוצר פסקה. </p>
-</div>
-
-<h3 id="שיטות_לטעינת_סקירפטים_(Script)">שיטות לטעינת סקירפטים (Script)</h3>
-
-<p>ישנן כמה סוגיות עם טעינה של סקריפטים באותו זמן. </p>
-
-<p>בעיה נפוצה היא שכל אלמנטי ה-HTML בדף מועלים בסדר שבה הם מוצגים/רשומים, מלמעלה למטה. אם אנחנו משתמשים ב-JavaScript על מנת לבצע מניפולציות באלמנטים על הדף (או יותר מדוייק, ב-DOM) הקוד שלנו לא יעבוד אם ה- JavaScript תיטען לפני שה-HTML שבו אנחנו מנסים לבצע מניפולציה ייטען בעצמו.</p>
-
-<p>בדוגמאות למעלה, ה-JavaScript הפנימי וקובץ ה-JavaScript החיצוני נטענו ורצו בראש המסמך, לפני שה-HTML הועבר. זה יכול ליצור שגיאה. על מנת למנוע זאת כאשר אנחנו מוסיפים JavaScript בתור אלמנט <code>script</code>, הוספנו את הקוד הבא: </p>
-
-<pre class="brush: js">document.addEventListener("DOMContentLoaded", function() {
- ...
-});</pre>
-
-<p>זהו ״<strong>מאזין לאירוע</strong>״  - <strong>event listener</strong>, אשר ״מקשיב״ לאירוע של הדפדפן בשם ״DOMContentLoaded״. אירוע זה מעיד על כך שגוף ה-HTML, כל תוכן שנמצא בתוך תגית <font face="consolas, Liberation Mono, courier, monospace"><span style="background-color: rgba(220, 220, 220, 0.498039);">&lt;body&gt;</span></font>  הועלה בשלמותו. כך, קוד JavaScript בתוך אותו בלוק לא ירוץ עד אשר האירוע יחל, ולכן השגיאה נמנעה. בהמשך הקורס, נרחיב על אירועים ומאזינים לאירועים. </p>
-
-<p>על מנת למנוע זאת כאשר אנחנו מוסיפים JavaScript באמצעות קובץ חיצוני, אנחנו משתמשים באפשרות יחסית חדשה של JavaScript, שהיא תכונה (attribute) בשם <code>defer</code>. שבעצם אומרת לדפדפן להמשיך לטעון את ה-HTML ברגע שהוא הגיע לתגית האלמנט <code>&lt;script&gt;</code>:</p>
-
-<pre class="brush: js">&lt;script src="script.js" defer&gt;&lt;/script&gt;</pre>
-
-<p>בשני המקרים, ה-HTML ייטען במקביל והקוד יעבוד. </p>
-
-<div class="note">
-<p><strong>תשומת לב</strong>: במקרה של JavaScript הנטען מקובץ חיצוני, אנחנו לא השתמשנו באירוע <code>DOMContentLoaded</code>  מכיוון שתכונת ה-<code>defer </code>פתרה את הבעיה. יחד עם זאת, ניתן להשתמש ב-<code>defer</code> ב-JavaScript חיצוני בלבד. </p>
-</div>
-
-<p>דרך מקובלת (ואינה נדרשת יותר) לפתור את הבעיה הזו, הייתה לשים את אלמנט ה-<code>script</code> שלנו ישר מתחת לתגית הסגירה של body. כלומר ישר מתחת לתגית <font face="consolas, Liberation Mono, courier, monospace"><span style="background-color: rgba(220, 220, 220, 0.498039);">&lt;body</span><span style="background-color: rgba(220, 220, 220, 0.498039);">/</span><span style="background-color: rgba(220, 220, 220, 0.498039);">&gt;</span></font>כך שראשית ייטען כל ה-<code>body</code>. הבעיה עם פתרון זה הוא שטעינה/העברה של הסקריפט חסום לחלוטין עד אשר ה-HTML DOM נטען באופן מלא. באתרים גדולים עם כמות גדולה של JavaScript, זה יכול ליצור בעית ביצועים אשר גורמת להאטת האתר.</p>
-
-<h4 id="async_and_defer">async and defer</h4>
-
-<p>בעיקרון יש  דרכים נוספות לעקוף את סוגיית חסימת הסקריפט - באמצעות — <code>async</code> and <code>defer</code>.</p>
-
-<p>סקריפטים בעלי תכונה של <code>async</code> יורדו מבלי לחסום את הדף ויורצו ברגע שהסקריפט יסיים לרדת. אין בטחון שהסקריפטים ירוצו בסדר מסויים, אלא שהם פשוט לא יעצרו מיתר הדף מלהיות מוצג. דרך טובה להשתמש ב-<code>async</code> היא כאשר הסקריפטים בדף רצים באופן עצמאי אחד מהשני ולא תלויים בסקריפטים אחרים בדף.</p>
-
-<p>לדוגמא:</p>
-
-<pre class="brush: html">&lt;script async src="js/vendor/jquery.js"&gt;&lt;/script&gt;
-
-&lt;script async src="js/script2.js"&gt;&lt;/script&gt;
-
-&lt;script async src="js/script3.js"&gt;&lt;/script&gt;</pre>
-
-<p>לא ניתן להסתמך על כך שהסקריפטים ירוצו בסדר שבה הם הועלו. הראשון עלול להיטען אחרי השני או השלישי, ובמקרה הזה, כל פונקציה לדוגמא אשר מוגדרת באותם סקריפטים ותלויה בקובץ הראשון, תציג שגיאה כי הקובץ הראשון לא מוגדר בזמן שהסקריפט השני או השלישי רץ.</p>
-
-<p><code>defer</code> לעומת זאת, גורמת לכך שהסקריפטים ירוצו בסדר שבה הם מוצגים על גבי הדף ותריץ אותם ברגע שהסקריפט והתוכן יורדו:</p>
-
-<pre class="brush: html">&lt;script defer src="js/vendor/jquery.js"&gt;&lt;/script&gt;
-
-&lt;script defer src="js/script2.js"&gt;&lt;/script&gt;
-
-&lt;script defer src="js/script3.js"&gt;&lt;/script&gt;</pre>
-
-<p>פה מה שיקרה הוא שכל הסקריפטים עם התכונה של <code>defer</code> ייטענו בסדר שבו הם מופיעים בדף. כך, אנחנו יכולים להיות בטוחים שהקובץ הראשון ייטען במלואו לפני שהקובץ השני יתחיל לרוץ וכך הלאה. </p>
-
-<p>לסיכום:</p>
-
-<ul>
- <li>אם הסקריפטים שלנו לא צריכים לחכות לקבצי סקריפטים אחרים והם יכולים לרוץ עצמאית, נשתמש ב-<code>async</code>.</li>
- <li>אם הסקריפטים צריכים לחכות לקבצי סקריפטים אחרים ותלויים בה, נשתמש ב-<code>defer</code> ונסדר את הסקריפטים בדף בסדר שבו אנו רוצים להריץ אותם. </li>
-</ul>
-
-<h2 id="הערות_ב-JavaScript">הערות ב-JavaScript</h2>
-
-<p>כמו בשפות HTML ו-CSS, גם ב-JavaScript  ניתן להוסיף הערות בקוד, אשר הדפדפן יתעלם מהן ונועדו על מנת לספק הוראות למפתחים אחרי כיצד הקוד עובד, וגם לכם, אפשרות לרענן את זכרונכם. <strong>הערות הן מאוד שימושיות</strong>, אנא בצעו בהם שימוש לעיתים קרובות, במיוחד עבור יישומים גדולים. </p>
-
-<p>יש שני סוגי הערות:</p>
-
-<ul>
- <li><strong>הערת בת שורה אחת</strong>, ונכתבת באמצעות הוספת התווים<code> // </code>:
-
- <pre class="brush: js">// I am a comment</pre>
- </li>
- <li><strong>הערת רבת שורות,</strong> הנכתבת בין התווים <code>*/</code>  לתווים  <code>/*</code> :
- <pre class="brush: js">/*
- I am also
- a comment
-*/</pre>
- </li>
-</ul>
-
-<p>לדוגמא: </p>
-
-<pre class="brush: js">// Function: creates a new paragraph and appends it to the bottom of the HTML body.
-
-function createParagraph() {
- let para = document.createElement('p');
- para.textContent = 'You clicked the button!';
- document.body.appendChild(para);
-}
-
-/*
- 1. Get references to all the buttons on the page in an array format.
- 2. Loop through all the buttons and add a click event listener to each one.
-
- When any button is pressed, the createParagraph() function will be run.
-*/
-
-const buttons = document.querySelectorAll('button');
-
-for (let i = 0; i &lt; buttons.length ; i++) {
- buttons[i].addEventListener('click', createParagraph);
-}</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: באופן כללי - יותר הערות בדרך כלל עדיף מקצת מדי הערות, אבל צריך לשים לב לא למצוא את עצמנו מוסיפים יותר מדי הערות שמסבירות מהן המשתנים שהגדרנו (במקרה כזה יהיה עדיף כבר להשתמש בשם הגיוני) או הערות שמסבירים פעולות פשוטות ומובנות בקלות. </p>
-</div>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>כעת עשינו את הצעד הראשון לתוך עולמה של JavaScript. התחלנו עם קצת תיאוריה על מנת להתחיל להתרגל להשתמש בה ולהבין מה הדברים שאנחנו יכולים לבצע איתה. בהמשך הדרך ראינו מספר דוגמאות קוד ולמדנו כיצד JavaScript משתלבת באתר האינטרנט שלנו, יחד עם רכיבים נוספים. </p>
-
-<p>JavaScript עלולה להיראות לנו קצת מלחיצה או לא ברורה בשלב זה, אבל אל דאגה, בקורס הזה אנחנו הולכים בצעדים קטנים אשר נבנים בצורה הגיונית. במאמר הבא אנחנו נעבור ליישום פרקטי ונתחיל בבניית דוגמאות JavaScript שלכם באופן עצמאי.</p>
-
-<ul>
-</ul>
-
-<p>{{NextMenu("Learn/JavaScript/First_steps/A_first_splash", "Learn/JavaScript/First_steps")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/What_is_JavaScript">מה זה JavaScript?</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/A_first_splash">מבט ראשון ל- JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/What_went_wrong">מה השתבש? פתרון בעיות ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Variables">אחסון המידע שאנחנו צריכים - משתנים — Variables</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Math">מתמתיקה בסיסית ב-  JavaScript — מספרים ואופרטורים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Strings">התמודדות עם טקסט — מחרוזות (Strings) ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Useful_string_methods">מתודות שימושיות למחרוזות</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Arrays">מערכים - Arrays</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Silly_story_generator">תרגיל: Silly story generator</a></li>
-</ul>
diff --git a/files/he/learn/javascript/first_steps/what_went_wrong/index.html b/files/he/learn/javascript/first_steps/what_went_wrong/index.html
deleted file mode 100644
index 87d85d786c..0000000000
--- a/files/he/learn/javascript/first_steps/what_went_wrong/index.html
+++ /dev/null
@@ -1,251 +0,0 @@
----
-title: מה השתבש? - פתרון שגיאות ב-JavaScript
-slug: Learn/JavaScript/First_steps/What_went_wrong
-translation_of: Learn/JavaScript/First_steps/What_went_wrong
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/First_steps/A_first_splash", "Learn/JavaScript/First_steps/Variables", "Learn/JavaScript/First_steps")}}</div>
-
-<p class="summary">כשבנינו את המשחק ״שחק את המספר״ במאמר הקודם, בטח שמתם לב שהוא לא עבד. מאמר זה לספק לכם הבנה כיצד למצוא שגיאות ב-JavaScript ולתקן אותן.</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>הבנה בסיסית של מחשב, הבנה בסיסית של  HTML, CSS ו - JavaScript.</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>
- <p>הכרת חלק מהאפשרויות ללתיקון שגיאות בקוד שלנו.</p>
- </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="סוגי_שגיאות">סוגי שגיאות</h2>
-
-<p>באופן כללי, כשאנחנו מבצעים משהו שגוי בקוד, יש שתי סוגי שגיאות עיקריות שאנחנו ניתקל בהן:</p>
-
-<ul>
- <li><strong>Syntax errors - שגיאות סינטקס</strong>: אלו בעיקרון שגיאות כתיב בקוד שכתבנו שגורמות לתוכנית לא לרוץ בכלל, או להפסיק לעבוד בשלב מסוים. בדרך כלל גם נקבל הודעת שגיאה מסויימת. שגיאות אלו בדר״כ קלות לתיקון, ככל ואנחנו מכירים את הכלים שעומדים לרשותנו ומה הודעת השגיאה אומרת.</li>
- <li><strong>Logic errors - טעויות לוגיות</strong>: אלו שגיאות שבהן הסינטקס היה נכון, כלומר כתבנו ללא שגיאות כתיב, אבל הקוד לא מבצע את מה שרצינו שיבצע. אלו שגיאות שקצת יותר מורכב לתקן אותן מאשר שגיאות סינטקס, שכן הן לרוב לא יקפיצו הודעת שגיאה.</li>
-</ul>
-
-<p>אוקיי, זה לא <em>כזה</em> פשוט — יש חלוקות נוספות של סוגי השגיאות, וככל ונעמיק בחומר ננחקור אותן לעומק. לצרוך הלימוד כרגע, החלוקה הזו תספיק בהתחלה. </p>
-
-<h2 id="דוגמא_לשגיאה">דוגמא לשגיאה</h2>
-
-<p>לשם התחלה, חזרו למשחק ״נחש את המספר״ שלנו - רק שהפעם, השתמשו בקובץ שלנו שהוכנסו בו מכלתחילה מספר שגיאות. כנסו ל-Github והכינו לעצמכם עותק מקומי של <a href="https://github.com/mdn/learning-area/blob/master/javascript/introduction-to-js-1/troubleshooting/number-game-errors.html">number-game-errors.html</a> (ראו זאת בדף אינטרנט<a href="http://mdn.github.io/learning-area/javascript/introduction-to-js-1/troubleshooting/number-game-errors.html"> כאן</a>).</p>
-
-<ol>
- <li>לשם התחלה, פתחו את הקובץ המקומי בעורך הקוד ובדפדפן.</li>
- <li>נסו לשחק עם המשחק, אתם תשימו לב כשאתם לוחצים על כפתור - "Submit guess", הכפתור לא עושה כלום.</li>
-</ol>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: יכול להיות שהגרסה שאתם עבדתם עליה לא עובדת בעצמה, ואולי אותה תרצו לתקן. בכל מקרה, אנא השתמשו בגרסה שלנו לאורך המאמר הנוכחי, על מנת שתוכלו ללמוד את הטכניקות שאנחנו נלמד כאן. לאחר מכן, חזרו לדוגמא שלכם ונסו לתקן אותה אם היא אינה עובדת.</p>
-</div>
-
-<p>בשלב זה, ניעזר בקונסולה בדפדפן על מנת לראות את שגיאות הסינטקס, וננסה לתקן אותם. </p>
-
-<h2 id="תיקון_שגיאות_סינטקס">תיקון שגיאות סינטקס</h2>
-
-<p>בתחילת הקורס, הזנו מס׳ פקודות של JavaScript לתוך ה<a href="/en-US/docs/Learn/Common_questions/What_are_browser_developer_tools">קונסולה</a>. יתרון נוסף של שימוש בקונסולה הוא העובדה שהקונסולה מחזירה לכם הודעות בדבר שגיאות כתיב כאשר אלו קיימות בקוד ה-JavaScript אשר נטען על ידי מנוע ה- JavaScript של הדפדפן. בוא נבדוק זאת:</p>
-
-<ol>
- <li>לך ללשונית שבה יש את הקובץ <code>number-game-errors.html</code> פתוח ופתחו את הקונסולה. אתם אמורים לראות שגיאה שמכילה את המלל הבאה:<img alt="" src="https://mdn.mozillademos.org/files/13496/not-a-function.png" style="display: block; margin: 0 auto;"></li>
- <li>זו שגיאה דיי קלה לאיתור, והדפדפן מספק לם מס׳ נתונים על מנת לעזור לכם - צילום המסך לעיל לקוח מדפדפן Firefox אבל גם דפדפנים אחרים מספקים את אותו מידע. משמאל לימין, זו השגיאה:
- <ul>
- <li>״x״ אדום אשר יעיד על כל שקיימת שגיאה.</li>
- <li>הודעת שגיאה על מנת להראות שמשהו השתבש: "TypeError: guessSubmit.addeventListener is not a function".</li>
- <li>טקסט וקישור "Learn More" אשר יוביל לדף MDN שמסביר מהי השגיאה - שימו לב שקישור זה קיים רק בפיירפוקס ולא בכרום.</li>
- <li>השם של קובץ JavaScript אשר מקושר ללשונית ה-Debugger. אם נעקוב אחרי הקישור נראה את השורה המדויקת שבה התרחשה השגיאה.</li>
- <li>מספר השורה שבה התרחשה השגיאה, ומספרו של התו באותה השורה שבו השגיאה נראתה לראשונה. במקרה שלנו, השגיאה התרחשה בשורה 86, ובתו מספר 3.</li>
- </ul>
- </li>
- <li>אם נסתכל על שורה 86 בעורך הקוד שלנו, אנחנו נמצא את השורה הבאה:
- <pre class="brush: js">guessSubmit.addeventListener('click', checkGuess);</pre>
- </li>
- <li>הודעת שגיאה זו אומרת ש-"guessSubmit.addeventListener is not a function", אז אנחנו כנראה אייתנו משהו בצורה לא נכונה. אם אנחנו לא בטוחים לגבי האיות הנכון של כתיב/סינטקס מסויים, הפתרון הכי טוב זה להסתכל על המאפיינים של הסינטקס באתר של MDN. הדרך הכי טובה לעשות זאת היא לחפש "mdn <em>name-of-feature</em>" במנוע החיפוש האהוב עליכם. הנה קישור לדוגמא לחסוך לכם זמן <code><a href="/en-US/docs/Web/API/EventTarget/addEventListener">()addEventListener</a></code>.</li>
- <li>אז, אם אנחנו מסתכלים על הדף, השגיאה הופיעה ככל הנראה מכיוון שאייתנו את שם המתודה לא נכון. זכרו ש- JavaScript היא case sensitive, וכל שינוי קטן באיות, או שימוש באותיות גדולות/קטנות לא בצורה נכונה, יגרום לשגיאה. שינוי של <code>add<strong>e</strong>ventListener</code> לכתיב הנכון: <code>add<strong>E</strong>ventListener</code> אמור לתקן את הבעיה.</li>
-</ol>
-
-<div class="note">
-<p><strong>לתשומת לבכם</strong> ראו גם: <a href="/en-US/docs/Web/JavaScript/Reference/Errors/Not_a_function">TypeError: "x" is not a function</a>. זהו דף שלנו שמסביר בפרטים על השגיאה הזו.</p>
-</div>
-
-<h3 id="שגיאות_סינטקס_-_דוגמאות_נוספות">שגיאות סינטקס - דוגמאות נוספות</h3>
-
-<ol>
- <li>שמרו את הדף ורעננו אותו, אתם אמורים לראות שהשגיאה נעלמה.</li>
- <li>כעת, אם המשתמש ינסה להכניס ניחוש וללחוץ על הכפתור של Submit, תתקבל שגיאה נוספת:<img alt="" src="https://mdn.mozillademos.org/files/13498/variable-is-null.png" style="display: block; margin: 0 auto;"></li>
- <li>הפעם, השגיאה מדווחת עם ההודעה הבאה: "TypeError: lowOrHi is null", בשורה 78.
- <div class="note"><strong>לתשומת לבכם</strong>: <code><a href="/en-US/docs/Glossary/Null">Null</a></code> הוא ערך מיוחד שמשמעותו הוא ״כלום״ או ״ללא ערך״. כך <code>lowOrHi</code> אמנם הוצהר ואותחל, אבל הוא ללא כל ערך, אין לו סוג ואין ערך שהוזן לתוכו.</div>
-
- <div class="note"><strong>לתשומת לבכם</strong>: שגיאה זו לא הופיעה ברגע שהדף נטען שכן שגיאה זו נמצאת בתוך פונקציה - בתוך <code>() { ... }checkGuess</code>. אנו נלמד על פונקציות במאמרים הבאים, ואנו נלמד שקוד אשר נמצא בתוך פונקציה רץ בסקופ (מתחם) אחר ונפרד מהסקופ שרץ בו קוד מחוץ לפונקציה. במקרה הנוכחי - הקוד שבתוך הפונקציה אשר גרם לשגיאה לא רץ עד אשר הפונקציה <code>()checkGuess</code> לא הופעלה בשורה 26.</div>
- </li>
- <li>:הסתכלו על הקוד בשורה 78
- <pre class="brush: js">lowOrHi.textContent = 'Last guess was too high!';</pre>
- </li>
- <li>שורה זו מנסה לקבוע את ה-property - מאפיין:  <code>textContent</code> של המשתנה <code>lowOrHi</code> למחרוזת טקסט, אך זה לא יעבוד מכיוון ש-<code>lowOrHi</code> לא מכיל את הערך שהוא אמור להכיל. בו ננסה לחפש מופעים נוספים של <code>lowOrHi</code> בקוד שלנו. הפעם הראשונה שנמצא אותו תהיה בשורה 48:
- <pre class="brush: js">var lowOrHi = document.querySelector('lowOrHi');</pre>
- </li>
- <li>בשלב זה אנחנו מנסים להפוך את המשתנה שלנו להפנייה לאלמנט בדף ה-html, בוא ננסה לראות האם הוא מקבל את הערך <code>null</code> אחרי ההרצה של השורה הזו. הוסיפו את הקוד הבא לאחר שורה 49:
- <pre class="brush: js">console.log(lowOrHi);</pre>
-
- <div class="note">
- <p><strong>לתשומת לבכם</strong>: <code><a href="/en-US/docs/Web/API/Console/log">()console.log</a></code> מקבלת ארגומנט כלשהו ומדפיסה אותו לקונסולה. זוהי פונקציה מאוד שימושית לשם איתור שגיאות.</p>
- </div>
- </li>
- <li>שמור ורענן, ואתה אמור לראות ש-<code>()console.log</code> החזירו את התשובה הבאה בקונסולה:<img alt="" src="https://mdn.mozillademos.org/files/13494/console-log-output.png" style="display: block; margin: 0 auto;"> אנו רואים שהערך של <code>lowOrHi</code>הוא בעצם <code>null</code> בנקודה זו ולכן הבעיה היא עם שורה 48.</li>
- <li>ננסה לחשוב מהי הבעיה. שורה 28 משתמשת במתודה <code><a href="/en-US/docs/Web/API/Document/querySelector">()document.querySelector</a></code> על מנת לקבל הפניה לאלמנט באמצעות בחירת סלקטור ה-CSS שלו. אם נסתכל בדף, אנחנו יכולים למצוא את האלמנט הרלוונטי:
- <pre class="brush: js">&lt;p class="lowOrHi"&gt;&lt;/p&gt;</pre>
- </li>
- <li>כאן אנחנו רואים שאנחנו צריכים סלקטור של קלאס, אשר מתחיל עם (<code>.</code>), אבל הסלקטור שמועבר במתודה <code>()querySelector</code> בשורה 48 אינו מכיל נקודה. זו יכולה להיות הבעיה, נסו לשנות את <code>lowOrHi</code> ל- <code>.lowOrHi</code> וראו מה קורה.</li>
- <li>שמרו ורעננו את הדף ו-<code>()console.log</code> אמור להחזיר את האלמנט <code>&lt;p&gt;</code> שרצינו. </li>
-</ol>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: ראו גם <a href="/en-US/docs/Web/JavaScript/Reference/Errors/Unexpected_type">TypeError: "x" is (not) "y"</a> -  דף ההסבר שלנו לפרטים נוספים על שגיאה זו.</p>
-</div>
-
-<h3 id="שגיאות_סינטקס_נוספות">שגיאות סינטקס נוספות</h3>
-
-<ol>
- <li>אם תנסו לשחק עכשיו במשחק, אתם אמורים להצליח להתקדם יותר - אך עד שהמשחק יסתיים, בין אם ניחשתם את המספר האקראי הנכון ובין אם נגמרו לך הנסיונות.</li>
- <li>כשהמשחק נגמר, אנחנו מקבלים שגיאה מסוג - "TypeError: resetButton.addeventListener is not a function"! אשר מופיעה בשורה 94.</li>
- <li>אם נסתכל על שורה 94, נראה כי עשינו טעות באיות המתודה <code>addEventListener</code> ולכן נדרש לשנות את הקוד. להזכירכם, מתודות הן case senitive.</li>
-</ol>
-
-<h2 id="טעות_לוגית">טעות לוגית</h2>
-
-<p>בשלב זה, המשחק אמור לעבוד טוב, אך עם זאת, אחרי כמה משחקים, אתם תשימו לב שהמספר האקראי שלנו הוא תמיד 0 או 1. זה לא ממש מה שהתכוונו.</p>
-
-<p>יש בוודאות שגיאה לוגית במשחק איפשהו, אך אנחנו לא מקבלים הודעת שגיאה, המשחק עובד, אך לא כמו רצינו.</p>
-
-<ol>
- <li>נסו לחפש את המשתנה <code>randomNumber</code> ואת השורות בקוד שבהן אנחנו מגדירים אותו. הוא נמצא בשורה 44:
-
- <pre class="brush: js">var randomNumber = Math.floor(Math.random()) + 1;</pre>
- והשורה שבה אנחנו מייצרים מספר אקראי חדש לאחר כל משחק היא בשורה 113:</li>
- <li>
- <pre class="brush: js">randomNumber = Math.floor(Math.random()) + 1;</pre>
- </li>
- <li>על מנת לבדוק האם השורות האלו הן הבעיתיות, אנחנו ניעזר ב- <code>()console.log</code> ונכניס את הקוד הבא מתחת לשתי שורות לעיל:
- <pre class="brush: js">console.log(randomNumber);</pre>
- </li>
- <li>שמרו ורעננו את הדף ותנסו לשחק מספר משחקים. אתם תראו ש- <code>randomNumber</code> שווה ל-1 בכל פעם שאנחנו מדפיסים אותו לקונסולה:</li>
-</ol>
-
-<h3 id="מעבר_על_הלוגיקה_של_המשחק">מעבר על הלוגיקה של המשחק</h3>
-
-<p>על מנת לתקן זאת, בואו נחשוב כיצד שורה זו עובדת. קודם כל, אנחנו קוראים ל-<code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/random">()Math.random</a></code>, אשר מייצרת מספר עשרוני בין 0 ל-1, לדוגמא: 0.5676665434:</p>
-
-<pre class="brush: js">Math.random()</pre>
-
-<p>לאחר מכן אנחנו מעבירים את התוצאה של הפעלת פונקציית <code>()Math.random</code> דרך הפונקציה <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math/floor">()Math.floor</a></code>, אשר בתורה, מעגלת את המספר ולאחר מכן מוסיפים <code>1</code>. אם לא נוסיף <code>1</code>, פונקציה זו יכולה לעגל כלפי מטה ואז נקבל <code>0</code>.</p>
-
-<pre>Math.floor(Math.random()) + 1</pre>
-
-<p>1.  אנחנו צריכים להכפיל את המספר האקראי שלנו ב-<code>100</code> לפני שנעביר אותו הלאה. זה ייתן לנו מספר אקראי בין 0 ל-99:</p>
-
-<pre class="brush: js">Math.floor(Math.random()*100);</pre>
-
-<p>הוספת של <code>1</code>, תאפשר לנו לקבל ערך בין 1 ל-100:</p>
-
-<pre class="brush: js">Math.floor(Math.random()*100) + 1;</pre>
-
-<p>נסו לשמור ולרענן את הדף ואתם תראו שהמשחק עושה מה שהוא צריך לבצע - מייצר מספר אקראי בין 0 ל-100.</p>
-
-<h2 id="שגיאות_נפוצות_נוספות">שגיאות נפוצות נוספות</h2>
-
-<p>ישנן שגיאות נפוצות נוספות שאנחנו ניתקל בהן: </p>
-
-<h3 id="SyntaxError_missing_before_statement">SyntaxError: missing ; before statement</h3>
-
-<p>שגיאה זו לרוב אומרת ששכחנו לשים <code>;</code> בסוף שורות הקוד, אבל היא יכולה להיות גם מסיבה אחרת. אם נשנה את השורה שנמצאת בתוך הפונקציה <code>()checkGuess</code> :</p>
-
-<pre class="brush: js">var userGuess = Number(guessField.value);</pre>
-
-<p>לקוד הבא:</p>
-
-<pre class="brush: js">var userGuess === Number(guessField.value);</pre>
-
-<p>זה יקפיץ לנו הודעת שגיאה מכיוון ש- JavaScript חושבת שאתה מנסה לבצע משהו אחר. צריך תמיד לוודא שאנחנו לא מערבבים בין סימן השווה שנועד להשים ערך (<code>=</code>) לבין שלושת סימני השווה שנועדו לבדוק האם ערך אחד שווה לשני, ולהחזיר <code>true</code>/<code>false:</code></p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: ראה גם <a href="/en-US/docs/Web/JavaScript/Reference/Errors/Missing_semicolon_before_statement">SyntaxError: missing ; before statement</a> דף ההסבר שלנו לפרטים נוספים על שגיאה זו.</p>
-</div>
-
-<h3 id="המשחק_תמיד_נותן_למשתמש_לנצח_לא_משנה_מה_הניחוש_שהמשתמש_הכניס">המשחק תמיד נותן למשתמש לנצח, לא משנה מה הניחוש שהמשתמש הכניס</h3>
-
-<p>זה יכול להיות עוד סימן לכך שעירבבנו בין סימן ההשמה לבין סימן הבדיקה. לדוגמא, אם אנחנו את השורה הבאה שנמצא בתוך<code>()checkGuess</code>:</p>
-
-<pre class="brush: js">if (userGuess === randomNumber) {</pre>
-
-<p>לקוד הבא:</p>
-
-<pre class="brush: js">if (userGuess = randomNumber) {</pre>
-
-<p>תוצאת המבחן תהיה תמיד <code>true</code>, מה שגורם לכך שתמיד הניחוש של המשתמש נכון.</p>
-
-<h3 id="SyntaxError_missing_)_after_argument_list">SyntaxError: missing ) after argument list</h3>
-
-<p>זוהי שגיאה פשוטה יחסית - היא אומרת באופן כללי ששכחנו לשים סוגריים בסוף קריאה לפונקציה או מתודה:</p>
-
-<div class="note">
-<p><strong>לתשומת לבד</strong>: ראה גם <a href="/en-US/docs/Web/JavaScript/Reference/Errors/Missing_parenthesis_after_argument_list">SyntaxError: missing ) after argument list</a>  - דף ההסבר שלנו לפרטים נוספים על שגיאה זו.</p>
-</div>
-
-<h3 id="SyntaxError_missing_after_property_id">SyntaxError: missing : after property id</h3>
-
-<p>שגיאה זו בדרך כלל מתייחסת לכך שלא יצרנו אובייקט ל JavaScript בצורה נכונה. נסה לשנות את הקוד הבא:</p>
-
-<pre class="brush: js">function checkGuess() {</pre>
-
-<p>לקוד הבא:</p>
-
-<pre class="brush: js">function checkGuess( {</pre>
-
-<p>זה גרם לדפדפן לחשוב שאנחנו מנסים להעביר את התוכן של הפונקציה כארגומנט של הפונקציה.</p>
-
-<h3 id="SyntaxError_missing_after_function_body">SyntaxError: missing } after function body</h3>
-
-<p>זו גם שגיאה פשוטה יחסית - היא אומרת בעיקרון ששכחנו אחת מהסוגריים המסולסלות במשפט תנאי שרשמנו. </p>
-
-<h3 id="SyntaxError_expected_expression_got_'string'_or_SyntaxError_unterminated_string_literal">SyntaxError: expected expression, got '<em>string</em>' or SyntaxError: unterminated string literal</h3>
-
-<p>שגיאות אלו אומרות באופן כללי ששכחנו להוסיף סימן של <code>'</code> או <code>"</code>. בשגיאה הראשונה <em>string</em> יוחלף עם תו לא ידוע שהדפדפן ימצא במקום המרכאות או הגרש. השגיאה השניה אומרת שהמחרוזת לא הסתיימה עם גרש או מרכאות.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: ראה גם <a href="/en-US/docs/Web/JavaScript/Reference/Errors/Unexpected_token">SyntaxError: Unexpected token</a> וגם <a href="/en-US/docs/Web/JavaScript/Reference/Errors/Unterminated_string_literal">SyntaxError: unterminated string literal</a>  - דפי ההסבר שלנו לפרטים נוספים על שגיאות אלו.</p>
-</div>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>כעת אנו יודעים את הבסיס להבין שגיאות בתוכניות JavaScript הפשוטות שלנו. רק צריך לזכור שזה לא יהיה תמיד קל להבין מה השתבש לנו בקוד. כאשר שגיאה מתרחשת, הסתכלו על מספר השורה שאתם מקבלים, ולכו לאותה שורה על מנת לנסות לאתר מה השתבש. זכרו תמיד שהשגיאה לא תמיד תהיה בשורה זו, ושאולי היא לא תהיה אחת מאלו שעברנו עליהם במאמר זה.</p>
-
-<h2 id="ראה_גם">ראה גם</h2>
-
-<div>
-<ul>
- <li>יש עוד הרבה סוגי שגיאות שלא פירטנו עליהן כאן. להרחבה, ראו <a href="/en-US/docs/Web/JavaScript/Reference/Errors">JavaScript error reference</a>.</li>
- <li>{{PreviousMenuNext("Learn/JavaScript/First_steps/A_first_splash", "Learn/JavaScript/First_steps/Variables", "Learn/JavaScript/First_steps")}}</li>
-</ul>
-</div>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/What_is_JavaScript">מה זה JavaScript?</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/A_first_splash">מבט ראשון ל- JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/What_went_wrong">מה השתבש? פתרון בעיות ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Variables">אחסון המידע שאנחנו צריכים - משתנים — Variables</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Math">מתמתיקה בסיסית ב-  JavaScript — מספרים ואופרטורים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Strings">התמודדות עם טקסט — מחרוזות (Strings) ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Useful_string_methods">מתודות שימושיות למחרוזות</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Arrays">מערכים - Arrays</a></li>
- <li><a href="/he/docs/Learn/JavaScript/First_steps/Silly_story_generator">תרגיל: Silly story generator</a></li>
-</ul>
diff --git a/files/he/learn/javascript/index.html b/files/he/learn/javascript/index.html
deleted file mode 100644
index e606644330..0000000000
--- a/files/he/learn/javascript/index.html
+++ /dev/null
@@ -1,83 +0,0 @@
----
-title: JavaScript
-slug: Learn/JavaScript
-tags:
- - JavaScript
- - "JavaScript\_למתחילים"
- - מדריך
- - מדריך JavaScript
- - מדריך javascript למתחילים
- - מודול
- - מתחיל
- - נושא
- - קידוד
-translation_of: Learn/JavaScript
----
-<div>{{LearnSidebar}}</div>
-
-<p class="summary">{{Glossary("JavaScript")}} הינה שפת תכנות אשר מאפשרת ליישם דברים מורכבים על גבי דפי האינטרנט. ברגע שדף האינטרנט עושה יותר מסתם להציג אינפורמציה סטטית — להציג עידכוני תוכן משתנים, מפות אינטרקטיביות או גרפים 2D/3D מונפשים, וכן הלאה — כנראה שJavaScript מעורב מאחורי הקלעים.</p>
-
-<h2 id="מסלול_למידה">מסלול למידה</h2>
-
-<p>ניתן לטעון שJavaScript הינה מסובכת יותר ללימוד מאשר טכנולוגיות קשורות כמו <a href="/he/docs/Learn/HTML">HTML</a> ו<a href="/he/docs/Learn/CSS">CSS</a>. לפני הניסיון ללמוד JavaScript, מומלץ מאוד לעשות היכרות לפחות עם שתי הטכנולוגיות המוזכרות, ואולי גם עם עוד טכנולוגיות. ניתן להתחיל בלעבוד על המודולים הבאים:</p>
-
-<ul>
- <li><a href="/he/docs/Learn/Getting_started_with_the_web">תחילת הדרך עם  ה-Web</a></li>
- <li><a href="/he/docs/Web/Guide/HTML/Introduction">הקדמה ל-HTML</a></li>
- <li><a href="/he/docs/Learn/CSS/Introduction_to_CSS">הקדמה ל-CSS</a></li>
-</ul>
-
-<p>ניסיון קודם עם שפות תכנות אחרות יכול לעזור גם כן.</p>
-
-<p>אחרי היכרות עם הבסיס של  JavaScript, הרמה שלכם אמורה להיות מספיק גבוהה בשביל לעבור ללמוד על נושאים מתקדמים, לדוגמא:</p>
-
-<ul>
- <li>JavaScript לעומק, כפי שנלמד ב<a href="/he/docs/Web/JavaScript/Guide">מדריך הJavaScript</a> שלנו.</li>
- <li><a href="/he/docs/Web/API">Web APIs</a>.</li>
- <li>ועוד.</li>
-</ul>
-
-<h2 id="מודולים">מודולים</h2>
-
-<p>נושא זה מכיל את המודולים הבאים, כאשר כל מודול מורכב ממספר מאמרים, מומלץ לעבור עליהם לפי הסדר המוצג.</p>
-
-<dl>
- <dt><a href="/he/docs/Learn/JavaScript/First_steps">צעדים ראשונים ב-JavaScript</a></dt>
- <dd>במודול JavaScript הראשון שלנו, אנחנו קודם כל נענה על כמה שאלות בסיסיות כמו "מהי JavaScript?", "איך היא ניראת?" ו-"מה היא יכולה לעשות?", לפני שנתקדם לניסיון הפרקטי הראשון בכתיבת JavaScript. לאחר מכן נדון בכמה תכונות מפתח של JavaScript בפירוט, כגון משתנים, מחרוזות, מספרים ומערכים.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/Building_blocks">אבני הבניין של JavaScript</a></dt>
- <dd>במודול זה, נגע באבני הבניין והמאפיינים הבסיסיים של JavaScript, נפנה את תשומת ליבנו לטיפוסים הנפוצים של בלוקי הקוד כמו משפטי תנאי, לולאות, פונקציות, ואירועים (Events). כבר ניתקלנו בדברים אלו בקורס, אך לא הרחבנו עליהם — במודול זה אנו נדון בכולם לעומק.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/Objects">הכרות עם אובייקטים של JavaScript</a></dt>
- <dd>ב-JavaScript, רוב הדברים הינם אובייקטים, מפיצ'רי הליבה של JavaScript כמו מחרוזות ומערכים עד לAPIים של הדפדפן הבנויים על גבי JavaScript. אתם יכולים אפילו לבנות אובייקטים בעצמכם כדי לעטוף פונקציות ומשתנים קשורים לחבילות אפקטיביות. חשוב להבין את העקרון של תכנות מונחה-העצמים של JavaScript אם אנחנו רוצים להתקדם עם הידע שלנו בשפה ולכתוב קוד יותר אפקטיבי, לכן סיפקנו את המודול הזה לעזור לכם. כאן נלמד את התאוריה והתחביר של אובייקט בפירוט, נראה איך יוצרים אובייקטים משלכם, ונסביר מה זה מידע בפורט JSON ואיך עובדים איתו ועם אובייקטים בכללי.</dd>
-</dl>
-
-
-
-<dl>
- <dt><a href="https://developer.mozilla.org/en-US/docs/Learn/JavaScript/Asynchronous">Asynchronous JavaScript</a></dt>
- <dd>
- <p>במודול זה אנחנו נסתכל על asynchronous JavaScript ונסביר את החשיבות של עקרון זה. כיצד אנחנו יכולים לבצע בכך שימוש על מנת לטפל באירועים מסויימים כמו קבלת מידע ומקורות משרת.</p>
- </dd>
-</dl>
-
-
-
-<dl>
- <dt><a href="/he/docs/Learn/JavaScript/Client-side_web_APIs"> Web API - צד לקוח</a></dt>
- <dd>כאשר כותבים JavaScript עבור צד-לקוח לדפי אינטרנט או יישומי אינטרנט, כמעט מיד תתקלו בצורך להשתמש ב - API - אלו ממשקים עבור ביצוע מניפולציות של היבטים שונים של הדפדפן ומערכות ההפעלה שהאתר רץ עליהם, או אפילו מניפולציה לנתונים מאתרים או שירותים אחרים. במודול הזה אנו נחקור מהם API ואיך להשתמש בכמה מה-API הנפוצים שתפגשו בהם לעיתים קרובות במהלך עבודת הפיתוח. </dd>
-</dl>
-
-<h2 id="פתרון_בעיות_נפוצות_ב_-_JavaScript">פתרון בעיות נפוצות ב - JavaScript</h2>
-
-<p>המאמר בנושא <a href="/he/docs/Learn/JavaScript/Howto">שימוש ב-JavaScript לפתרון בעיות נפוצות</a> מספק קישורים לקטעי תוכן המסבירים איך להשתמש ב-JavaScript על מנת לפתור בעיות מאוד נפוצות בתהליך הפיתוח.</p>
-
-<h2 id="ראה_בנוסף">ראה בנוסף</h2>
-
-<ul>
-</ul>
-
-<dl>
- <dt><a href="/he/docs/Web/JavaScript">JavaScript on MDN</a></dt>
- <dd>נקודת הפתיחה הראשית לליבת התיעוד של JavaScript ב-MDN — כאן תמצאו תיעוד נרחב על כל ההיבטים של שפת JavaScript, וכמה הדרכות מתקדמות המכוונות למפתחי JavaScript מנוסים.</dd>
- <dt><a href="https://www.youtube.com/user/codingmath">Coding math</a></dt>
- <dd>סדרות של הדרכות וידאו מצויינות ללימוד המתמטיקה הנצרכת להפיכתכם למתכנתים אפקטיביים, מועבר על ידי <a href="https://twitter.com/bit101">Keith Peters</a>.</dd>
-</dl>
diff --git a/files/he/learn/javascript/objects/adding_bouncing_balls_features/index.html b/files/he/learn/javascript/objects/adding_bouncing_balls_features/index.html
deleted file mode 100644
index 23197f00c4..0000000000
--- a/files/he/learn/javascript/objects/adding_bouncing_balls_features/index.html
+++ /dev/null
@@ -1,214 +0,0 @@
----
-title: Adding features to our bouncing balls demo
-slug: Learn/JavaScript/Objects/Adding_bouncing_balls_features
-translation_of: Learn/JavaScript/Objects/Adding_bouncing_balls_features
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/Objects/Object_building_practice", "", "Learn/JavaScript/Objects")}}</div>
-
-<p class="summary">במשימה זאת, אתה צריך להשתמש בכדורים הקופצים מהמאמר הקודם כנקודת התחלה ולהוסיף אליה כמה פיצ'רים חדשים ומעניינים.</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">Prerequisites:</th>
- <td>Before attempting this assessment you should have already worked through all the articles in this module.</td>
- </tr>
- <tr>
- <th scope="row">Objective:</th>
- <td>To test comprehension of JavaScript objects and object-oriented constructs</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Starting_point">Starting point</h2>
-
-<p>To get this assessment started, make a local copy of <a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/bouncing-balls/index-finished.html">index-finished.html</a>, <a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/bouncing-balls/style.css">style.css</a>, and <a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/bouncing-balls/main-finished.js">main-finished.js</a> from our last article in a new directory in your local computer.</p>
-
-<p>Alternatively, you could use a site like <a class="external external-icon" href="http://jsbin.com/">JSBin</a> or <a class="external external-icon" href="https://glitch.com/">Glitch</a> to do your assessment. You could paste the HTML, CSS and JavaScript into one of these online editors. If the online editor you are using doesn't have separate JavaScript/CSS panels, feel free to put them inline <code>&lt;script&gt;</code>/<code>&lt;style&gt;</code> elements inside the HTML page.</p>
-
-<div class="note">
-<p><strong>Note</strong>: If you get stuck, then ask us for help — see the {{anch("Assessment or further help")}} section at the bottom of this page.</p>
-</div>
-
-<h2 id="Hints_and_tips">Hints and tips</h2>
-
-<p>A couple of pointers before you get started.</p>
-
-<ul>
- <li>This assessment is quite challenging. Read the whole assessment before you start coding, and take each step slowly and carefully.</li>
- <li>It might be a good idea to save a separate copy of the demo after you get each stage working, so you can refer back to it if you find yourself in trouble later on.</li>
-</ul>
-
-<h2 id="Project_brief">Project brief</h2>
-
-<p>Our bouncy ball demo is fun, but now we want to make it a little bit more interactive by adding a user-controlled evil circle, which will eat the balls if it catches them. We also want to test your object-building skills by creating a generic <code>Shape()</code> object that our balls and evil circle can inherit from. Finally, we want to add a score counter to track the number of balls left to capture.</p>
-
-<p>The following screenshot gives you an idea of what the finished program should look like:</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/13875/bouncing-evil-circle.png" style="display: block; margin: 0 auto;"></p>
-
-<ul>
-</ul>
-
-<p>To give you more of an idea, have a look at the <a href="http://mdn.github.io/learning-area/javascript/oojs/assessment/">finished example</a> (no peeking at the source code!)</p>
-
-<h2 id="Steps_to_complete">Steps to complete</h2>
-
-<p>The following sections describe what you need to do.</p>
-
-<h3 id="Creating_our_new_objects">Creating our new objects</h3>
-
-<p>First of all, change your existing <code>Ball()</code> constructor so that it becomes a <code>Shape()</code> constructor and add a new <code>Ball()</code> constructor:</p>
-
-<ol>
- <li>The <code>Shape()</code> constructor should define the <code>x</code>, <code>y</code>, <code>velX</code>, and <code>velY</code> properties in the same way as the <code>Ball()</code> constructor did originally, but not the <code>color</code> and <code>size</code> properties.</li>
- <li>It should also define a new property called <code>exists</code>, which is used to track whether the balls exist in the program (have not been eaten by the evil circle). This should be a boolean (<code>true</code>/<code>false</code>).</li>
- <li>The <code>Ball()</code> constructor should inherit the <code>x</code>, <code>y</code>, <code>velX</code>, <code>velY</code>, and <code>exists</code> properties from the <code>Shape()</code> constructor.</li>
- <li>It should also define a <code>color</code> and a <code>size</code> property, like the original <code>Ball()</code> constructor did.</li>
- <li>Remember to set the <code>Ball()</code> constructor's <code>prototype</code> and <code>constructor</code> appropriately.</li>
-</ol>
-
-<p>The ball <code>draw()</code>, <code>update()</code>, and <code>collisionDetect()</code> method definitions should be able to stay exactly the same as they were before.</p>
-
-<p>You also need to add a new parameter to the <code>new Ball() ( ... )</code> constructor call — the <code>exists</code> parameter should be the 5th parameter, and should be given a value of <code>true</code>.</p>
-
-<p>At this point, try reloading the code — it should work just the same as it did before, with our redesigned objects.</p>
-
-<h3 id="Defining_EvilCircle">Defining EvilCircle()</h3>
-
-<p>Now it's time to meet the bad guy — the <code>EvilCircle()</code>! Our game is only going to involve one evil circle, but we are still going to define it using a constructor that inherits from <code>Shape()</code> to give you some practice. You might want to add another circle to the app later on that can be controlled by another player, or have several computer-controlled evil circles. You're probably not going to take over the world with a single evil circle, but it will do for this assessment.</p>
-
-<p>The <code>EvilCircle()</code> constructor should inherit <code>x</code>, <code>y</code>, <code>velX</code>, <code>velY</code>, and <code>exists</code> from <code>Shape()</code>, but <code>velX</code> and <code>velY</code> should always equal 20.</p>
-
-<p>You should do this something like <code>Shape.call(this, x, y, 20, 20, exists);</code></p>
-
-<p>It should also define its own properties, as follows:</p>
-
-<ul>
- <li><code>color</code> — <code>'white'</code></li>
- <li><code>size</code> — <code>10</code></li>
-</ul>
-
-<p>Again, remember to define your inherited properties as parameters in the constructor, and set the <code>prototype</code> and <code>constructor</code> properties correctly.</p>
-
-<h3 id="Defining_EvilCircles_methods">Defining EvilCircle()'s methods</h3>
-
-<p><code>EvilCircle()</code> should have four methods, as described below.</p>
-
-<h4 id="draw"><code>draw()</code></h4>
-
-<p>This method has the same purpose as <code>Ball()</code>'s <code>draw()</code> method: It draws the object instance on the canvas. It will work in a very similar way, so you can start by copying the <code>Ball.prototype.draw</code> definition. You should then make the following changes:</p>
-
-<ul>
- <li>We want the evil circle to not be filled in, but rather just have an outer line (stroke). You can achieve this by updating <code><a href="/en-US/docs/Web/API/CanvasRenderingContext2D/fillStyle">fillStyle</a></code> and <code><a href="/en-US/docs/Web/API/CanvasRenderingContext2D/fill">fill()</a></code> to <code><a href="/en-US/docs/Web/API/CanvasRenderingContext2D/strokeStyle">strokeStyle</a></code> and <code><a href="/en-US/docs/Web/API/CanvasRenderingContext2D/stroke">stroke()</a></code>.</li>
- <li>We also want to make the stroke a bit thicker, so you can see the evil circle a bit more easily. This can be achieved by setting a value for <code><a href="/en-US/docs/Web/API/CanvasRenderingContext2D/lineWidth">lineWidth</a></code> somewhere after the <code><a href="/en-US/docs/Web/API/CanvasRenderingContext2D/beginPath">beginPath()</a></code> call (3 will do).</li>
-</ul>
-
-<h4 id="checkBounds"><code>checkBounds()</code></h4>
-
-<p>This method will do the same thing as the first part of <code>Ball()</code>'s <code>update()</code> function — look to see whether the evil circle is going to go off the edge of the screen, and stop it from doing so. Again, you can mostly just copy the <code>Ball.prototype.update</code> definition, but there are a few changes you should make:</p>
-
-<ul>
- <li>Get rid of the last two lines — we don't want to automatically update the evil circle's position on every frame, because we will be moving it in some other way, as you'll see below.</li>
- <li>Inside the <code>if()</code> statements, if the tests return true we don't want to update <code>velX</code>/<code>velY</code>; we want to instead change the value of <code>x</code>/<code>y</code> so the evil circle is bounced back onto the screen slightly. Adding or subtracting (as appropriate) the evil circle's <code>size</code> property would make sense.</li>
-</ul>
-
-<h4 id="setControls"><code>setControls()</code></h4>
-
-<p>This method will add an <code>onkeydown</code> event listener to the <code>window</code> object so that when certain keyboard keys are pressed, we can move the evil circle around. The following code block should be put inside the method definition:</p>
-
-<pre class="brush: js notranslate">let _this = this;
-window.onkeydown = function(e) {
- if (e.key === 'a') {
- _this.x -= _this.velX;
- } else if (e.key === 'd') {
- _this.x += _this.velX;
- } else if (e.key === 'w') {
- _this.y -= _this.velY;
- } else if (e.key === 's') {
- _this.y += _this.velY;
- }
- }</pre>
-
-<p>So when a key is pressed, the event object's <code><a href="/en-US/docs/Web/API/KeyboardEvent/keyCode">keyCode</a></code> property is consulted to see which key is pressed. If it is one of the four represented by the specified keycodes, then the evil circle will move left/right/up/down.</p>
-
-<p>For a bonus point, can you tell us why we've had to set <code>let _this = this;</code> in the position it is in? It is something to do with function scope.</p>
-
-<h4 id="collisionDetect"><code>collisionDetect()</code></h4>
-
-<p>This method will act in a very similar way to <code>Ball()</code>'s <code>collisionDetect()</code> method, so you can use a copy of that as the basis of this new method. But there are a couple of differences:</p>
-
-<ul>
- <li>In the outer <code>if</code> statement, you no longer need to check whether the current ball in the iteration is the same as the ball that is doing the checking — because it is no longer a ball, it is the evil circle! Instead, you need to do a test to see if the ball being checked exists (with which property could you do this with?). If it doesn't exist, it has already been eaten by the evil circle, so there is no need to check it again.</li>
- <li>In the inner <code>if</code> statement, you no longer want to make the objects change color when a collision is detected — instead, you want to set any balls that collide with the evil circle to not exist any more (again, how do you think you'd do that?).</li>
-</ul>
-
-<h3 id="Bringing_the_evil_circle_into_the_program">Bringing the evil circle into the program</h3>
-
-<p>Now we've defined the evil circle, we need to actually make it appear in our scene. To do this, you need to make some changes to the <code>loop()</code> function.</p>
-
-<ul>
- <li>First of all, create a new evil circle object instance (specifying the necessary parameters), then call its <code>setControls()</code> method. You only need to do these two things once, not on every iteration of the loop.</li>
- <li>At the point where you loop through every ball and call the <code>draw()</code>, <code>update()</code>, and <code>collisionDetect()</code> functions for each one, make it so that these functions are only called if the current ball exists.</li>
- <li>Call the evil ball instance's <code>draw()</code>, <code>checkBounds()</code>, and <code>collisionDetect()</code> methods on every iteration of the loop.</li>
-</ul>
-
-<h3 id="Implementing_the_score_counter">Implementing the score counter</h3>
-
-<p>To implement the score counter, follow the following steps:</p>
-
-<ol>
- <li>In your HTML file, add a {{HTMLElement("p")}} element just below the {{HTMLElement("h1")}} element containing the text "Ball count: ".</li>
- <li>In your CSS file, add the following rule at the bottom:
- <pre class="brush: css notranslate">p {
- position: absolute;
- margin: 0;
- top: 35px;
- right: 5px;
- color: #aaa;
-}</pre>
- </li>
- <li>In your JavaScript, make the following updates:
- <ul>
- <li>Create a variable that stores a reference to the paragraph.</li>
- <li>Keep a count of the number of balls on screen in some way.</li>
- <li>Increment the count and display the updated number of balls each time a ball is added to the scene.</li>
- <li>Decrement the count and display the updated number of balls each time the evil circle eats a ball (causes it not to exist).</li>
- </ul>
- </li>
-</ol>
-
-<ul>
-</ul>
-
-<h2 id="Assessment_or_further_help">Assessment or further help</h2>
-
-<p>If you would like your work assessed, or are stuck and want to ask for help:</p>
-
-<ol>
- <li>Put your work into an online shareable editor such as <a href="https://codepen.io/">CodePen</a>, <a href="https://jsfiddle.net/">jsFiddle</a>, or <a href="https://glitch.com/">Glitch</a>.</li>
- <li>Write a post asking for assessment and/or help at the <a href="https://discourse.mozilla.org/c/mdn/learn">MDN Discourse forum Learning category</a>. Your post should include:
- <ul>
- <li>A descriptive title such as "Assessment wanted for Adding bouncing balls features".</li>
- <li>Details of what you have already tried, and what you would like us to do, e.g. if you are stuck and need help, or want an assessment.</li>
- <li>A link to the example you want assessed or need help with, in an online shareable editor (as mentioned in step 1 above). This is a good practice to get into — it's very hard to help someone with a coding problem if you can't see their code.</li>
- <li>A link to the actual task or assessment page, so we can find the question you want help with.</li>
- </ul>
- </li>
-</ol>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/Objects/Object_building_practice", "", "Learn/JavaScript/Objects")}}</p>
-
-<h2 id="In_this_module">In this module</h2>
-
-<ul>
- <li><a href="/en-US/docs/Learn/JavaScript/Objects/Basics">Object basics</a></li>
- <li><a href="/en-US/docs/Learn/JavaScript/Objects/Object-oriented_JS">Object-oriented JavaScript for beginners</a></li>
- <li><a href="/en-US/docs/Learn/JavaScript/Objects/Object_prototypes">Object prototypes</a></li>
- <li><a href="/en-US/docs/Learn/JavaScript/Objects/Inheritance">Inheritance in JavaScript</a></li>
- <li><a href="/en-US/docs/Learn/JavaScript/Objects/JSON">Working with JSON data</a></li>
- <li><a href="/en-US/docs/Learn/JavaScript/Objects/Object_building_practice">Object building practice</a></li>
- <li><a href="/en-US/docs/Learn/JavaScript/Objects/Adding_bouncing_balls_features">Adding features to our bouncing balls demo</a></li>
-</ul>
diff --git a/files/he/learn/javascript/objects/basics/index.html b/files/he/learn/javascript/objects/basics/index.html
deleted file mode 100644
index 25c439e43d..0000000000
--- a/files/he/learn/javascript/objects/basics/index.html
+++ /dev/null
@@ -1,257 +0,0 @@
----
-title: JavaScript object basics
-slug: Learn/JavaScript/Objects/Basics
-translation_of: Learn/JavaScript/Objects/Basics
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{NextMenu("Learn/JavaScript/Objects/Object-oriented_JS", "Learn/JavaScript/Objects")}}</div>
-
-<p class="summary">במאמר בזה, אנחנו נסתכל על עקרונות הסינטקס הבסיסים של אובייקטים ב-JavaScript, ונבקר בחלק ממאפייניה של השפה שנתקלנו בה בעבר, ונבין כי חלק ממאפיינים אלו הם בעצם אובייקטים.</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">Prerequisites:</th>
- <td>Basic computer literacy, a basic understanding of HTML and CSS, familiarity with JavaScript basics (see <a href="/en-US/docs/Learn/JavaScript/First_steps">First steps</a> and <a href="/en-US/docs/Learn/JavaScript/Building_blocks">Building blocks</a>).</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>הבנת התיאוריה הבסיסית שעומדת מאחורי תכנות מונחה עצמים, כיצד זה מתקשר ל-JavaScript (״רוב הדברים הם אובייקטים״) והבנה כיצד ניתן לעבוד עם אובייקטים ב-JavaScript.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Object_-_אובייקטים_-_עקרונות_יסוד">Object - אובייקטים - עקרונות יסוד</h2>
-
-<p>אובייקט הוא אוסף של מידע או פונקציונליות (בדרך מכיל מספר של מתשנים ופונקציות, אשר נקראים - מאפיינים (properties) ו-מתודות (Methodes) כאשר ה נמצאים בתוך אובייקט). נסתכל על דוגמא על מנת להמחיש את הנושא.</p>
-
-<p>על מנת להתחיל, הכינו עותק מקומי של <a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/introduction/oojs.html">oojs.html</a>. קובץ זה מכיל אלמנט של {{HTMLElement("script")}} על מנת שבתוכו נכתוב את הקוד שלנו. אנחנו נשתמש בתצורה הזו על מנת להבין את הסינטקס הבסיסי של אובייקטים. יד עם קובץ זה, פתחו את <a href="/en-US/docs/Learn/Common_questions/What_are_browser_developer_tools#The_JavaScript_console">developer tools JavaScript console</a>.</p>
-
-<p>כמו בהרבה דברים ב-JavaScript, יצירת אובייקט לרוב מתחילים עם הגדרת ואתחול של משתנה. נסו להכניס את הקוד הבא לתוך קוד ה-JavaScript שבקובץ ולאחר מכן שמרו ורעננו את הדף:</p>
-
-<pre class="brush: js notranslate">const person = {};</pre>
-
-<p>כעת פתחו את הקונסולה בדפדפן והזינוו <code>person</code> בתוך הקונסולה, ולאחר מכן לחצו על , <kbd>Enter</kbd>/<kbd>Return</kbd>. אתם אמורים לקבל תוצאה שנראית כך:</p>
-
-<pre class="brush: js notranslate">[object Object]
-Object { }
-{ }
-</pre>
-
-<p>מזל טוב, הרגע יצרתם את האובייקט הראשון שלכם. יחד עם זאת, זהו אובייקט ריק, אז אין יותר מדי מה לעשות איתו. נעדכן את האובייקט שלנו בתוך הקובץ כך שייראה בתצורה הזו:</p>
-
-<pre class="brush: js notranslate">const person = {
- name: ['Bob', 'Smith'],
- age: 32,
- gender: 'male',
- interests: ['music', 'skiing'],
- bio: function() {
- alert(this.name[0] + ' ' + this.name[1] + ' is ' + this.age + ' years old. He likes ' + this.interests[0] + ' and ' + this.interests[1] + '.');
- },
- greeting: function() {
- alert('Hi! I\'m ' + this.name[0] + '.');
- }
-};
-</pre>
-
-<p>לאחר שמירה ורענון של הדף, נסו להכניס את השורות הבאות לתוך הקונסולה:</p>
-
-<pre class="brush: js notranslate">person.name
-person.name[0]
-person.age
-person.interests[1]
-person.bio()
-person.greeting()</pre>
-
-<p>כעת יש לנו מידע ופונקציונליות בתוך האובייקט שלנו, ואנחנו יכולים לגשת אליהם באמצעות סינטקס פשוט:</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אם אינכם מצליחים לגרום לכך לעבוד, נסו להשוות אל מול הקובץ שלנו <a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/introduction/oojs-finished.html">oojs-finished.html</a> או ראו את <a href="http://mdn.github.io/learning-area/javascript/oojs/introduction/oojs-finished.html"> דף האינטרנט ופתחו את הקונסולה בדף זה</a></p>
-</div>
-
-<p>אובייקט מורכב ממספר רכיבים, כאשר לכל רכיב יש שם   (<code>name</code> ו- <code>age</code> למעלה), וכן יש לכל רכיב value (e.g. <code>['Bob', 'Smith']</code> ו- <code>32</code>). כל צמד של שם/ערך חייב להיות מופרד באמצעות פסיק , והשם והערך בכל צמד חייבים להיות מופרדים עם :. הסינטקס תמיד ייראה בתבנית הזו:</p>
-
-<pre class="brush: js notranslate">const objectName = {
- member1Name: member1Value,
- member2Name: member2Value,
- member3Name: member3Value
-};</pre>
-
-<p>הערך של אובייקט יכול להיות כל דבר - במקרה שלנו, האובייקט person, יש לנו מחרוזת, מספר, שני מערכים, ושתי פונקציות. ארבעת הצמדים הראשונים הם פריטי מידע והם נקראים כ-properties של האובייקט. שני הצמדים האחרונים אלו פונקציות שמאפשרות לאובייקט לעשות משהו עם המידע הזה, והם נקראים ה-methods של האובייקט.</p>
-
-<p>אובייקט כמו זה נקרא <strong>object literal</strong> — אנחנו באופן ליטראלי )מפורש) יצרנו את האובייקט והתוכן שלו. זה בניגוד לאובייקטים שנוצרו ממחלקות (classs) שאשר נראה בהמשך.</p>
-
-<p>זה נפוץ מאוד ליצור אובייקט באמצעות <strong>object literal</strong> כאשר אנחנו רוצים להעביר סדרה של פריטי מידע קשורים ובמבנה מסויים, לדוגמא, שליחת בקשה לשרת לצורך השמה במאגר המידע. שליחה של אובייקט יחיד היא יעילה יותר מאשר שליחה של כמה פריטי מידע בנפרד, וזה קל יותר לעבוד עם אובייקט מאשר עם מערך, כאשר אנחנו רוצים לזהות כל פריט באמצעות השם שלךו.</p>
-
-<h2 id="Dot_notation_שימוש_בנקודה-">Dot notation שימוש בנקודה-</h2>
-
-<p>למעלה, אנחנו יכולים לגשת למתודות ולפרופ׳ של האובייקט באמצעות <strong>dot notation</strong>. שם האובייקט - person - משמש כ-<strong>namespace</strong> - הוא חייב להיות מוכנס ראשון, על מנת לקבל גישה לכל מה שמוכס - <strong>encapsulated</strong> בתוך האובייקט. לאחר מכן אנחנו רושמים נקודה <code>.</code> ואז את הפריט מידע שאנחנו רוצים לגשת אליו - זה יכול שם של פרופ׳ מסויים, או לקרוא לאחת מהמתודות של האובייקט. לדוגמא:</p>
-
-<pre class="brush: js notranslate">person.age
-person.interests[1]
-person.bio()</pre>
-
-<h3 id="Sub-namespaces">Sub-namespaces</h3>
-
-<p>זה אפילו אפשרי ליצור אובייקט כערך מסויים של אובייקט אחר. כך לדוגמא, נסו לשנות את ערך הפרופ׳ name מהקוד הבא:</p>
-
-<pre class="brush: js notranslate">name: ['Bob', 'Smith'],</pre>
-
-<p>לקוד זה:</p>
-
-<pre class="brush: js notranslate">name : {
- first: 'Bob',
- last: 'Smith'
-},</pre>
-
-<p>כאן אנחנו בעצם יצרנו <strong>sub-namespace</strong>. זה אולי נשמע מורכז, אבל זה לא - על מנת לגשת לפריטים אלו, אנחנו פשוט צריכים להשתמש בעוד נקודה <code>.</code>. נסו להזין את הקוד הבא בקונסולה:</p>
-
-<pre class="brush: js notranslate">person.name.first
-person.name.last</pre>
-
-<p><strong>חשוב</strong>: לאחר שינוי זה אתם צריכים גם לשנות במתודות את צורת הכתיבה לאור כך ששינינו את הערך ממערך לאובייקט</p>
-
-<pre class="brush: js notranslate">name[0]
-name[1]</pre>
-
-<p>לתצורה הבאה:</p>
-
-<pre class="brush: js notranslate">name.first
-name.last</pre>
-
-<p>אחרת המתודות לא יעבדו.</p>
-
-<h2 id="Bracket_notation_-_שימוש_בסוגריים_מרובעות">Bracket notation - שימוש בסוגריים מרובעות</h2>
-
-<p>יש דרך נוספת לגשת לפרופ׳ של האובייקט - באמצעות שימוש בסוגריים מרובעות. במקום הקוד הבא:</p>
-
-<pre class="brush: js notranslate">person.age
-person.name.first</pre>
-
-<p>אנחנו יכולים להשתמש בקוד זה:</p>
-
-<pre class="brush: js notranslate">person['age']
-person['name']['first']</pre>
-
-<p>זה אמנם נראה מאוד דומה לדרך שבה אנחנו ניגשים לאיברים במערך, ובעיקרון זה אותו דבר - אך במקום להשתמש במספר אינדקס על מנת לבחור איבר מסויים, כפי שנאחנו עושים במערך, אנחנו משתמשים בשם המקושר לכל ערך. זה לא פלא שלפעמים אובייקטים נקראים <strong>associative arrays</strong> — they map strings to values in the same way that arrays map numbers to values.</p>
-
-<h2 id="הגדרת_מפתחות_ומתודות_לאובייקט_-">הגדרת מפתחות ומתודות לאובייקט -</h2>
-
-<p>עד עכשיו ראינו כיצד לאחזר או לגשת לפריטים באובייקט - אך אנחנו יכולים גם לקבוע או לעדכן את הערכים של אותם פריטים ואף ליצור מפתחות ומתודות חדשים, באמצעות הצהרה על אותו מפתח או מתודה שאנחנו רוצים לעדכן או קבוע - (באמצעות שימוש בנקודה או בסוגריים המרובעות) כך:</p>
-
-<pre class="brush: js notranslate">person.age = 45;
-person['name']['last'] = 'Cratchit';</pre>
-
-<p>נסו להזין את השורות למעלה ואז לגשת לערכים ששיניתם באמצעות הקוד על מנת לראות השינוי:</p>
-
-<pre class="brush: js notranslate">person.age
-person['name']['last']</pre>
-
-<p>קביעת ערכים במפתחות או מתודות קיימים היא רק אחד מהדברים שניתן לעשות. כפי שאמרנו למעלה, ניתן גם ליצור מפתחות ומתודות חדשים לאותו אובייקט. נסו להזין את הקוד הבא בקונסולה:</p>
-
-<pre class="brush: js notranslate">person['eyes'] = 'hazel';
-person.farewell = function() { alert("Bye everybody!"); }</pre>
-
-<p>וכעת בדקו את המפתח והמתודה החדשה כך:</p>
-
-<pre class="brush: js notranslate">person['eyes']
-person.farewell()</pre>
-
-<p>היבט מאוד שימושי של שימוש בסוגריים מרובעות הוא שזה לא רק מאפשר לנו לקבוע את הערכים של אותו פריט בצורה דינאמית, אלא גם את השם של אותו פרופ׳ . נניח שאנחנו רוצים שהמשתמשים יוכלו לאחסן ערכים שונים בתוך המידע, באמצעות One useful aspect of bracket notation is that it can be used to set not only member values dynamically, but member names too. Let's say we wanted users to be able to store custom value types in their people data, by typing the member name and value into two text inputs. We could get those values like this:</p>
-
-<pre class="brush: js notranslate">let myDataName = nameInput.value;
-let myDataValue = nameValue.value;</pre>
-
-<p>We could then add this new member name and value to the <code>person</code> object like this:</p>
-
-<pre class="brush: js notranslate">person[myDataName] = myDataValue;</pre>
-
-<p>To test this, try adding the following lines into your code, just below the closing curly brace of the <code>person</code> object:</p>
-
-<pre class="brush: js notranslate">let myDataName = 'height';
-let myDataValue = '1.75m';
-person[myDataName] = myDataValue;</pre>
-
-<p>Now try saving and refreshing, and entering the following into your text input:</p>
-
-<pre class="brush: js notranslate">person.height</pre>
-
-<p>הוספת פרופ׳ לאובייקט באמצעות המתודה לעיל אינה אפשרית כאשר אנחנו משתמשים ב-dot notation, כי היא מקבלת רק ערך ליטרלי ולא ערך של משתנה מסויים שמצביע על אותו שם.</p>
-
-<h2 id="מה_זה_this">מה זה "this"?</h2>
-
-<p>אולי שמתם לב למשהו קצת מוזר בתוך המתודות שלנו. ראו את הדוגמא הבאה:</p>
-
-<pre class="brush: js notranslate">greeting: function() {
- alert('Hi! I\'m ' + this.name.first + '.');
-}</pre>
-
-<p>אתם בטח שואלים את עצמכם מה זה "this". המילה השומרה <code>this</code> מתייחסת לאובייקט שהקוד נכתב בתוכו - אז במקרה הזה המילה <code>this</code> שווה ל- <code>person</code>. אז מדוע לא לרשום <code>person</code> במקום? כפי שתראו במאמר שלנו בנושא<a href="/en-US/docs/Learn/JavaScript/Objects/Object-oriented_JS">Object-oriented JavaScript מתחילים</a> - כאשר אנחנו יוצרים קונסטרקטורים, המילה <code>this</code> היא מאוד שימושית - היא תבטיח לנו תמיד שהערכים הנכונים מושמים בכל פעם שהמופעים של האובייקט פפפפפ נוצרים - גלומר - אובייקטים שנוצרו - 999999, יהיו בעלי ערכים שונים article, when we start creating constructors and so on, <code>this</code> is very useful — it will always ensure that the correct values are used when a member's context changes (e.g. two different <code>person</code> object instances may have different names, but will want to use their own name when saying their greeting).</p>
-
-<p>ננסה לפשט ולהסביר באמצעות יצירת שני אובייקטים של person:</p>
-
-<pre class="brush: js notranslate">const person1 = {
- name: 'Chris',
- greeting: function() {
- alert('Hi! I\'m ' + this.name + '.');
- }
-}
-
-const person2 = {
- name: 'Brian',
- greeting: function() {
- alert('Hi! I\'m ' + this.name + '.');
- }
-}</pre>
-
-<p>במקרה הזה, <code>person1.greeting()</code> יציג "Hi! I'm Chris.";ואילו <code>person2.greeting()</code> יציג "Hi! I'm Brian.", למרות שהקוד של המתודה הוא זהה לחלוטין. כפי שאמרנו למעלה, <code>this</code> שוה בעצם לאובייקט שהקוד נמצא בתוכו - this לא משמעותי ושימושי כאשר אנחנו יוצרים אובייקטים באמצעות אובייקט ליטראלי, אבל הוא מאוד שימושי כאשר אנחנו יוצרים אובייקטים באופן דינאמי (באמצעות קונסטרקטורים לדוגמא). זה יהיה ברור יותר בהמשך הדרך, מבטיחים.</p>
-
-<h2 id="השתמשנו_באובייקטים_לאורך_כל_הזמן_הזה">השתמשנו באובייקטים לאורך כל הזמן הזה</h2>
-
-<p>ככל שאנחנו עוברים על הדוגמאות הללו, אתם בטח חושבים לעצמכם שכבר השתמשנו בעבר בתחביר של סימון נקודה, וזה נכון. בכל פעם שאנחנו השתמשנו בדוגמא אשר משתמשת ב-api מובנה של הדפדפן או באובייקט של javascript, אנחנו בעצם השתמשנו באובייקטים, מכיוון שאותם מאפיינים נבנו באמצעות שימוש במבנה זה למבנה של אובייקט שהסברנו עליו במודול זה, אמנם בצורה קצת יותר מורכבת מהדוגמאות שלנו כאן, אך במבנה דומה.</p>
-
-<p>כאשר אנחנו משתמשים במתודות של מחרוזות כאלו לדוגמא:</p>
-
-<pre class="brush: js notranslate">myString.split(',');</pre>
-
-<p>אנחנו בעצם מתשמשים במתודה שזמינה לנו באמצעות האובייקט הגלובלי <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/String">String</a></code>. בכל פעם שאנחנו יוצרים מחרוזת בקוד שלנו, מחרוזת זו באופן אוטומטי נוצרת כמופע/מודל/דוגמא של <code>String</code>, ולכן יש לה מספר מתודות ופרופ׳ אשר זמינות לה.</p>
-
-<p>כאשר אנחנו ניגשים ל-<strong>d</strong>ocument <strong>o</strong>bject <strong>m</strong>odel אמצעות הקוד הבא:</p>
-
-<pre class="brush: js notranslate">const myDiv = document.createElement('div');
-const myVideo = document.querySelector('video');</pre>
-
-<p>אנחנו מתשמשים במתודות שזמינות לנו עבור מופע של ה-<code><a href="/en-US/docs/Web/API/Document">Document</a></code>. לכל דף אינטרנט שמועלה, נוצר מופע של <code>Document</code>, אשר נקרא <code>document</code>והוא מייצג את כל המבנה, תוכן ומאפיינים נוספים של אותו דף (כמו לדוגמא ה-URL שלו). וזה אומר שיש לו מספר מתודות ומפתחות שזמינים עבור אותו מופע זה.</p>
-
-<p>אותו הדבר בערך קורה עם הרבה אובייקטים מובנים/api שאנחנו משתשמים בהם — <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a></code>, <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math">Math</a></code>, וכך הלאה.</p>
-
-<p>שימו לב שbuilt in Objects/APIs לא תמיד יוצרים מופעים של אובייקט באופן אוטומטי. לדוגמא, ה- <a href="/en-US/docs/Web/API/Notifications_API">Notifications API</a> — אשר מאפשר לדפדפנים מודרניים להזרים התראות מערת - דורש מאיתנו לייצר מופע אובייקט חדש באמצעות קונסטקטור, עבור כל התראה שנרצה להזרים. נסו להזין את הקוד הבא בקוסולה: :</p>
-
-<pre class="brush: js notranslate">const myNotification = new Notification('Hello!');</pre>
-
-<p>אנו נסתכל על קונסרקטורים במאמרים הבאים.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: זה מאוד שימושי לחשוב על הדרך שבה אובייקטים מתקשרים כ- <strong>message passing</strong> — כאשר אובייקט אחד צריך אובייקט אחד על מנת לבצע פעולה מסויימת, הוא לרוב ישלח הודעה לאותו אובייקט באמצעו תאחת המתודות שלו ויחכה לתגובה, שהיא בעצם ה- return value.</p>
-</div>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>סיימנו את המאמר הראשונות שלנו בנושא אובייקטים ב-JavaScript - כעת, אמור להיות לכם בסיס כיצד לעבוד עם אובייקטים ב-JavaScript, כיצד ליצור אובייקטים פשוטים בעצמם. הבנו גם שאובייקטים הם מבנה מאוד שימוש לאחסון של מידע ופונקציונליות הקשורים זה בזה - אם היינו מנסים לשמור את כל המידע והפונקציונליות של האובייקט <code>person</code> כמשתנים ופונקציות נפרדות, זה היה מאתגר וקשה. אבוייקטים מאפשרים לנו לשמור את המידע בצורה בטוחה ונעולה בתוך חבילה משל עצמו.</p>
-
-<p>במאמר הבא אנחנו נסתכל על תיאוריית object-oriented programming (OOP), וכיצד טכניקות שכאלו יכולות לשמש אותנו ב- JavaScript.</p>
-
-<p>{{NextMenu("Learn/JavaScript/Objects/Object-oriented_JS", "Learn/JavaScript/Objects")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Basics">אובייקטים - עקרונות יסוד</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Object-oriented_JS">Object-oriented JavaScript למתחילים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Object_prototypes">Object prototypes</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Inheritance">הורשה ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/JSON">עבודה עם JSON data</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Object_building_practice">שיטות ליצירת אובייקטים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Adding_bouncing_balls_features">Adding features to our bouncing balls demo</a></li>
-</ul>
diff --git a/files/he/learn/javascript/objects/index.html b/files/he/learn/javascript/objects/index.html
deleted file mode 100644
index 3b033ee0e8..0000000000
--- a/files/he/learn/javascript/objects/index.html
+++ /dev/null
@@ -1,54 +0,0 @@
----
-title: Introducing JavaScript objects
-slug: Learn/JavaScript/Objects
-tags:
- - Article
- - Assessment
- - Beginner
- - CodingScripting
- - Guide
- - JavaScript
- - Learn
- - NeedsTranslation
- - Objects
- - TopicStub
- - Tutorial
-translation_of: Learn/JavaScript/Objects
----
-<div>{{LearnSidebar}}</div>
-
-<p class="summary">ב-JavaScript, רוב הדברים הם אובייקטים, החל מהמאפיינים הבסיסיים של השפה כמו מחרוזות ומערכים, ועד {{Glossary("API", "APIs")}} של הדפדפן שבנויים מעל JavaScript. אנחנו אפילו יכולים ליצור אובייקטים בעצמנו, ו-״להכמיס״ בתוכן פונקציות ומשתנים כך שיתפקדו ככלי להכלת מידע מאוד שימושי. חשוב להבין את הרעיון של JavaScript סביב האובייקט אם אנחנו רוצים להמשיך להתקדם בלמידה שלנו של שפה זו, ומודול זה נועד בדיוק לשם כך. במודול זהנלמד על התיאוריה סביב אובייקט וכן על הסינטקס בפרטים ומשם נמשיך ליצירת אובייקטים בעצמנו</p>
-
-<h2 id="ידע_מוקדם">ידע מוקדם</h2>
-
-<p>לפני שתחלו בלימוד מודול זה, ודאו כי אתם בקיאים ב- {{Glossary("HTML")}} וב- {{Glossary("CSS")}}. אנו ממליצים לכם לעבור על המודולים בנושא <a href="https://developer.mozilla.org/he/docs/Web/Guide/HTML/Introduction">הכרות עם HTML</a> ו-<a href="https://developer.mozilla.org/he/docs/Learn/CSS/Introduction_to_CSS">הכרות עם CSS</a> לפני שתמשיכו בלימוד JavaScript.</p>
-
-<p>בנוסף, הנכם מתבקשים לעבור על עקרונות הבסיס של JavaScript לפני שתמשיכו במודול זה. לשם כך, וודאו כי הנכם בקיאי במודול <a href="/he/docs/Learn/JavaScript/First_steps">צעדים ראשונים ב-JavaScript</a> ובמודול <a href="/he/docs/Learn/JavaScript/Building_blocks">אבני הבניין של JavaScript </a>לפני שתמשיכו במודול זה.</p>
-
-<div class="note">
-<p><strong>הערה</strong>: אם אתם עובדים על מחשב\טבלט\מכשיר אחר שאין לכם אפשרות ליצור עליו קבצים אישיים, אתם יכולים לנסות את (רוב) דוגמאות הקוד על תוכנות קוד אינטרנטיות כמו <a href="http://jsbin.com/">JSBin</a> או <a href="https://thimble.mozilla.org/">Thimble</a>.</p>
-</div>
-
-<h2 id="Guides">Guides</h2>
-
-<dl>
- <dt><a href="/he/docs/Learn/JavaScript/Objects/Basics">אובייקטים - עקרונות יסוד</a></dt>
- <dd>במאמר הראשון אנחנו נסתכל על אובייקטים ב-JavaScript, ועל הסינטקס הבסיסי והחשוב של אובייקט. נבקר שוב כמה מאפשרויות של JavaScript שכבר ראינו לפני כן בקורס, ונבין שהרבה מאותן אפשרויות אלו שנתקלנו בהן בעבר, הן בעצם אובייקטים.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/Objects/Object-oriented_JS">תכנות מונחה עצמים ב-JavaScript למתחילים</a></dt>
- <dd>לאחר שסיימנו עם הבסיס, נתמקד במעבר על התיאוריה של תכנות מונחה עצמים (object-oriented programming (OOP)) ב-JavaScript (object-oriented JavaScript (OOJS)) - מאמר זה יספק רקע בסיסי על תכנות מונחה עצמים בכלל, ולאחר מכן נחקור כיצד JavaScript מחקה (מלשון: חיקוי) מחלקות (classes) באמצעות constructor functions ואיך אנחנו יוצרים אובייקט.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/Objects/Object_prototypes">Object prototypes - טיפוסי אב של אובייקט</a></dt>
- <dd>טיפוסי אב - Prototypes - זה המנגנון שבאמצעותו אובייקטים ב-JavaScript יורשים מאפיינים אחד מהשנים, והם עובדים בצורה אחרת מאשר מנגנוני הורשה הקיימים בשפות לתכנות מונחה עצמים אחרות. במאמר זה אנחנו נחקור את ההבדלים השונים, נסביר כיצד שרשרת אבי הטיפוס (prototype chains) עובדת ונסתכל על איך ה-property שנקרא prototype יכול לשמש על מנת להוסיף מתודות לקונסטרקטורים קיימים.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/Objects/Inheritance">הורשה ב-JavaScript</a></dt>
- <dd>לאחר שסיימנו להסביר על התיאוריה של תכנות מונחה עצמים (object-oriented programming (OOP)) ב-JavaScript, מאמר זה יראה איך ליצור מחלקות בנות (constructors) שיורשות מאפיינים מהמחלקות ״הורים״ With most of the gory details of OOJS now explained, this article shows how to create "child" object classes (constructors) that inherit features from their "parent" classes. In addition, we present some advice on when and where you might use OOJS.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/Objects/JSON">Working with JSON data</a></dt>
- <dd>JavaScript Object Notation (JSON) is a standard text-based format for representing structured data based on JavaScript object syntax, which is commonly used for representing and transmitting data on web sites (i.e. sending some data from the server to the client, so it can be displayed on a web page). You'll come across it quite often, so in this article we give you all you need to work with JSON using JavaScript, including parsing the JSON so you can access data items within it and writing your own JSON.</dd>
- <dt><a href="/he/docs/Learn/JavaScript/Objects/Object_building_practice">Object building practice</a></dt>
- <dd>In previous articles we looked at all the essential JavaScript object theory and syntax details, giving you a solid base to start from. In this article we dive into a practical exercise, giving you some more practice in building custom JavaScript objects, which produce something fun and colorful — some colored bouncing balls.</dd>
-</dl>
-
-<h2 id="Assessments">Assessments</h2>
-
-<dl>
- <dt><a href="/he/docs/Learn/JavaScript/Objects/Adding_bouncing_balls_features">Adding features to our bouncing balls demo</a></dt>
- <dd>In this assessment, you are expected to use the bouncing balls demo from the previous article as a starting point, and add some new and interesting features to it.</dd>
-</dl>
diff --git a/files/he/learn/javascript/objects/inheritance/index.html b/files/he/learn/javascript/objects/inheritance/index.html
deleted file mode 100644
index 1d43d06d14..0000000000
--- a/files/he/learn/javascript/objects/inheritance/index.html
+++ /dev/null
@@ -1,437 +0,0 @@
----
-title: Inheritance in JavaScript
-slug: Learn/JavaScript/Objects/Inheritance
-translation_of: Learn/JavaScript/Objects/Inheritance
----
-<div dir="rtl">{{LearnSidebar}}</div>
-
-<div dir="rtl">{{PreviousMenuNext("Learn/JavaScript/Objects/Object_prototypes", "Learn/JavaScript/Objects/JSON", "Learn/JavaScript/Objects")}}</div>
-
-<p class="summary" dir="rtl">לאחר שסיימנו עם התיאוריה והפרטים של OOJS, המאמר הזה נועד להראות כיצד ליצור מחלקות אובייקטים ״ילדים״ (constructors) אשר יורשים מההורים שלהם. אנו גם נציג מעין עצות מתי נרצה להשתמש ב-OOJS ונסתכל כיצד ״מחלקות״ מתבצעות בסינטקס המודרני של ECMAScript.</p>
-
-<table class="learn-box standard-table" dir="rtl">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>
- <p>אוריינות מחשב בסיסית, הבנה בסיסית ב-HTML ו ב-CSS, היכרות עם יסודות ה-JavaScript (ראה <a href="/en-US/docs/Learn/JavaScript/First_steps">First steps</a> and <a href="/en-US/docs/Learn/JavaScript/Building_blocks">Building blocks</a>) and OOJS basics (see <a href="/en-US/docs/Learn/JavaScript/Object-oriented/Introduction">Introduction to objects</a>).</p>
- </td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>להבין כיצד זה אפשרי להחיל הורשה ב- JavaScript</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="Prototypal_inheritance">Prototypal inheritance</h2>
-
-<p dir="rtl">עד עכשיו ראינו קצת הורשה בפעולה - ראינו כיצד prototype chains עובדות וכיצד מתודות ופרופ׳ מורשים בהמשך השרשרת. אבל זה היה בעיקר עם פונקציות מובנות של הדפדפן. כיצד אנחנו יכולים ליצור אובייקט ב-JavaScript אשר יורש מאובייקט אחר?</p>
-
-<h2 dir="rtl" id="דוגמא">דוגמא:</h2>
-
-<p dir="rtl">ראשית, עשו עותק מקומי של <a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/advanced/oojs-class-inheritance-start.html">הקובץ</a> או ראו אותו כ<a href="http://mdn.github.io/learning-area/javascript/oojs/advanced/oojs-class-inheritance-start.html">דף אינטרנט</a>. בקוד זה אתם תראו את ה-<code>Person()</code> constructor שהשתמשנו בו לאורך המודול, עם שינוי קל - הגדרנו רק את ה-properties בתוך ה-constructor.</p>
-
-<pre class="brush: js">function Person(first, last, age, gender, interests) {
- this.name = {
- first,
- last
- };
- this.age = age;
- this.gender = gender;
- this.interests = interests;
-};</pre>
-
-<p dir="rtl">כל המתודות <em>כולן</em> מוגדרות בתוך ה-constructor's prototype. לדוגמא:</p>
-
-<pre class="brush: js" dir="rtl">Person.prototype.greeting = function() {
- alert('Hi! I\'m ' + this.name.first + '.');
-};</pre>
-
-<div class="note" dir="rtl">
-<p><strong>לתשומת לבך</strong>: בקוד המקור אתם גם תראו מתודות נוספות שמוגדרות, <code>()bio</code> ו-<code>()farewell</code>. אנחנו נראה בהמשך כיצד מתודות אלו יכולות להיות מורשות ל-constructors אחרים.</p>
-</div>
-
-<p dir="rtl">נניח ואנחנו רוצים ליצור מחלקה של <code>Teacher</code>, כמו זו שהסברנו בתחילת המודול לגבי תכנות מונחה עצמים, ומחלקה זו יורשת את כל הפרופ׳ והמתודות של <code>Person</code>, אבל גם כוללת:</p>
-
-<ol dir="rtl">
- <li>ה- property החדש בשם <code>subject</code> — אשר יכיל את נושאי הלימוד שהמורה מלמד.</li>
- <li>מתודה <code>()greeting</code> מעודכנת, אשר תהיה יותר רשמית מהמתודה <code>()greeting</code> הרגילה.</li>
-</ol>
-
-<h2 dir="rtl" id="הגדרה_של_ה-constructor_function_בשם_Teacher">הגדרה של ה-constructor function בשם ()Teacher</h2>
-
-<p dir="rtl">הדבר הראשון שאנחנו צריכים לעשות הוא להגדיר את ה-constructor בשם <code>()Teacher</code> - הוסיפו את הקוד הבא מתחת לקוד הנוכחי:</p>
-
-<pre class="brush: js">function Teacher(first, last, age, gender, interests, subject) {
- Person.call(this, first, last, age, gender, interests);
-
- this.subject = subject;
-}</pre>
-
-<p dir="rtl">זה נראה מאוד דומה ל-constructor בשם Person, אבל משהו פה שונה, משהו שלא ראינו עד כה - פונקציה בשם <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function/call">()call</a></code>.</p>
-
-<p dir="rtl">פונקציה זו היא בעיקרון מאפשרת לנו לקרוא לפונקציה שהוגדרה במקום אחר, אבל לקרוא לה בהקשר הנוכחי.</p>
-
-<p dir="rtl">הפרמטר הראשון שהפונקציה הזו מקבלת מכיל את הערך של <code>this</code> שאנחנו נרצה להשתמש בו כאשר אנחנו מריצים את הפונקציה, והפרמטרים האחרים אלו פרמטרים שאמורים להיות מועברים לפונקציה עצמה כאשר היא מופעלת.</p>
-
-<p dir="rtl">אנחנו רוצים שה-<code>Teacher()</code> constructor יקבל את אותם פרמטרים כמו שה-<code>Person()</code> constructor שהוא יורש ממנו מקבל, ולכן אנחנו מציינים אותם כפרמטרים בתוך ההפעלה של ה-<code>()call</code>.</p>
-
-<p dir="rtl">השורה האחרונה בתוך ה-constructor פשוט מגדירה property בשם <code>subject</code> אשר ייחודי למורים, שאנשים רגילים מ-<code>()Person</code> לא מקבלים.</p>
-
-<p dir="rtl">יכלנו גם לרשום זאת כך, ללא שימוש ב-<code>()call</code>:</p>
-
-<pre class="brush: js" dir="rtl">function Teacher(first, last, age, gender, interests, subject) {
- this.name = {
- first,
- last
- };
- this.age = age;
- this.gender = gender;
- this.interests = interests;
- this.subject = subject;
-}</pre>
-
-<p>אבל בקוד למעלה זו הגדרה מחדש של ה-properties כחדשים, לא כאלו שיורשים מ- <code>()Person</code>, אז זה סותר את מה שאנחנו מנסים לעשות - זה לא מוריש אלא זה יוצר חדשים. מה גם שזה לוקח יותר שורות קוד.</p>
-
-<h3 id="ירושה_מ-constructor_שלא_מקבל_פרמטרים">ירושה מ-constructor שלא מקבל פרמטרים</h3>
-
-<p>שימו לב שאם ה-constructor שאנחנו יורשים ממנו לא מקבל את הערכים של ה-property שלו מקבלים מפרמטרים, אז אנחנו לא צריכים לציין אותם כפרמטרים בתוך ה-<code>()call</code>. לדומא, אם היה לנו משהו פשוט כמו זה: :</p>
-
-<pre class="brush: js">function Brick() {
- this.width = 10;
- this.height = 20;
-}</pre>
-
-<p>אנחנו יכולים לרשת את ה-properties של ה-<code>width</code> ואת ה-<code>height</code>, באמצעות שימוש בקוד הרשום מטה:</p>
-
-<pre class="brush: js">function BlueGlassBrick() {
- Brick.call(this);
-
- this.opacity = 0.5;
- this.color = 'blue';
-}</pre>
-
-<p>שימו לב שאנחנו רק צריכים לציין את ה-<code>this</code> בתוך ה-<code>()call</code>, ללא פרמטרים נוספים, שכן אנחנו לא יכולים יורשים שום דבר מ-<code>()Brick</code> שהוא קיבל דרך פרמטרים.</p>
-
-<h2 id="קביעת_ה-prototype_וה-constructor_של_Teacher">קביעת ה-prototype וה-constructor של ()Teacher</h2>
-
-<p>עד עכשיו הכל עובד תקין, אך יש לנו בעיה. הגדרנו אמנם constructor חדש, ויש לו את ה-property בשם <code>prototype</code>, אשר כברירת מחדל מכיל רק הפנייה ל-constructor function עצמה.</p>
-
-<p>הוא לא מכיל שום מתודות של ה-property בשם <code>prototype</code> של ה-Person constructor. על מנת לראות זאת, הכניסו <code>(Object.getOwnPropertyNames(Teacher.prototype</code> לתוך הקונסולה.</p>
-
-<p>לאחר מכן הכניסו זאת שוב, והחליפו את המילה <code>Teacher</code> במילה <code>Person</code>. ה-constructor החדש לא יורש את אותן מתודות. על מנת לראות זאת, השוו את הפלט של <code>Person.prototype.greeting</code> והפלט של <code>Teacher.prototype.greeting</code>. אנחנו צריכים לגרום ל-<code>()Teacher</code> לירוש מתודות שמוגדרות ב-prototype של <code>()Person</code>. איך עושים זאת?</p>
-
-<ol>
- <li>הוסיפו את הקוד הבא מתחת לקוד שהוספתם לפני כן:
- <pre class="brush: js">Teacher.prototype = Object.create(Person.prototype);</pre>
- כאן <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/create">()create</a></code> מגיע שוב לעזרה. במקרה הזה, אנחנו משתמשים בו על מנת ליצור אובייקט חדש שיהיה הערך של <code>Teacher.prototype</code>. האובייקט החדש הוא בעל <code>Person.prototype</code> כאובייקט ה-prototype שלו, ולכן, הוא יירש ממנו אם וכאשר יצטרך, את כל המתודות שזמינות ב-<code>Person.prototype</code>.</li>
- <li>אנחנו צריכים לעשות משהו נוסף לפני שנמשיך הלאה. לאחר שהוספנו את השורה הקודמת, ה-property בשם <code>constructor</code> שווה כעת ל- <code>()Person</code>, מכיוון שאנחנו הרגע הגדרנו את <code>Teacher.prototype</code> אליו. נסו לשמור את הקוד ולהעלות את הדף בדפדפן וראו זאת על ידי הקלדת <code>Teacher.prototype.constructor</code> בקונסולה.</li>
- <li>זה יכול להיות בעיה, ולכן אנחנו צריכים לתקן זאת. ניתן לעשות זאת באמצעות הקלדת הקוד הבא מתחת לקוד הנוכחי שלנו.:
- <pre class="brush: js">Object.defineProperty(Teacher.prototype, 'constructor', {
-  value: Teacher,
-  enumerable: false, // so that it does not appear in 'for in' loop
-  writable: true });</pre>
- </li>
- <li>כעת, אם תשמרו ותרעננו את הדף, הקלדת <code>Teacher.prototype.constructor</code> לקונסולה אמורה להחזיר לכם <code>()Teacher</code>, כפי שרצינו, ובנוסף אנחנו יורשים מ-<code>()Person</code>.</li>
-</ol>
-
-<h2 id="הענקה_ל-_Teacher_פונקצייתמתודת_greeting_חדשה">הענקה ל- Teacher() פונקציית/מתודת greeting() חדשה</h2>
-
-<p>אנו רוצים להגדיר פונקציית <code>()greeting</code> חדשה בתוך ה-<code>Teacher()</code> constructor שלנו.</p>
-
-<p>הדרך הפשוטה ביותר לעשות זאת היא להגדיר זאת בתוך ה-prototype של <code>()Teacher</code> - הוסיפו את הקוד הבא מתחת לקוד הנוכחי:</p>
-
-<pre class="brush: js">Teacher.prototype.greeting = function() {
- var prefix;
-
- if (this.gender === 'male' || this.gender === 'Male' || this.gender === 'm' || this.gender === 'M') {
- prefix = 'Mr.';
- } else if (this.gender === 'female' || this.gender === 'Female' || this.gender === 'f' || this.gender === 'F') {
- prefix = 'Mrs.';
- } else {
- prefix = 'Mx.';
- }
-
- alert('Hello. My name is ' + prefix + ' ' + this.name.last + ', and I teach ' + this.subject + '.');
-};</pre>
-
-<p>מתודה זו מקפיצה את הברכה של המורה, ומשתמשת במילים הנכונות בהתאם למין המורה באמצעות משפטי תנאי שהוגדרו.</p>
-
-<h2 id="נסו_את_הדוגמא_הבאה">נסו את הדוגמא הבאה:</h2>
-
-<p>כעת שהכנסו את כל הקוד, נסו ליצור אובייקטים חדשים מ-<code>()Teacher</code> באמצעות הכנסת הקוד הבא מתחת לקוד הנוכחי:</p>
-
-<pre class="brush: js">var teacher1 = new Teacher('Dave', 'Griffiths', 31, 'male', ['football', 'cookery'], 'mathematics');</pre>
-
-<p>כעת, שמרו את הדף ורעננו ונסו לגשת לפרופ׳ והמתודות של האובייקט <code>teacher1</code> החדש שלנו. לדוגמא:</p>
-
-<pre class="brush: js">teacher1.name.first;
-teacher1.interests[0];
-teacher1.bio();
-teacher1.subject;
-teacher1.greeting();
-teacher1.farewell();</pre>
-
-<p>הכל אמור לעבוד כשורה. השורות 1,2,3 ו-6 משתמשות במתודות/פרופ׳ שנורשו מה-<code>Person()</code> constructor שלנו. השורה 4 משתמשת בפרופ׳ שזמין רק באמצעות ה-<code>Teacher()</code> constructor שלנו. שורה 5 הייתה יכולה להיות מורשת מ-<code>()Person</code>, אבל מכיוון של-<code>()Teacher</code> יש את אותה מתודה, אז היא ניגשת למתודה שנמצאת ב-<code>()Teacher</code>.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אם נתקלתם בבעיות, נסו להשוות את הקוד שלכם ל <a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/advanced/oojs-class-inheritance-finished.html">קוד הסופי</a> או ראו אותו כ <a href="http://mdn.github.io/learning-area/javascript/oojs/advanced/oojs-class-inheritance-finished.html">דף אינטרנט</a>.</p>
-</div>
-
-<p>הטכניקות שראינו עד כה, אינן היחידות ליצירת מחלקות ירושה ב-JavaScript, אבל הן עובדות בסדר, הן נותנות לכם הבנה כיצד להחיל ירושה ב-JavaScript.</p>
-
-<p>אולי תהיו מעוניינים לבדוק חלק מהאפשרויות החדשות ש-{{glossary("ECMAScript")}} מאפשרת לנו, בצורה ״נקייה״ יותר, באמצעות <a href="/en-US/docs/Web/JavaScript/Reference/Classes">Classes</a>. אנו נגע בדרך זו בהמשך. שימו לב כי דרך חדשה זו לא תומכת בכל הדפדפנים. כל יתר הדרכים שראינו תומכות בדפדנים ישנים גם כמו IE9 ומוקדם יותר ויש דרכים גם לאפשר תמיכה לדפדפנים ישנים יותר.</p>
-
-<p>דרך מקובלת היא להשתמש בספריית JavaScript - לפופולריות שביניהן יש סט של פונקציונליות שזמין עבור ביצוע הורשה בצורה פשוטה ומהירה. אחת מהן היא <a href="http://coffeescript.org/#classes">CoffeeScript</a> אשר מאפשרת <code>class</code> ,<code>extends</code> לדוגמא.</p>
-
-<h2 id="המשך_תרגול">המשך תרגול</h2>
-
-<p>במאמר שלנו בנושא <a href="/en-US/docs/Learn/JavaScript/Objects/Object-oriented_JS#Object-oriented_programming_from_10000_meters">OOP theory section</a>, כללנו גם מחלקת <code>Student</code> באופן עקרוני, אשר יורשת תכונות מ-<code>Person</code> וגם יש לה מתודת <code>()greeting</code> שונה מזו של <code>Person</code> ומשל <code>Teacher</code>. נסתכל כיצד ה-greeting של התלמידים אמורה להיות וננסה לבנות constructor בשם <code>()Student</code> משלנו, אשר יורש את כל התכונות מ-<code>()Person</code> ומחיל מתודת <code>()greeting</code> שונה.</p>
-
-<div class="note">
-<p><strong>שימו לב</strong>: אם אתם נתקלים בבעיות, ראו את ה<a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/advanced/oojs-class-inheritance-student.html">גרסה הסופית</a> או <a href="http://mdn.github.io/learning-area/javascript/oojs/advanced/oojs-class-inheritance-student.html">כדף אינטרנט</a> .</p>
-</div>
-
-<h2 id="סיכום_בנושא_תכונות_האובייקט">סיכום בנושא תכונות האובייקט</h2>
-
-<p>על מנת לסכם, יש לנו בעיקרון שלוש סוגים של property/method לדאוג להם:</p>
-
-<ol>
- <li>אלו המוגדרים בתוך ה-constructor function וניתנים לאובייקטים שנוצרים באמצעות ה- <code>this</code>. אלו בעיקרון מאוד קלים לאיתור - בתוך הקוד שלנו, אלו התכונות שמוגדרות בתוך ה-constructor באמצעות <code>this.x = x</code>, והם זמינים רק עבור האובייקטים שנוצרים (בדרך כלל נוצרים באמצעות ה-constructor ושימוש במילה השמורה <code>new</code>, לדוגמא: <code>()var myInstance = new myConstructor</code>.</li>
- <li>אלו המוגדרים ישרות על ה-constructor עצמם, ואלו זמינות רק על ה-constructor. הם לרוב יהיו זמינים רק אובייקטים מובנים של הדפדפן, ואנחנו יכולים לזהות שהם קשורים באופן ישירות ל-constructor ולא למופע אובייקט. לדוגמא <code>()<a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/keys">Object.keys</a></code>.</li>
- <li>ואלו המוגדרים על הפרופ׳ בשם prototype של ה-constructor, אשר נורשים על ידי כל מופעי האובייקט שנוצרים או אובייקטים שיורשים מהם. זה כולל כל תכונה שמוגדרת ב-property בשם prototype של ה-Constructor. לדוגמא: <code>()myConstructor.prototype.x</code>.</li>
-</ol>
-
-<p>אם אתם לא בטוחים מה זה מה, אל תדאגו, אתם תכירו אותם יותר לעומק במהלך הדרך והמשך הקריירה שלכם ככל שתתמודדו איתם.</p>
-
-<h2 id="ECMAScript_2015_Classes">ECMAScript 2015 Classes</h2>
-
-<p>ECMAScript 2015 הציגה מעין סינטקס חדש בשם <a href="/en-US/docs/Web/JavaScript/Reference/Classes">class syntax</a> ל- JavaScript כדרך חדשה לרשום מחלקות לשימוש חוזר, באמצעות סינטקס פשוט ונקי יותר, אשר דומה יותר ל-classes ב-C++ או ב-Java. בחלק הזה של המאמר אנחנו נמיר את הדוגמאות מלמעלה מ-prototypal inheritance ל-classes, על מנת להראות לכם איך לעשות שימוש-classes.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: דרך חדשה זו של כתיבת classes נתמכת בכל הדפדפנים המודרניים, אבל זה עדיין חשוב להבין את ה-prototypal inheritance במקרה ותיתקלו בפרוייקט שדורש תמיכה בדפדפן שאינו תומך בסינטקס של classes - הידוע מבין כולם הוא Internet Explorer.</p>
-</div>
-
-<p>נסתכל על הדוגמא שלנו של Person כתובה בצורת classes:</p>
-
-<pre class="brush: js">class Person {
- constructor(first, last, age, gender, interests) {
- this.name = {
-  first,
-  last
-  };
- this.age = age;
- this.gender = gender;
-  this.interests = interests;
- }
-
- greeting() {
-  console.log(`Hi! I'm ${this.name.first}`);
- };
-
- farewell() {
-  console.log(`${this.name.first} has left the building. Bye for now!`);
- };
-}
-</pre>
-
-<p>ההצהרה באמצעות המילה השמורה <a href="/en-US/docs/Web/JavaScript/Reference/Statements/class">class</a> מצהירה בעצם בשאנחנו רוצים ליצור class חדשה. בתוך הבלוק הזה שבין <code>{}</code>, אנחנו מגדירים את התכונות של אותה מחלקה:</p>
-
-<ul>
- <li>המתודה <code><a href="/en-US/docs/Web/JavaScript/Reference/Classes/constructor">()constructor</a></code> מגדירה את ה-constructor function שמייצגת את ה-class <code>Person</code> שלנו.</li>
- <li><code>()greeting</code> ו- <code>()farewell</code> הם class methods. כל מתודה שאנחנו נרצה לייחס אותה למחלקה מוגדרת בתוך ה-class, לאחר ה-constructor. בדוגמא הזו, השתמשנו ב- <a href="/en-US/docs/Web/JavaScript/Reference/Template_literals">template literals</a> מאשר בשרשור מחרוזות על מנת שהקוד שלנו יהיה קריא יותר.</li>
-</ul>
-
-<p>כעת אנחנו יכולים ליצור מופעי אובייקט חדשים באמצעות שימוש באופרטור <a href="/en-US/docs/Web/JavaScript/Reference/Operators/new"><code>new</code> operator</a>, באותה הדרך שעשינו בעבר:</p>
-
-<pre class="brush: js">let han = new Person('Han', 'Solo', 25, 'male', ['Smuggling']);
-han.greeting();
-// Hi! I'm Han
-
-let leia = new Person('Leia', 'Organa', 19, 'female', ['Government']);
-leia.farewell();
-// Leia has left the building. Bye for now
-</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: מאחורי הקלעים, ה-classes שלנו מומרים ל-prototypal Inheritance models - זהו רק syntactic sugar - שזה אומר דרך אחרת מבחינת סינטקס לעשות דבר זהה, אך לא משהו אחר. יחד עם זאת, אין ספק שזו דרך פשוטה יותר להעניק הורשה.</p>
-</div>
-
-<h3 id="הורשה_עם_class_syntax">הורשה עם class syntax</h3>
-
-<p>למעלה יצרנו class על מנת לתאר person. יש לנו סט של תכונות שזהות לכל האנשים. בחלק זה אנחנו ניצור את ה-class המיוחד של <code>Teacher</code>, ונגרום לו לירוש מ-<code>Person</code> באמצעות שימוש בסינטקס class החדש. זה נקרא יצירת subclass או ביצוע subclassing.</p>
-
-<p>על מנת ליצור subclass אנחנו יכולים להשתמש במילה השמורה <a href="/en-US/docs/Web/JavaScript/Reference/Classes/extends">extends</a> על מנת להגיד ל-JavaScript איזו class אנחנו מתבססים עליה ביצירת ה-class החדשה:</p>
-
-<pre class="brush: js">class Teacher extends Person {
- constructor(subject, grade) {
- this.subject = subject;
-  this.grade = grade;
- }
-}</pre>
-
-<p>אך יש קאצ׳ קטן:</p>
-
-<p>שלא כמו ה-Constructor function, שבהן האופרטור <a href="/en-US/docs/Web/JavaScript/Reference/Operators/new"><code>new</code> operator</a> היה עושה את האתחול של המילה <code>this</code> לאובייקט חדש, פה זה לא קורה בצורה אוטומטית בעבור המחלקה שמוגדרת באמצעות המילה <a href="/en-US/docs/Web/JavaScript/Reference/Classes/extends">extends</a>, כלומר עבור ה-sub-classes.</p>
-
-<p>ולכן הרצה שלהקוד למעלה יציג לנו שגיאה:</p>
-
-<pre class="brush: js">Uncaught ReferenceError: Must call super constructor in derived class before
-accessing 'this' or returning from derived constructor</pre>
-
-<p>למחלקות משנה, sub-classes, ההגדרה של <code>this</code> בעבור אובייקט חדש, תהיה תמיד תלויה ב-parent class constructor, כלומר ב-constructor function של ה-class שממנה אנחנו מתרחבים (extending).</p>
-
-<p>כאן, אנחנו מרחיבים את המחלקה <code>Person</code>- המחלקת משנה בשם -<code>Teacher</code> היא בעצם extension - הרחבה - של המחלקה <code>Person</code>. אז עבור <code>Teacher</code> האתחול של <code>this</code> מתבצע על ידי ה-constructor <code>Person</code>.</p>
-
-<p>על מנת לקרוא ל-constructor ה-parent, אנחנו צריכים להשתמשש באופרטור <a href="/en-US/docs/Web/JavaScript/Reference/Operators/super"><code>()super</code> </a>, כך:</p>
-
-<pre class="brush: js">class Teacher extends Person {
- constructor(subject, grade) {
-  super(); // Now `this` is initialized by calling the parent constructor.
-  this.subject = subject;
-  this.grade = grade;
-  }
-}</pre>
-
-<p>אין שום סיבה שתהיה לנו sub-class אם היא לא יורשת מאפיינים מה-parent class.<br>
- זה רעיון טוב אז שהאופרטור <a href="/en-US/docs/Web/JavaScript/Reference/Operators/super"><code>()super</code></a>  גם מקבל ארגומנטים בעבור ה- parent constructor.</p>
-
-<p>כאשר אנחנו מסתכלים על ה- <code>Person</code> constructor,  אנחנו יכולים לראות שיש לו את הבלוק קוד הבא בתוך ה-constructor שלו:</p>
-
-<pre class="brush: js"> constructor(first, last, age, gender, interests) {
- this.name = {
-  first,
-  last
-  };
-  this.age = age;
-  this.gender = gender;
-  this.interests = interests;
-} </pre>
-
-<p>מאחר והאופרטור <code><a href="/en-US/docs/Web/JavaScript/Reference/Operators/super">()super</a></code> הוא בעצם ה-parent class constructor, העברה של הארגומנטים הרלוונטיים של המחלקת אם, גם תאתחל את הפרופ׳ במחלקת משנה שלנו, ותירש אותם: </p>
-
-<pre class="brush: js">class Teacher extends Person {
-  constructor(first, last, age, gender, interests, subject, grade) {
- super(first, last, age, gender, interests);
-
-  // subject and grade are specific to Teacher
-  this.subject = subject;
-  this.grade = grade;
- }
-}
-</pre>
-
-<p>כעת, כשיוצרים מופעי אובייקט של <code>Teacher</code>, אנחנו יכולים לקרוא למתודות ופרופ׳ שהוגדרו גם ב-<code>Teacher</code> וגם ב-<code>Person</code>:</p>
-
-<pre class="brush: js">let snape = new Teacher('Severus', 'Snape', 58, 'male', ['Potions'], 'Dark arts', 5);
-snape.greeting(); // Hi! I'm Severus.
-snape.farewell(); // Severus has left the building. Bye for now.
-snape.age // 58
-snape.subject; // Dark arts
-</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אתם יכולים למצוא את הדוגמא ב-GitHub ב- <a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/advanced/es2015-class-inheritance.html">es2015-class-inheritance.html</a>  או כ-<a href="https://mdn.github.io/learning-area/javascript/oojs/advanced/es2015-class-inheritance.html">דף אינטרנט</a>.</p>
-</div>
-
-<h2 id="Getters_ו-_Setters">Getters ו- Setters</h2>
-
-<p>יהיו פעמים שאנחנו נרצה לשנות את הערכים של מאפיין בתוך השאנחנו יוצרים או שאנחנו לא נדע מהו הערך הסופי שאותו מאפיין יקבל. אם נסתכל על הדוגמא שלנו <code>Teacher</code>, יכול להיות מצב שאנחנו לא נדע מה הנושא שהמורה מלמד לפני שאנחנו יוצרים אותו או שהנושא יכול להשתנות במהלך התקופה.</p>
-
-<p>במקרים כאלו אנחנו נוכל להשתמש ב-getters ו-setters.</p>
-
-<p>נשפר את Teacher class עם  getters ו-setters. המחלקה מתחילה בדיוק כמו שראינו אותה בדוגמא האחרונה.</p>
-
-<p> getters ו-setters עובדים בזוגות. getter מחזיר את הערך הנוכחי של משתנה וה-setter הבן זוג שלו משנה את הערך של המשתנה למה שה-setter יגדיר. </p>
-
-<p>המחלקה <code>Teacher</code> החדשה תיראה כך:</p>
-
-<pre class="brush: js">class Teacher extends Person {
- constructor(first, last, age, gender, interests, subject, grade) {
- super(first, last, age, gender, interests);
- // subject and grade are specific to Teacher
- this._subject = subject;
-  this.grade = grade;
- }
-
- get subject() {
- return this._subject;
-  }
-
- set subject(newSubject) {
-  this._subject = newSubject;
- }
-}
-</pre>
-
-<p>במחלקה למעלה יש לנו getter ו-setter בעבור הפרופ׳ <code>subject</code>. אנחנו משתמשים בסימן <code>_</code> על מנת ליצור ערך נפרד שבו נאחסכן את השם של הפרופ׳. אם לא נעשה זאת בצורה הזה, אנחנו נקבל שגיאות בכל פעם שנקרא ל-get או ל-set. בנקודה זו: </p>
-
-<ul>
- <li>על מנת לקבל את הערך הנוכחי של הפרופ׳ <code>_subject</code> של האובייקט <code>snape</code>, אנחנו יכולים להשתמש במתודת <code>snape.subject</code> getter.</li>
- <li>על מנת להשים ערך חדש לפרופ׳ <code>_subject</code> אנחנו יכולים להשתמש במתודת <code>snape.subject="new value"</code> setter. </li>
-</ul>
-
-<p>הדוגמא למטה מראה את השימוש באפשרויות האלו: </p>
-
-<pre class="brush: js">// Check the default value
-console.log(snape.subject) // Returns "Dark arts"
-
-// Change the value
-snape.subject="Balloon animals" // Sets _subject to "Balloon animals"
-
-// Check it again and see if it matches the new value
-console.log(snape.subject) // Returns "Balloon animals"
-</pre>
-
-<div class="note">
-<p><strong>לתשומת לב </strong>: תוכלו למצוא את <a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/advanced/es2015-getters-setters.html">es2015-getters-setters.html</a> ב-GitHub, או כ<a href="https://mdn.github.io/learning-area/javascript/oojs/advanced/es2015-getters-setters.html">דף אינטרנט</a>.</p>
-</div>
-
-<h2 id="מתי_אנחנו_נשתמש_בהורשה_ב-JavaScript">מתי אנחנו נשתמש בהורשה ב-JavaScript?</h2>
-
-<p>רוב הסיכויים שלאחר קריאת המאמר הזה, אתם בטח חושבים לעצמכם ״טוב, זה מסובך מאוד״. אתם צודקים. הורשה ואבי טיפוס הינם חלק מההיבטים המורכבים ביותר של JavaScript, אבל הרבה מעוצמתה של השפה והגמישות שלה מגיע מתוך המבנה של האובייקטים והירושה שלהם, וזה שווה להכיר ולהבין כיצד התהליכים הללו מתרחשים. </p>
-
-<p>בדרך מסויימת, אנחנו משתמשים בהורשה כל הזמן. בכל פעם שאנחנו משתמשים במאפיינים שונים של Web API או בפרופ׳/מתודות שהוגדרו באובייקט מובנה של הדפדפן (built-in browser object) על מחרוזות, מערכים וכד׳ אנחנו באופן עקיף משתמשים בירושה. </p>
-
-<p>במונחים של שימוש בירושה בקוד שלנו, אנחנו ככל הנראה לא נשתמש בזה באופן תדיר, במיוחד בהתחלה ובפרוייקטים קטנים. זה בזבוז זמן להשתמש באובייקטים וירושה רק לשם השימוש בהם אם אנחנו לא צריכים. אבל ככל שכמות הקוד גדלה, אנחנו ככל הנראה נזהה את הצורך להתחיל להשתמש בכך. םא אנחנו מוצאים את עצמנו מתחילים ליצור מספר אובייקטים שיש להם מאפיינים זהים, אז יצירת אובייקט גנרי אחד אשר יכיל את כל הפונקציונליות המשותפת של אותם אובייקטים ויוריש להם את אותה פונקציונליות תהיה דרך מאוד שימושית ונוחה.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: לאור הדרך שבה JavaScript עובדת עם שרשרת אבי הטיפוס (prototype chain) וכד׳ - השיתוף של פונקציונליות בין אובייקטים נקרא לרוב <strong>delegation - ״האצלה״</strong>. אובייקטים מיוחדים ״מאצילים״ פונקציונליות לאובייקטים שנוצרים.  </p>
-</div>
-
-<p>כאשר אנחנו משתמשים בהורשה, ההמלצה היא שלא יהיו יותר מדי רמות של הורשה, ושתמיד נעקוב איפה אנחנו מגדירים את המתודות והפרופ׳. זה אפשרי להתחיל לכתוב קוד שבאופן זמני משנה את ה-prototypes של האובייקטים המובנים של הדפדפן (built-in browser objects), אבל אין לעשות זאת אלא אם כן יש לנו סיבה מאוד טובה. יותר מדי הורשה יכולה להוביל לבלבול אינסופי ולשגיאות בקוד. </p>
-
-<p>באופן אולטמטיבי, אובייקטים הם פשוט תבנית אחרת של שימוש חוזר בקוד, כמו פונקציות ולולאות, עם הכללים והיתרונות שלהם. אם אתם מוצאים את עצמכם יוצרים משתנים ופונקציות הקשורים אחד לשני ואתם רוצים לעקוב ולארוז אותם יחד בצורה מסודרת, אובייקט הוא רעיון טוב. אובייקטים גם שימושיים מאוד כשאנחנו רוצים להעביר ריכוז של מידע ממקום אחד למקום שני. את שני הדברים הללו ניתן להשיג ללא שימוש ב-constructors או ב-inheritance. אם אנחנו צריכים רק מופע אחד של אובייקט, כנראה יהיה עדיף פשוט להשתמש ב-inheritance ואין צורך בירושה.</p>
-
-<h2 id="אלטרנטיבות_להרחבה_של_שרשרת_ההורשה">אלטרנטיבות להרחבה של שרשרת ההורשה </h2>
-
-<p>ב-JavaScript, יש מספר דרכים שונות להרחבה של ה-prototype של אובייקט חוץ מאלו שראינו במאמר זה. להרחבה בנושא, ראו את הדף שלנו בנושא <a href="/en-US/docs/Web/JavaScript/Inheritance_and_the_prototype_chain#Different_ways_to_create_objects_and_the_resulting_prototype_chain">Inheritance and the prototype chain</a>.</p>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>מאמר זה נועד לסקור את יתרת הנושא של OOJS וסינטקס נוסף שאנחנו חושבים שאתם צריכים לדעת. בנקודה זו אתם אמורים להבין את ההיבטים של אובייקטים ב-JavaScript ואת הבסיס של תכנות מונחה עצמים (OOP), אביט טיפוס, שרשרת אבי-טיפוס, הורשה באמצעות אבי-טיפוס, כיצד ליצור מחלקות (classes), מופעי אובייקטים, הוספת מאפיינים למחלקות, יצירת מחלקות משנה שיורשות ממחלקות אחרות ועוד. </p>
-
-<p>במאמר הבא אנחנו נגע כיצד לעבוד עם (JavaScript Object Notation (JSON, פורמט מקובל להעברת מידע.</p>
-
-<h2 id="ראו_גם">ראו גם</h2>
-
-<ul>
- <li><a href="http://www.objectplayground.com/">ObjectPlayground.com</a> — אתר ללמידה אינטראקטיבית של בנושא אובייקטים.</li>
- <li><a href="https://www.manning.com/books/secrets-of-the-javascript-ninja-second-edition">Secrets of the JavaScript Ninja</a>, פרק 7 - ספר טוב בנושא עקרונות מתקדמים של JavaScript של John Resig, Bear Bibeault, ו-Josip Maras. פרק 7 מכסה את ההיבטים של אבי טיפוס והורשה. </li>
-</ul>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/Objects/Object_prototypes", "Learn/JavaScript/Objects/JSON", "Learn/JavaScript/Objects")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Basics">אובייקטים - עקרונות יסוד</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Object-oriented_JS">Object-oriented JavaScript למתחילים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Object_prototypes">Object prototypes</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Inheritance">הורשה ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/JSON">עבודה עם JSON data</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Object_building_practice">שיטות ליצירת אובייקטים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Adding_bouncing_balls_features">Adding features to our bouncing balls demo</a></li>
- <li></li>
-</ul>
diff --git a/files/he/learn/javascript/objects/json/index.html b/files/he/learn/javascript/objects/json/index.html
deleted file mode 100644
index 5f61b5aa22..0000000000
--- a/files/he/learn/javascript/objects/json/index.html
+++ /dev/null
@@ -1,346 +0,0 @@
----
-title: Working with JSON
-slug: Learn/JavaScript/Objects/JSON
-translation_of: Learn/JavaScript/Objects/JSON
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/Objects/Inheritance", "Learn/JavaScript/Objects/Object_building_practice", "Learn/JavaScript/Objects")}}</div>
-
-<p class="summary">JavaScript Object Notation (JSON) הוא סטדנרט לפורמט מבוסס-טקסט, המבוסס על הסינטקס של אובייקט ב-ה. הוא לרוב משמש בעבור העברת מידע ביישומי רשת (כלומר העברת מידע משרת לקוח, כך שהמידע יוכל להיות מוצג על גבי דף אינטרנט, או ההפך). אנחנו ניתקל בו לעיתים קרובות מאוד ומאמר זה נועד להעניק לכם כל מה שצריך לדעת על עבודה עם JSON כשאנחנו משתמשים ב-JavaScript, כולל עיבוד שלו כך שאנחנו נוכל לגשת למידע המאוחסן בו וכן ליצור JSON.</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>Basic computer literacy, a basic understanding of HTML and CSS, familiarity with JavaScript basics (see <a href="/en-US/docs/Learn/JavaScript/First_steps">First steps</a> and <a href="/en-US/docs/Learn/JavaScript/Building_blocks">Building blocks</a>) and OOJS basics (see <a href="/en-US/docs/Learn/JavaScript/Object-oriented/Introduction">Introduction to objects</a>).</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>להבין כיצד לעבוד עם מידע המאוחסן בתוך JSON וכיצד ליצור אובייקטי JSON בעצמנו.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="מה_זה_JSON">מה זה JSON?</h2>
-
-<p>{{glossary("JSON")}} הוא פורמט מידע מבוסס-טקסט אשר דומה לסינטקס של אובייקט ב-JavaScript. פורמט זה הוצג על ידי <a href="https://en.wikipedia.org/wiki/Douglas_Crockford">Douglas Crockford</a>. למרות שהוא מאוד דומה ומזכיר סינטקס של object literal ב-JavaScript, ניתן להשתמש בו באופן עצמאי ולא רק ב-JavaScript, וסביבות פיתוח אחרות מכילות אפשרויות לקרוא או לעבד וכן ליצור JSON. </p>
-
-<p>JSON מתקיים כמחרוזת - שימושי מאוד כשאנחנו רוצים להעביר מידע ברשת. הוא צריך להיות מומר לאובייקט JavaScript כאשר אנחנו רוצים לגשת לאותו מידע שמאוחסן בתוך ה-JSON. זה לא מורכב או מסובך - JavaScript מעניקה לנו את האובייקט <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON">JSON</a> הגלובלי שיש לו מתודות שזמינות עבורו בעבור המרה בין JSON למחרוזת.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: המרה של מחרוזת לאובייקט נקראת <em>parsing</em> ואילו המרה של אובייקט למחרזות כך שהוא יוכל להיות מועבר ברשת, נקראת <em>stringification</em>.</p>
-</div>
-
-<p>אובייקט JSON יכול להיות מאוחסן בתוך קובץ נפרד משלו, שהוא בעצם קובץ טקסט עם סיימות של <code>.json</code> ו-{{glossary("MIME type")}} של <code>application/json</code>.</p>
-
-<h3 id="המבנה_של_JSON">המבנה של JSON</h3>
-
-<p>כפי שציינו למעלה, JSON הוא מחרוזת, שהמבנה שלה מזכיר מאוד object literal ב-JavaScript. אנחנו יכולים לכלול את אותם סוגי מידע בסיסיים בתוך JSON כפי אנחנו יכולים לכלול אותם בתוך אובייקט של JavaScript - מחרוזות, מספרים, מערכים, בוליאנים ואובייקטים אחרים. זה מאפשר לנו ליצור היררכיית מידע כמו זו לדוגמא:</p>
-
-<pre class="brush: json">{
-  "squadName": "Super hero squad",
-  "homeTown": "Metro City",
-  "formed": 2016,
-  "secretBase": "Super tower",
- "active": true,
-  "members": [
-    {
-      "name": "Molecule Man",
-      "age": 29,
-      "secretIdentity": "Dan Jukes",
-      "powers": [
-        "Radiation resistance",
-        "Turning tiny",
-        "Radiation blast"
-      ]
-    },
-    {
-      "name": "Madame Uppercut",
-      "age": 39,
-      "secretIdentity": "Jane Wilson",
-      "powers": [
-        "Million tonne punch",
-        "Damage resistance",
-        "Superhuman reflexes"
-      ]
-    },
-    {
-      "name": "Eternal Flame",
-      "age": 1000000,
-      "secretIdentity": "Unknown",
-      "powers": [
-        "Immortality",
-        "Heat Immunity",
-        "Inferno",
-        "Teleportation",
-        "Interdimensional travel"
-      ]
-    }
-  ]
-}</pre>
-
-<p>אם אנחנו נטען את האובייקט הזה לתוך תוכנית JavaScript ונמיר אותו (parse) בתוך משתנה בשם <code>superHeroes</code> לדוגמא, אנחנו אז נוכל לגשת לאותו מידע המאוחסן בו באמצעות שימוש ב-00000 שאנחנו מכירים מהמאמר בנושא <a href="/he/docs/Learn/JavaScript/Objects/Basics">אובייקטים - עקרונות יסוד</a>. לדוגמא: </p>
-
-<pre class="brush: js">superHeroes.homeTown
-superHeroes['active']</pre>
-
-<p>על מנת לגשת למידע בהמשך ההיררכיה, אנחנו פשוט נצטרך ״לקשור״ את שם הפרופ׳ המבוקש והאינדקס הרלוונטי במערך ביחד. לדוגמא, על מנת לגשת ל-9999 השלישי של ה-0000 השני ברשימת ה-9999, נוכל לרשום קוד כזה:</p>
-
-<pre class="brush: js">superHeroes['members'][1]['powers'][2]</pre>
-
-<ol>
- <li>ראשית יש לנו את שם המשתנה  — <code>superHeroes</code>.</li>
- <li>בתוך המשתנה אנחנו רוצים לגשת לפרופ׳ <code>members</code>, אז אנחנו משתמשים ב- <code>["members"]</code>. </li>
- <li><code>members</code> מכיל מערך של אובייקטים. אנחנו רוצים לגשת לאובייקט השני בתוך המערך אז אנחנו נשתמש באינדקס <code>[1]</code>. </li>
- <li>בתוך האובייקט, אנחנו רוצים לגשת לפרופ׳ <code>powers</code>, אז אנחנו נשתמש ב-<code>["powers"]</code>. </li>
- <li>ובתוך הפרופ׳ <code>powers</code>, אנחנו נרצה את הערך השלישי, אז אנחנו נשתמש ב-<code>[2]</code>. </li>
-</ol>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: יצרנו את ה-JSON שבדוגמא למעלה בקובץ <a href="http://mdn.github.io/learning-area/javascript/oojs/json/JSONTest.html">JSONTest.html</a> וניתן לראותו גם ב-<a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/json/JSONTest.html">קוד המקור</a>. </p>
-
-<p>מנסו להעלות את הקובץ ולגשת למידע בתוך המשתנה באמצעות הקונסולה בדפדפן. </p>
-</div>
-
-<h3 id="מערכים_כ-JSON">מערכים כ-JSON</h3>
-
-<p>למעלה ציינו שטקסט ב-JSON דומה בעקרון לאובייקט ב-JavaScript, וזה דיי נכון. הסיבה שאנחנו אומרים ״דומה״ ולא ״זהה״, מכיוון שמערך ב-JavaScript הוא בעצם JSON תקין:</p>
-
-<pre class="brush: json">[
- {
- "name": "Molecule Man",
- "age": 29,
- "secretIdentity": "Dan Jukes",
- "powers": [
- "Radiation resistance",
- "Turning tiny",
- "Radiation blast"
- ]
- },
- {
-    "name": "Madame Uppercut",
-    "age": 39,
-    "secretIdentity": "Jane Wilson",
-    "powers": [
-      "Million tonne punch",
-      "Damage resistance",
-      "Superhuman reflexes"
-    ]
-  }
-]</pre>
-
-<p>הטקסט למעלה הוא JSON תקין לחלוטין. אנחנו פשוט נצטרך לגשת לאיברים במערך (בגרסה המעובדת שלו), באמצעות אינדקס של מערך/</p>
-
-<h3 id="הערות_נוספות">הערות נוספות</h3>
-
-<ul>
- <li>JSON הוא פשוט פורמט מידע — הוא מכיל רק פרופ׳ ולא מתודות. </li>
- <li>JSON דורש גרשיים כפולות - <code>״ ״</code> - סביב מחרוזות ושמות של פרופ׳. גרשיים בודדות - <code>׳ ׳</code> - אינן תקינות. </li>
- <li>אפילו טעות כתיב קטנה כמו פסיק או נקודותיים לא במקום יכולה לגרום לקובץ JSON לשגיאה. צריך לשים לב ולעשות ולידציה לכל מידע שאנחנו נרצה להשתמש בו, למרות שהסיכויים שקובץ JSON שנוצר על ידי מחשב יכיל שגיאות הוא נמוך, אם התוכנה שיצרה אותו עובדת כמו שצריך. אנחנו יכולים לעשות ולידציה לקבצי JSON באמצעות יישומים כמו <a href="http://jsonlint.com/">JSONLint</a>. </li>
- <li>JSON גם יכול לקחת תבנית של כל סוג מידע שאפשר לכלול אותו ב-JSON, לא רק מערכים או אובייקטים. לדוגמא, מחרוזת בודדת או מספר הם אובייקטי JSON תקינים לחלוטין. </li>
- <li>שלא כמו בקוד JavaScript שבו פרופ׳ של אובייקטים אינם מחוייבים בגרשיים, ב-JSON, הפרופ׳ מחוייבים בגרשיים (וכפי שציינו למעלה, רק גרשיים כפולות).</li>
-</ul>
-
-<h2 id="למידה_עצמאית_עבודה_עם_JSON">למידה עצמאית: עבודה עם JSON</h2>
-
-<p>כעת נלמד באמצעות דוגמא כיצד ניתן לעשות שימוש במידע JSON באתר אינטרנט.</p>
-
-<h3 id="התחלה">התחלה</h3>
-
-<p>על מנת להתחיל, עשו עותקים מקודמיים של <a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/json/heroes.html">heroes.html</a> ושל <a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/json/style.css">style.css</a> . הקובץ האחרון מכיל CSS פשוט לעיצוב הדף שלנו והראשון מכיל גוף HTML פשוט:</p>
-
-<pre class="brush: html">&lt;header&gt;
-&lt;/header&gt;
-
-&lt;section&gt;
-&lt;/section&gt;</pre>
-
-<p>בנוסף, הקובץ הראשון מכיל אלמנט {{HTMLElement("script")}} פשוט שיכיל את קוד ה-JavaScript שנכתוב בתרגיל זה. כעת, קובץ זה מכיל שתי שורות, אשר מכילות הפניה לאלמנט {{HTMLElement("header")}} ולאלמנט {{HTMLElement("section")}} ומאחסן הפניות אלו בתוך משתנים:</p>
-
-<pre class="brush: js">var header = document.querySelector('header');
-var section = document.querySelector('section');</pre>
-
-<p>מידע ה-JSON זמין ב-GitHub בכתובת: <a href="https://mdn.github.io/learning-area/javascript/oojs/json/superheroes.json">https://mdn.github.io/learning-area/javascript/oojs/json/superheroes.json</a>.</p>
-
-<p>בתרגיל אנחנו נעלה את המידע לתוך הדף שלנו, באמצעות שימוש במניפולציות על ה-DOM, כך שהדף שלנו ייראה כך:</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/13857/json-superheroes.png" style="display: block; margin: 0 auto;"></p>
-
-<h3 id="קבלת_ה-JSON">קבלת ה-JSON</h3>
-
-<p>על מנת להשיג את ה-JSON, אנחנו נשתמש ב-API שנקרא {{domxref("XMLHttpRequest")}} (לרוב נקרא <strong>XHR</strong>). זהו אובייקט JavaScript שימושי מאוד, אשר מאפשר לנו לבצע בקשות רשת על מנת לקבל משאבים מהשרת באמצעות JavaScript (כמו תמונות, טקסט, JSON, ואפילו קוד HTML), כלומר, אנחנו יכולים לעדכן חלקים מתוך התוכן שלנו, מבלי לטעון מחדש את הדף כולו. אפשרות זו איפשה לדפי אינטרנט להיות הרבה יותר רספונסיביים. אנחנו נלמד בהרחבה על נושא זה בהמשך. </p>
-
-<ol>
- <li>על מנת להתחיל, אנחנו הולכים לאחסן את ה-URL של ה-JSON שאנחנו נרצה לקבל בתוך משתנה. הוסיפו את הקוד הבא בתחתית הקוד של JavaScript שברשותכם:</li>
- <li>
- <pre class="brush: js">var requestURL = 'https://mdn.github.io/learning-area/javascript/oojs/json/superheroes.json';</pre>
- </li>
- <li>על מנת ליצור בקשה, אנחנו צריכים ליצור אובייקט בקשה חדשה מה-constructor בשם <code>XMLHttpRequest</code>, באמצעות שימוש במילה השמורה <code>new</code>. הוסיפות את הקוד הבא מתחת לשורה האחרונה:
- <pre class="brush: js">var request = new XMLHttpRequest();</pre>
- </li>
- <li>כעת, אנחנו צריכים לפתוח בקשה חדשה לאובייקט בקשה שיצרנו באמצעות המתודה <code><a href="/en-US/docs/Web/API/XMLHttpRequest/open">()open</a></code>. הוסיפו את הקוד הבא:
- <pre class="brush: js">request.open('GET', requestURL);</pre>
-
- <p>מתודה זו מקבל לפחות שני פרמטרים - וניתן להזין עוד פרמטרים אופציונליים. הפרמטרים שאנחנו חייבים לציין בעבור הדוגמא הזו הם:</p>
-
- <ul>
- <li>סוג המתודה של HTTP שאנחנו נרצה לבצע בבקשת השרת - במקרה שלנו זו תהיה <code><a href="/en-US/docs/Web/HTTP/Methods/GET">GET</a></code>, שכן אנחנו רוצים לקבל מידע כלשהו. </li>
- <li>ה-URL שאנחנו נבצע אליו בקשה - זהו ה-URL שבו מאוחסן קובץ ה-JSON שלנו. </li>
- </ul>
- </li>
- <li>כעת, הוסיפו את השורות הבאות  - בשורות אלו אנחנו מגדירים את ה-<code><a href="/en-US/docs/Web/API/XMLHttpRequest/responseType">responseType</a></code> ל-JSON, כך שה-XHR יודע שהשרת יחזיר לנו JSON, ושמאחורי הקלעים תבוצע לו המרה לאובייקט JavaScript. בשורה השנייה אנחנו שולחים את הבקשה באמצעות מתודת <code><a href="/en-US/docs/Web/API/XMLHttpRequest/send">()send</a></code>:
- <pre class="brush: js">request.responseType = 'json';
-request.send();</pre>
- </li>
- <li>החלק האחרון של הקוד הרשום להלן הוא בעצם המתנה לקבלת תגובה מהשרת, וביצוע פעולה איתה. הוסיפו את הקוד הבא מתחת לקוד הנוכחי שלכם:
- <pre class="brush: js">request.onload = function() {
- var superHeroes = request.response;
- populateHeader(superHeroes);
- showHeroes(superHeroes);
-}</pre>
- </li>
-</ol>
-
-<p>כאן אנחנו מאחסנים את התגובה לבקשה לשלנו (הזמינה בפרופ׳ <code><a href="/en-US/docs/Web/API/XMLHttpRequest/response">response</a></code> ) בתוך משתנה שנקרא <code>superHeroes</code>. המשתנה עכשיו מכיל את האובייקט JavaScript שמבוסס על ה-JSON. לאחר מכן אנחנו מעבירים את אותו אובייקט כארגומנט לשתי קריאות פונקציות - הראשונה תמלא את ה-&lt;<code>header&gt;</code> עם המידע הנכון, ואילו השניה תיצור לנו כרטיס מידע בעבור כל ״גיבור״ בקבוצה ותכניס את הכרטיס הזה לתוך &lt;<code>section&gt;</code>. </p>
-
-<p>עטפנו את הקוד הזה בתוך מטפל אירוע - event handler - שירוץ ברגע שהאירוע load נוצר על האובייקט <code>request</code> (ראו <code><a href="/en-US/docs/Web/API/XMLHttpRequestEventTarget/onload">onload</a></code>) - זה מכיוון שהאירוע load נוצר כאשר התגובה מהשרת הוחזרה בהצלחה. ביצוע של דבר זה מבטיח לנו שה-<code>request.response</code> יהיה זמין בוודאות כשנרצה לעשות משהו איתו.</p>
-
-<h3 id="מילוי_של_מידע_ב-header">מילוי של מידע ב-header</h3>
-
-<p>כעת, כשהשגנו את המידע ב-JSON והמרנו אותו לאובייקט JavaScript, אנחנו יכולים לעשות בו שימוש באמצעות כתיבה של הפונקציות שציינו למעלה. ראשית, הוסיפו את הפונקציות הרשומות מטה מתחת לקוד הנוכחי שלכם: </p>
-
-<pre class="brush: js">function populateHeader(jsonObj) {
- var myH1 = document.createElement('h1');
- myH1.textContent = jsonObj['squadName'];
- header.appendChild(myH1);
-
- var myPara = document.createElement('p');
- myPara.textContent = 'Hometown: ' + jsonObj['homeTown'] + ' // Formed: ' + jsonObj['formed'];
- header.appendChild(myPara);
-}</pre>
-
-<p>אנחנו קראנו לפרמטר בשם <code>jsonObj</code>, על מנת להזכיר לעצמנו שזהו בעצם אובייקט JavaScript שמקורו ב-JSON. ראשית, יצרנו אלמנט {{HTMLElement("h1")}} עם <code><a href="/en-US/docs/Web/API/Document/createElement">()createElement</a></code>, והשמנו את ה-<code><a href="/en-US/docs/Web/API/Node/textContent">textContent</a></code> שיהיה שווה לפרופ׳ <code>squadName</code> של האובייקט, ולאחר מכן שייכנו אותו ל-header באמצעות <code><a href="/en-US/docs/Web/API/Node/appendChild">()appendChild</a></code>. </p>
-
-<p>לאחר מכן עשינו פעולה דומה בעבור הפסקה - <code>p</code>: יצרנו אותה, השמנו את ה-<code><a href="/en-US/docs/Web/API/Node/textContent">textContent</a></code> שלה ולאחר מכן הוספנו אותה ל-header. ההבדל היחיד הוא שהטקסט שלה הוא שרשור של מחרוזות המכילות את הפרופ׳ <code>homeTown</code> ו-<code>formed</code> של האובייקט <code>jsonObj</code>.</p>
-
-<h3 id="יצירה_של_כרטיסי_המידע_״hero״">יצירה של כרטיסי המידע ״hero״</h3>
-
-<p>כעת, הוסיפו את הפונקציה הבאה מתחת לקוד הנוכחי, אשריוצרץ ומצגיה את כרטיסי המידע של ה-hero: </p>
-
-<pre class="brush: js">function showHeroes(jsonObj) {
- var heroes = jsonObj['members'];
-
- for (var i = 0; i &lt; heroes.length; i++) {
- var myArticle = document.createElement('article');
- var myH2 = document.createElement('h2');
- var myPara1 = document.createElement('p');
- var myPara2 = document.createElement('p');
- var myPara3 = document.createElement('p');
- var myList = document.createElement('ul');
-
- myH2.textContent = heroes[i].name;
- myPara1.textContent = 'Secret identity: ' + heroes[i].secretIdentity;
- myPara2.textContent = 'Age: ' + heroes[i].age;
- myPara3.textContent = 'Superpowers:';
-
- var superPowers = heroes[i].powers;
- for (var j = 0; j &lt; superPowers.length; j++) {
- var listItem = document.createElement('li');
- listItem.textContent = superPowers[j];
- myList.appendChild(listItem);
- }
-
- myArticle.appendChild(myH2);
- myArticle.appendChild(myPara1);
- myArticle.appendChild(myPara2);
- myArticle.appendChild(myPara3);
- myArticle.appendChild(myList);
-
- section.appendChild(myArticle);
- }
-}</pre>
-
-<p>לשם התחלה, אחסנו את הפרופ׳ <code>members</code> של אובייקט ה-JavaScript בתוך משתנה חדש. מערך זה מכיל מספר אובייקטים שמכילים את המידע בעבור כל hero. </p>
-
-<p>לאחר מכן, השתמשנו בלולאת <a href="/en-US/docs/Learn/JavaScript/Building_blocks/Looping_code#The_standard_for_loop">for</a> על מנת לעבור על כל אובייקט בתוך מערך זה. בעבור כל אובייקט במערך, עשינו את הדברים הבאים: </p>
-
-<ol>
- <li>יצרנו מספר אלמנטים חדשים: <code>&lt;article&gt;</code>, <code>&lt;h2&gt;</code>, שלוש <code>&lt;p&gt;</code>, ו-<code>&lt;ul&gt;</code>.</li>
- <li>קבענו ש-<code> &lt;h2&gt; </code>יכיל את הערך הנוכחי של ה-<code>name</code> של ה-hero.</li>
- <li>מילאנו את שלושת ה-p עם <code>secretIdentity</code>, <code>age</code> ושורה עם הטקסט "Superpowers:".</li>
- <li>אחסנו את הפרופ׳ <code>powers</code> בתוך משתנה חדש שנקרא <code>superPowers</code> - זה מכיל מערך שמציג את ה-superpowers הנוכחיים.</li>
- <li>השתמשנו בלולאת <code>for</code> שוב על מנת לעבור על כל ה-superpowers הנוכחיים של hero - בעבור כל אחד יצרנו אלמנט <code>&lt;li&gt;</code>, והכנסו את ה-superpower לתוכו ולאחר מכן שמנו את ה-<code>listItem</code> בתוך <code>&lt;ul&gt;</code> באמצעות <code>()appendChild</code>.</li>
- <li>לבסוף, שייכנו את <code>&lt;h2&gt;</code>, <code>&lt;p&gt;</code> ו-<code>&lt;ul&gt;</code> לתוך <code>&lt;article&gt;</code> (<code>myArticle</code>) ולאחר מכן שייכנו את <code>&lt;article&gt;</code> לתוך <code>&lt;section&gt;</code>. הסדר שבו דברים משוייכים הוא חשוב שכן כך הם יוצגו על גבי הדף.</li>
-</ol>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אם אתם נתקלים בבבעיה, ראו את הקוד המקור ב-<a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/json/heroes-finished.html">heroes-finished.html</a> או כ-<a href="http://mdn.github.io/learning-area/javascript/oojs/json/heroes-finished.html">דף אינטרנט</a>. </p>
-</div>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>:  אם אתם מתקשים בעניין ה-dot/bracket notation שאנו משתמשים כדי לגשת לאובייקט JavaScript, אולי יעזור לכם לפתוח את הקובץ <a href="http://mdn.github.io/learning-area/javascript/oojs/json/superheroes.json">superheroes.json</a> בלשונית אחרת או בעורך הקוד שלכם, ולהסתכל עליו תוך כדי מעבר על הקוד שלנו. בנוסף, שקלו לעשות חזרה על המאמר שלנו בנושא <a href="/he/docs/Learn/JavaScript/Objects/Basics">אובייקטים - עקרונות יסוד</a>.</p>
-</div>
-
-<h2 id="המרה_בין_אובייקטים_וטקסט">המרה בין אובייקטים וטקסט</h2>
-
-<p>הדוגמא למעלה הייתה יחסי פשוטה במונחים של לגשת לאובייקט JavaScript, מכיוון שקבענו שבקשת ה-XHR שלנו תמיר את התגובת JSON ישירות לאובייקט JavaScript באמצעות: </p>
-
-<pre class="brush: js">request.responseType = 'json';</pre>
-
-<p>לפעמים אנחנו נקבל מחרוזת JSON לא מעובדת, ואנחנו נצטרך להמיר אותה לאובייקט בעצמנו. וכאשר אנחנו נרצה לשלוח אובייקט JavaScript ברשת, אנחנו נצטרך להמיר אותו ל-JSON (מחרוזת) לפני השליחה שלו. למזלנו, שתי בעיות אלו כל כך נפוצות, שקיים אובייקט בשם <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON">JSON</a> הזמין בכל הדפדפנים, המכיל שתי מתודות: </p>
-
-<ul>
- <li><code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/parse">()parse</a></code>: מקבל מחרוזת JSON כפרמטר ומחזיר את אובייקט JavaScript בהתאם. </li>
- <li><code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON/stringify">()stringify</a></code>: מקבל אובייקט כפרמטר ומחזיר אותו כמחרוזת JSON בהתאם.</li>
-</ul>
-
-<p>אתם יכולים לראות את הראשון בפעולה בקובץ -<a href="http://mdn.github.io/learning-area/javascript/oojs/json/heroes-finished-json-parse.html">heroes-finished-json-parse.html</a> - הוא עושה בדיוק את אותו הדבר כמו בדוגמא שבנינו קודם, רק שאנחנו קבענו שה-XHR יחזיר טקסט JSON גולמ, ואז השתמשנו ב-<code>()parse</code> על מנת להמיר אותו לאובייקט JavaScript זה הקוד הרלוונטי:</p>
-
-<pre class="brush: js">request.open('GET', requestURL);
-request.responseType = 'text'; // now we're getting a string!
-request.send();
-
-request.onload = function() {
- var superHeroesText = request.response; // get the string from the response
- var superHeroes = JSON.parse(superHeroesText); // convert it to an object
- populateHeader(superHeroes);
- showHeroes(superHeroes);
-}</pre>
-
-<p>כפי שאתם יכולים לנחש, <code>()stringify</code> עובד בדרך ההפוכה. נסו להזין את השורות הבאות לקונסולה:</p>
-
-<pre class="brush: js">var myJSON = { "name": "Chris", "age": "38" };
-myJSON
-var myString = JSON.stringify(myJSON);
-myString</pre>
-
-<p>כאן יצרנו אובייקט JavaScript ואז המרנו אותו למחרוזת JSON באמצעות <code>()stringify</code> - ושמרנו את הערך שחזר במשתנה חדש. </p>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>במאמר זה, ניסינו להעניק לכם מדריך פשוט כיצד להשתמש ב-JSON בתוכנויות שלנו, כולל כיצד ליצור ולהמיר JSON, וכיצד לגשת למידע המאוחסן בתוכו. במאמר הבא אנחנו נסתכל על פרקטיקות ביצירת אובייקטים ב-JavaScript.</p>
-
-<h2 id="ראו_גם">ראו גם</h2>
-
-<ul>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON">JSON object reference page</a></li>
- <li><a href="/en-US/docs/Web/API/XMLHttpRequest">XMLHttpRequest object reference page</a></li>
- <li><a href="/en-US/docs/Web/API/XMLHttpRequest/Using_XMLHttpRequest">Using XMLHttpRequest</a></li>
- <li><a href="/en-US/docs/Web/HTTP/Methods">HTTP request methods</a></li>
- <li><a href="http://json.org">Official JSON web site with link to ECMA standard</a></li>
-</ul>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/Objects/Inheritance", "Learn/JavaScript/Objects/Object_building_practice", "Learn/JavaScript/Objects")}}</p>
-
-<h2 id="In_this_module">In this module</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Basics">אובייקטים - עקרונות יסוד</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Object-oriented_JS">Object-oriented JavaScript למתחילים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Object_prototypes">Object prototypes</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Inheritance">הורשה ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/JSON">עבודה עם JSON data</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Object_building_practice">שיטות ליצירת אובייקטים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Adding_bouncing_balls_features">Adding features to our bouncing balls demo</a></li>
-</ul>
diff --git a/files/he/learn/javascript/objects/object-oriented_js/index.html b/files/he/learn/javascript/objects/object-oriented_js/index.html
deleted file mode 100644
index 63f83aa94d..0000000000
--- a/files/he/learn/javascript/objects/object-oriented_js/index.html
+++ /dev/null
@@ -1,275 +0,0 @@
----
-title: Object-oriented JavaScript for beginners
-slug: Learn/JavaScript/Objects/Object-oriented_JS
-translation_of: Learn/JavaScript/Objects/Object-oriented_JS
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/Objects/Basics", "Learn/JavaScript/Objects/Object_prototypes", "Learn/JavaScript/Objects")}}</div>
-
-<p class="summary">לאחר שסיימנו עם עקרונות היסוד, כעת אנחנו נתמקד על- object-oriented JavaScript (OOJS) — מאמר זה נועד להעניק מבט בסיסי של תיאוריית object-oriented programming (OOP) ולאחר מכן נחקור כיצד JavaScript מחקה (מלשון חיקוי) מחלקות אובייקטים באמצעות פנקציה בנאית (constructor functions), וכיצד אנחנו יכולים ליצור ״מופעי״ אובייקטים</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>Basic computer literacy, a basic understanding of HTML and CSS, familiarity with JavaScript basics (see <a href="/en-US/docs/Learn/JavaScript/First_steps">First steps</a> and <a href="/en-US/docs/Learn/JavaScript/Building_blocks">Building blocks</a>) and OOJS basics (see <a href="/en-US/docs/Learn/JavaScript/Object-oriented/Introduction">Introduction to objects</a>).</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>להבין את בסיס התיאוריה שעומדת מאחורי תכנות מונחה עצמים, וכיצד זה מתקשר ל- JavaScript ("everything is an object"), ולהבין כיצד ליצור constructors ו- object instances.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Object-oriented_programming_—_הבסיס">Object-oriented programming — הבסיס</h2>
-
-<p>לשם ההצלחה, ננסה ללהעניק לכם נקודת מבט מופשטת, מלמעלה, של מה זה בעצם תכנות מונחה עצמים - Object-oriented programming (OOP). אנחנו אומרים מופשט מכיוון ש-0000 יכול להיות מורכב מאוד ופירוט של כל התיאוריה רוב הסיכויים תבלבל אתכם. הרעיון הבסיסי של OOP הוא שאנחנו משתמשים באובייקטים על מנת לדמות דברים אמיתיים מהעולם האמיתי שנרצה לכלול בתוך התוכנית שלנו, ו/או להעניק דרך פשוטה לגשת לפונקציונליות מסויימת, שבדרכים אחרות היה פשוט בלתי אפשרי או מסובך מאוד.</p>
-
-<p>אובייקטים יכולים להכיל מידע וקוד הקשורים זה לזה, אשר מייצדים מידע אודות הדבר שנאחנו מנסים לדמות, ופונקציונליות או התנהגות שאנחנו רוצים שיהיה לאובייקט שלנו. המידע של האובייקט, ולרוב גם הפונקציות שלו, יכולות להיות מאוחסות בצורה מסודרת - (המילה המקצועית היא <strong>encapsulated</strong> - בתוך האובייקט (וניתן לתת להם שמות שיהוו הפניה לאותם ערכים, ולפעמים זה נקרא <strong>namespace</strong>), וכך נהיה פשוט לבנות ולגשת אליהם. אובייקטים גם לרוב משמשים כמאחסני מידע שאנחנו יכולים לשלוח בקלות ברשת.</p>
-
-<h3 id="הגדרה_של_טמפלייט_של_אובייקט">הגדרה של טמפלייט של אובייקט</h3>
-
-<p>ננסה לחשוב על תוכנית פשוטה אשר מציגה מידע על תלמידים ועל מורים בבית ספר. אנחנו נסתכל על דוגמא זו ועל תיאוריית oop באופן כללי, מבלי להתייחס לשפת תכנות מסויימת.</p>
-
-<p>על מנת להתחיל, אנחנו נחזור לאובייקט Person מהמאמר הקוד <a href="/he/docs/Learn/JavaScript/Objects/Basics">אובייקטים - עקרונות יסוד</a>, אשר מגדיר את המידע והפונקציונליות הגנריות של בן אדם, של person. יש הרבה דברים שאנחנו יכולים לדעת על אדם (כתובת, גובה, מידת נעליים וכד׳), אבל במקרה שלנו אנחנו מעונינים להראות את השם, גיל, מין תחומי עניין שלהם, ואנחנו רוצים שתאפשר לנו לכתוב הקדמה קצרה עליהם, בהתבסס על המידע שיש לנו ולאפשר לאותו אובייקט להגיד שלום בצורה כלשהי. זה בעצם נקרה <strong>abstraction</strong> — יצירת מודל פשוט של משהו מורכב יותר אשר מייצג את האספקטיים החשובים ביותר בדרך כזו שניתן לעבוד איתה בתוכנית שלנו ולצרכי התוכנית שלנו.</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/13889/person-diagram.png" style="display: block; height: 219px; margin: 0px auto; width: 610px;"></p>
-
-<h3 id="יצירת_אובייקטים">יצירת אובייקטים</h3>
-
-<p>מהמחלקה שלנו אנחנו יכולים ליצור מופעי אובייקט - <strong>object instances</strong> — אלו בעצם אובייקטים המכילים את המידע והפונקציונליות שהוגדרו ב-מחלקה. מהמחלקה Person שלנו, אנחנו יכולים ליצור כמה אנשים בפועל:</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/15163/MDN-Graphics-instantiation-2-fixed.png" style="display: block; height: 702px; margin: 0px auto; width: 695px;"></p>
-
-<p>כאשר נוצר מופע אובייקט ממחלקה, ה- <strong>constructor function</strong> של אותה מחלקה מורץ על מנת ליצור את האובייקט החדש. תהליך זה של יצירת מופע אובייקט ממחלקה נקרא <strong>instantiation</strong> — ומופע האובייקט שנוצר, האובייקט שנוצר, אנו אומרים שהוא <strong>instantiated</strong> מהמחלקה</p>
-
-<h3 id="Specialist_classes">Specialist classes</h3>
-
-<p>במקרה שלנו אנחנו לא רוצים אנשים שנראים אותו דבר - אנחנו רוצים מורים וסטודנטים, אשר הם בעלי מאפיינים ספיצפיים של בני אדם. ב-OOP, אנחנו יכולים ליצור מחלקות חדשות בהתבסס על מחלקות קיימות - אלו נקראים - <strong>child classes</strong> והם יכולים לרשת, <strong>ירושה </strong> של מידע ומאפיינים של  <strong>קלאס האב</strong> שלהם, כך שאנחנו יכולים להשתמש בפונקציונליות שמשותפת לכל האובייקטים באמצעות אותה הורשה, מבלי שנצטרף לכתוב אותה מחדש בכל פעם. כאשר אנחנו צריכים להעניק תכונה או פונקציונליות פרטנית לאובייקט, אנחנו יכולים להגדיר אותם על אותו אובייקט באופן פרטני.</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/13881/MDN-Graphics-inherited-3.png" style="display: block; height: 743px; margin: 0px auto; width: 700px;"></p>
-
-<p>זהו מאוד שימושי - מורים וסטודנטים חולקים מאפיינים בסיסיים כמו שם, גיל, מין כך שזה יהיה נוח אם נוכל להגדיר את המאפיינים הללו פעם אחת בלבד. אנחנו גם יכולים להגדיר מאפיינים דומים באופן נפרד, במחלקות שונות, כך שכל מאפיין שכזה יהיה ב-namespace אחר. לדוגמא,הברה של סטודנט יכולה להיות שונה מהברכה של מורה. כך לדוגמא, הברכה של סטודנט תהיה "Yo, I'm [firstName]" (e.g <em>Yo, I'm Sam</em>), בעוד הברכה של מורה תהיה "Hello, my name is [Prefix] [lastName], and I teach [Subject]." (e.g <em>Hello, My name is Mr Griffiths, and I teach Chemistry</em>).</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: המילה הרשמית לאפשרות לשכפל אובייקטים ולהחיל עליהם את אותה פונקציונליות נקראת <strong>polymorphism</strong>. רק למקרה ותהיתם</p>
-</div>
-
-<p>אנחנו יכולים ליצור מופעי אובייקטים חדשים מה-child classes. לדוגמא:</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/13885/MDN-Graphics-instantiation-teacher-3.png" style="display: block; height: 743px; margin: 0px auto; width: 700px;"></p>
-
-<p>בהמשך המאמר, אנחנו נסתכל כיצד תיאורית oop באה לידי ביטוי ב-JavaScript.</p>
-
-<h2 id="Constructors_ו-_object_instances">Constructors ו- object instances</h2>
-
-<p>JavaScript  משתמש בפונקציות מיוחדות שנקראות <strong>constructor functions</strong> על מנת להגדיר ול initialize אובייקטים ואת המאפיינים שלהם. זה שימושי מאוד מכיוון שאנחנו ניתקל בסיטואציות שבהן אנחנו לא יודעים כמה אובייקטים אנחנו נרצה או נצטרף ליצור. constructors מאפשרים לנו ליצור אובייקטים כמה שנרצה בדרך אפקטיבית, וך צירוף המידע והפונקציות שלהם ככל שנרצה.</p>
-
-<p>נחקור כעת יצירה של מחלקות באמצעות constructors ויצירה של מופעי אובייקט מהם ב-JavaScript. ראשית, אנא צרו עותק של <a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/introduction/oojs.html">oojs.html</a></p>
-
-<h3 id="דוגמא_פשוטה">דוגמא פשוטה</h3>
-
-<ol>
- <li>נתחיל בכך שנסתכל כיצד אנחנו יכולים להגדיר person באמצעות פונקציה רגילה. הוסיפו את הפונקציה הזו לתוך אלמנט <code>script</code> :
-
- <pre class="brush: js notranslate">function createNewPerson(name) {
- var obj = {};
- obj.name = name;
- obj.greeting = function() {
- alert('Hi! I\'m ' + obj.name + '.');
- };
- return obj;
-}</pre>
- </li>
- <li>כעת אנחנו יכולים ליצור person חדש באמצעות קריאה לפונקציה זו - נסו להזין אתהקוד הבא בקונסולה:
- <pre class="brush: js notranslate">var salva = createNewPerson('Salva');
-salva.name;
-salva.greeting();</pre>
- זה עובד בצורה טובה, אבל קצת מפותלת. אם אנחנו יודעים שאנחנו רוצים ליצור אובייקט, מדוע אנחנו צריכים ליצור במפורש אובייקט ריק בהתחלה ולהחזיר אותו? למרבה המזל, javascript מעניקה לנו קיצור שימושי פונקציה בנאית- constructor functions - בואו ניצור אחת יחד:</li>
- <li>החליפו את הפונקציה הקודמת עם הפונקציה הנוכחית:
- <pre class="brush: js notranslate">function Person(name) {
- this.name = name;
- this.greeting = function() {
- alert('Hi! I\'m ' + this.name + '.');
- };
-}</pre>
- </li>
-</ol>
-
-<p>ה-constructor function היא הגרסה של javascript למחלקות. שימו לב שיש לה את כל המאפיינים שאנחנו נצפה לראות בפונקציה, למרות שהיא לא מחזירה שום דבר או יוצרת אובייקט באופן מפורש - היא בסך הכל מגדירה מפתחות ומתודות. אנו משתמשים במילה השמורה <code>this</code> — זה בעיקרון אומר שבכל פעם שנוצר מופע אובייקט, ה- <code>name</code> property יהיה שווה לערך של name value שהועבר לתוך ה- constructor, והמתודה <code>greeting()</code> תשתמש באותם ערכים שהועברו ל- constructor.</p>
-
-<div class="note">
-<p><strong>שימו לב</strong>:שם של constructor function בדרך כלל מתחיל עם אות גדולה - זו מוסכמה מקובלת על מנת לזהות בקלותconstructor functions קוד שלנו.</p>
-</div>
-
-<p>אז כיצד אנחנו קוראים ל-constructor function על מנת ליצור אובייקטים?</p>
-
-<ol>
- <li>הוסיפו את השורות הבאות מתחת לקוד הקודם שהוספתם:
- <pre class="brush: js notranslate">var person1 = new Person('Bob');
-var person2 = new Person('Sarah');</pre>
- </li>
- <li>שמרו ורעננו את הדף ולאחר מכן הזינו את השורות הבאות בקונסולה:
- <pre class="brush: js notranslate">person1.name
-person1.greeting()
-person2.name
-person2.greeting()</pre>
- </li>
-</ol>
-
-<p>אתם תראו שאנחנו יצרנו שני אובייקטים חדשים, כאשר כל אחד מהם נשמר תחת שם אחר — כאשר אנחנו רוצים לגשת למפתחות ולמתודות שלהם, אנחנו צריכים להתחיל עם קריאה ל <code>person1</code> או ל- <code>person2</code>; הפונקציונליות המאוחסנת בהם ארוזה בצורה מסודרת כך שהיא תתנגש עם פונקציונליות אחרת. יחד עם זאת, יש להם את אותו מפתח <code>name</code>  ואת אותה מתודת <code>greeting()</code> שזמינה עבורה. שימו לב שהם משתמשים בערך של ה - <code>name</code> שניתן להם כאשר הם נוצרו. זו אחת מהסיבות מדוע זה מאוד חשוב להתשמש במילה <code>this</code>, כך שהם ישתמשו בערכים שלהם ולא בערכים אחרים.</p>
-
-<p>נסתכל שוב על הקריאות ל- constructor שוב:</p>
-
-<pre class="brush: js notranslate">var person1 = new Person('Bob');
-var person2 = new Person('Sarah');</pre>
-
-<p>בכל אחת מהקריאות, המילה השמורה <code>new</code> משמשת על מנת להגיד לדפדפן שאנחנו רוצים ליצוא מופע אובייקט חדש, ולאחר מכן יש את שם הפונקציה עם הפרמטרים הרלוונטיים בתוך הסוגריים והתוצאה של אותה פונקציה, של אותה constructor function, מאוחסנת בתוך משתנה - זה דומה מאוד לאיך שפונקציה רגילה מופעלת או לאיך שקוראים לפונקציה רגילה. כל מופע אובייקט שכזה נוצר בהתאם להגדרה של ה-constructor function:</p>
-
-<pre class="brush: js notranslate">function Person(name) {
- this.name = name;
- this.greeting = function() {
- alert('Hi! I\'m ' + this.name + '.');
- };
-}</pre>
-
-<p>לאחר שהאובייקטים החדשים נוצרו, המשתנים <code>person1</code> ו- <code>person2</code> מכילים את האובייקטים הבאים:</p>
-
-<pre class="brush: js notranslate">{
- name: 'Bob',
- greeting: function() {
- alert('Hi! I\'m ' + this.name + '.');
- }
-}
-
-{
- name: 'Sarah',
- greeting: function() {
- alert('Hi! I\'m ' + this.name + '.');
- }
-}</pre>
-
-<p>שימו לב שכאשר אנחנו קוראים ל-constructor function שלנו, אנחנו מגדירים את המתודה <code>greeting()</code> בכל פעם - משהו שאינו אידיאלי. על מנת להימנע מכך, אנחנו נגדיר פונקציות שהוא בתבנית האב - אנו נגע בנושא זה בהמשך.</p>
-
-<h3 id="יצירת_ה-constructor_הסופי_שלנו">יצירת ה-constructor הסופי שלנו</h3>
-
-<p>הדוגמא שהסברנו למעלה הייתה דוגמא פשוטה שנועדה רק לסבר לנו את האוזן. כעת, ניצור את ה-constructor function code&gt;Person() הסופי שלנו.</p>
-
-<ol>
- <li>הסירו את הקוד שהכנסתם עד עכשיו, והוסיפו את ה - constructor הזה - הוא בעצם אותו דבר כמו בדוגמא למעלה, רק קצת יותר מורכב: :
- <pre class="brush: js notranslate">function Person(first, last, age, gender, interests) {
- this.name = {
-    first : first,
-    last : last
-  };
- this.age = age;
- this.gender = gender;
- this.interests = interests;
- this.bio = function() {
- alert(this.name.first + ' ' + this.name.last + ' is ' + this.age + ' years old. He likes ' + this.interests[0] + ' and ' + this.interests[1] + '.');
- };
- this.greeting = function() {
- alert('Hi! I\'m ' + this.name.first + '.');
- };
-}</pre>
- </li>
- <li>כעת, הוסיפו את הקוד הבא מתחת, על מנת ליצור מופעי אובייקט מ-constructor:
- <pre class="brush: js notranslate">var person1 = new Person('Bob', 'Smith', 32, 'male', ['music', 'skiing']);</pre>
- </li>
-</ol>
-
-<p>אתם תראו שאנחנו יכולים לגשת לכל אחד מהמפתחות והמתודות בדיוק כפי שיכלנו לפני כן - נסו להזין את הקוד הבא בקונסולה:</p>
-
-<pre class="brush: js notranslate">person1['age']
-person1.interests[1]
-person1.bio()
-// etc.</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אם אתם נתקלים בבעיות, נסו להשוות את הקוד שלכם לקוד שלנו - <a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/introduction/oojs-class-finished.html">oojs-class-finished.html</a> או ראו את <a href="http://mdn.github.io/learning-area/javascript/oojs/introduction/oojs-class-finished.html">דף האינטרנט</a>.</p>
-</div>
-
-<h3 id="תרגולים_נוספים">תרגולים נוספים</h3>
-
-<p>על מנת להתחיל, הוסיפו כמה אובייקטים נוספים משלכם, ונסו לקבל או לקבוע את המידע שלהם.</p>
-
-<p>בנוסף, יש מספר בעיות עם המתודה <code>bio()</code> — הפלט שלה תמיד יציג פלט בלשון זכר, למרות ש-person הוא נקבה. והמתמודה גם תציג רק שני תחומי עניין, אפילו אם בתוך המערך <code>interests</code> יש יותר תחומי עניין. האם אתם יכולים לתקן את זה ב-constructor שלנו? אם יכולים לשים כל קוד בתוך הconstructor (אתם כנראה תצרו משפטי תנאי ולולאה). חשבו כיצד המשפטים אמורים להיראות בצורה שונה כאשר מדובר במין שונה ומה עושים כאשר מספר תחומי העניין הוא 1, 2 או יותר מ-2.</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אם אתם נתקעים, ראו את <a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/introduction/oojs-class-further-exercises.html">התשובה ב- GitHub repo</a> או ב<a href="http://mdn.github.io/learning-area/javascript/oojs/introduction/oojs-class-further-exercises.html">דף היאנטרנט</a>) — אך נסו בעצמכם לפני כן</p>
-</div>
-
-<h2 id="דרכים_נוספות_ליצירת_מופעי_אובייקט_-_ליצירת_אובייקטים_חדשים">דרכים נוספות ליצירת מופעי אובייקט - ליצירת אובייקטים חדשים</h2>
-
-<p>עד עכשיו ראינו שתי דרכים ליצירת מופעי אובייקט — <a href="/en-US/docs/Learn/JavaScript/Objects/Basics#Object_basics">הצהרה על אובייקט ליטראלי</a>, ובאמצעות שימוש ב - constructor function (כפי שראינו למעלה).</p>
-
-<p>ישנם דרכים נוספים ואנחנו נרצה להציג לכם אותם על מנת שתכירו אותם במידה ותיתקלו בהם בהמשך הדרך</p>
-
-<h3 id="The_Object_constructor">The Object() constructor</h3>
-
-<p>ראשית, אתם יכולים לעשות שימוש ב constructor <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object">Object()</a></code> על מנת ליצור אובייקט חדש. כן, גם אובייקטים גנריים יש להם constructor, אשר יוצר אובייקט ריק.</p>
-
-<ol>
- <li>נסו להזין את הקוד הבא לתוך הקונסולה:
- <pre class="brush: js notranslate">var person1 = new Object();</pre>
- </li>
- <li>קוד זה מאחסן בעצם אובייקט ריק בתוך המשתנה <code>person1</code> .אנחנו יכולים להוסיף מפתחות ומתודות לאובייקט זה באמצעות שימוש ב- dot או dot; נסו להזין את הדוגמאות הבאות בקונסולה:
- <pre class="brush: js notranslate">person1.name = 'Chris';
-person1['age'] = 38;
-person1.greeting = function() {
- alert('Hi! I\'m ' + this.name + '.');
-};</pre>
- </li>
- <li>אתם גם יכולים להעביר object literal ל- <code>Object()</code> constructor כפרמטר, על מנת למלא מראש את הפרופ׳ והמתודות: נסו להזין את הקוד הבא בקונסולה:
- <pre class="brush: js notranslate">var person1 = new Object({
- name: 'Chris',
- age: 38,
- greeting: function() {
- alert('Hi! I\'m ' + this.name + '.');
- }
-});</pre>
- </li>
-</ol>
-
-<h3 id="שימוש_במתודת_create">שימוש במתודת create()</h3>
-
-<p>Constructors יכולים לעזור להעניק סדר לקוד שלנו - אנחנו יכולים ליצור את הconstructors במקום אחד ואז ליצור מופעים שלהם כמה שנרצה, במקום אחר, וזה יהיה ברור מאיפה הם נוצרוץ</p>
-
-<p>יחד עם זאת, ישנם מפתחים אשר מעדיפים ליצור מופעי אובייקט מבלי ליצור תחילה constructors, במיוחד אם אתם יוצרים רק מספר קטם של מופעי אובייקט. ל-JavaScript יש מתודה מובנת שנקראת <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/create">create()</a></code> אשר מאפשרת לנו לעשות זאת. עם מתודה זו, אנחנו יכולים ליצור אובייקט חדש, בהתבסס על אובייקט קיים.</p>
-
-<ol>
- <li>העלו את התרגיל שסיימתם בתרגול הקודם לדפדפן והוסיפו את הקוד הבא לקונסולה: :
- <pre class="brush: js notranslate">var person2 = Object.create(person1);</pre>
- </li>
- <li>כעת נסו להזין את הקוד הבא בקונסולה:
- <pre class="brush: js notranslate">person2.name
-person2.greeting()</pre>
- </li>
-</ol>
-
-<p>אתם תראו ש-<code>person2</code> נוצר בהתבסס על <code>person1</code> - יש לו את אותם פרופ׳ ומתודות שזמינות עבורו.</p>
-
-<p>הגבלה אחת שיש בשימוש עם מתודת <code>create()</code> היא שדפדפן IE8 does לא תומך בה. אז constructors יכולים להיות דרך רלוונטם במידה ואתם צריכים לתמוך בגרסה זו.</p>
-
-<p>אנו נחקור את המתודה <code>create()</code> בפרטי פרטים בהמשך הקורס.</p>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>מאמר זה העניק לכם מבט מופשט על תיאוריית פיתוח מונחה עצמים - זה לא הסיפור המלא כמובן, אבל זה נועד לתת לכם את הרעיון שאיתו אנחנו ממשיכים. בנוסף, התחלנו לגלות כיצד אנחנו יכולים ליצור מופעי אובייקט, או אובייקטים חדשים, בדרכים שונות.</p>
-
-<p>במאמר הבא אנחנו נחקור את נושא JavaScript object prototypes.</p>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/Objects/Basics", "Learn/JavaScript/Objects/Object_prototypes", "Learn/JavaScript/Objects")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Basics">אובייקטים - עקרונות יסוד</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Object-oriented_JS">Object-oriented JavaScript למתחילים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Object_prototypes">Object prototypes</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Inheritance">הורשה ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/JSON">עבודה עם JSON data</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Object_building_practice">שיטות ליצירת אובייקטים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Adding_bouncing_balls_features">Adding features to our bouncing balls demo</a></li>
-</ul>
diff --git a/files/he/learn/javascript/objects/object_prototypes/index.html b/files/he/learn/javascript/objects/object_prototypes/index.html
deleted file mode 100644
index 0afe0ef67d..0000000000
--- a/files/he/learn/javascript/objects/object_prototypes/index.html
+++ /dev/null
@@ -1,283 +0,0 @@
----
-title: Object prototypes
-slug: Learn/JavaScript/Objects/Object_prototypes
-translation_of: Learn/JavaScript/Objects/Object_prototypes
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{PreviousMenuNext("Learn/JavaScript/Objects/Object-oriented_JS", "Learn/JavaScript/Objects/Inheritance", "Learn/JavaScript/Objects")}}</div>
-
-<p class="summary">Prototypes - אבי טיפוס, זה המנגנון שבאמצעותו אובייקטים של javascript יורשים מאפיינים אחד מהשני. במאמר זה אנחנו נסביר כיצד שרשראות אבי טיפוס - (prototype chains) עובדות ונסתכל כיצד מאפיין (property) בשם prototype יכול לשמש עבור הוספת מתודות ל-constructors קיימים.</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">ידע מוקדם:</th>
- <td>
- <p>הבנה של פונקציות ב-JavaScript, הכרות עם הבסיס של JavaScript (ראו את המאמר צעדים ראשונים ב-<a href="/en-US/docs/Learn/JavaScript/First_steps">צעדים ראשונים ב-JavaScript</a> ו-<a href="/en-US/docs/Learn/JavaScript/Building_blocks">אבני הבניין של </a><a href="/en-US/docs/Learn/JavaScript/First_steps">JavaScript</a>) וכן הבסיס של תכנות מונחה עצמית ב-JavaScript (ראו <a href="/he/docs/Learn/JavaScript/Objects/Basics">אובייקטים - עקרונות יסוד</a>).</p>
- </td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>הבנה של JavaScript object prototypes, כיצד שרשראות prototype עובדות, וכיצד להוסיף מתודות חדשות לתוך פרופ׳ בשם prototype .</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="שפה_מבוססת_אב-טיפוס">שפה מבוססת אב-טיפוס?</h2>
-
-<p>JavaScript לעיתים קרובות מתוארת כ<strong>שפה מונחית אבי-טיפוס (prototype-based language)</strong> - על מנת לאפשר הורשה, לאובייקטים יכול להיות <strong>אובייקט אב-טיפוס </strong>(<strong>prototype object</strong>)<strong>,</strong> אשר מתפקד כאובייקט תבנית - אובייקט אב טיפוס אשר ממנו האובייקטים יכולים לירוש מתודות (methods) ומאפיינים (properties).</p>
-
-<p>לאובייקט אב-הטיפוס (prototype), יכול להיות גם אובייקט אב-טיפוס משל עצמו, אשר ממנו הוא יורש מתודות (methods) ומאפיינים (properties) וכך הלאה. תהליך זה לרוב מוגדר כ<strong>שרשרת אבי הטיפוס (prototype chain)</strong>, אשר מסבירה מדוע לאובייקטים שונים יש מאפיינים ומתודות שזמינים עבורם, כאשר אלו בכלל הוגדרו באובייקטים אחרים. </p>
-
-<p>ליתר דיוק, המתודות והמאפיינים מוגדרים במאפיין (property) בשם <code>prototype</code> ב-constructor functions <strong>ולא</strong> באובייקטים עצמם שנוצרו (object instance).</p>
-
-<p>ב-JavaScript, נוצר קשר בין האובייקט שנוצר (object instance) לבין אב הטיפוס/prototype שלו באמצעות ״הליכה״ על שרשרת אבי הטיפוס. אנו נוכל לראות את אב הטיפוס של אובייקט ב-property של האובייקט שנוצר בשם <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/proto">__proto__</a></code> . שם זה נגזר מ-<code>prototype</code> שמוגדר בכלל ב-constructor.  </p>
-
-<div class="note">
-<p><strong>לתשומת לב:</strong>  חשוב להבין שיש אבחנה בין אב הטיפוס של האובייקט  (object' s prototype) אשר זמין באמצעות <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/getPrototypeOf">(Object.getPrototypeOf(obj</a></code> או באמצעות מאפיין <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/proto">__proto__</a></code><u><strong>לבין</strong></u> מאפיין (property) בשם אב-טיפוס (prototype) אשר נמצא ב-constructor functions. </p>
-
-<p>הראשון הוא מאפיין שיופיע על כל אובייקט שייווצר ויעיד מיהו אב הטיפוס של אותו אובייקט ואילו השני, אשר נמצא ב-constructor הוא בעצם מאפיין של אותו constructor. </p>
-</div>
-
-<p>נסתכל על דוגמא על מנת להבין זאת לעומק.</p>
-
-<h2 id="הבנה_של_אובייקטים_מסוג_אב-טיפוס">הבנה של אובייקטים מסוג אב-טיפוס</h2>
-
-<p>נחזור לדוגמא הקודמת שבה סיימנו לכתוב את ה-constructor שלנו <code>()Person</code>:</p>
-
-<p>העלו את הדוגמא בדפדפן שלכם. אם אין לכם את הדוגמא עצמה או שהיא אינה עובדת, אנא השתמשו בדוגמא שלנו אשר נמצאת ב<a href="http://mdn.github.io/learning-area/javascript/oojs/introduction/oojs-class-further-exercises.html">קישור</a> זה או ב<a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/introduction/oojs-class-further-exercises.html">קוד המקור</a>.</p>
-
-<p>בדוגמא זו, אנחנו מגדירים את ה -constructor function שלנו כך:</p>
-
-<pre class="brush: js">function Person(first, last, age, gender, interests) {
-
- // property and method definitions
- this.first = first;
- this.last = last;
-//...
-}</pre>
-
-<p>אנו יוצרים אובייקטים מה-constructor function שהגדרנו כך:</p>
-
-<pre class="brush: js">var person1 = new Person('Bob', 'Smith', 32, 'male', ['music', 'skiing']);</pre>
-
-<p>אם תקלידו <code>.person1</code> בקונסולה, אתם אמורים לראות שהדפדפן מנסה להשלים באופן אוטומטי אפשרויות הזמינות עבור אובייקט זה: </p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/13853/object-available-members.png" style="display: block; margin: 0 auto;"></p>
-
-<p>ברשימה זו, אתם יכולים לראות את הפרופ׳ ומתודות שהוגדרו ב-constructor <code>Person()</code> — <code>name</code>, <code>age</code>, <code>gender</code>, <code>interests</code>, <code>bio</code>, ו- <code>greeting</code>. בנוסף, אנחנו גם נראה פרופ׳ ומתודות נוספות - <code>watch</code>, <code>valueOf</code> וכד׳ - אלו מוגדרים בתבנית אב הטיפוס (prototype object) של <code>()Person</code>, שזה  <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object">Object</a></code>.</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/13891/MDN-Graphics-person-person-object-2.png" style="display: block; height: 150px; margin: 0px auto; width: 700px;"></p>
-
-<p>מה קורה כשאנחנו רוצים לקרוא למתודה, להפעיל מתודה על <code>person1</code>, אשר מוגדרת ב-<code>Object</code>?:</p>
-
-<pre class="brush: js">person1.valueOf()</pre>
-
-<p>המתודה הזו - <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/valueOf">()Object.valueOf</a></code> נורשת על ידי <code>person1</code> בגלל שתבנית אב הטיפוס של האובייקט (הפונקציה <code>()Person</code>) שיצר אותו היא  <code>()Object.</code> המתודה <code>()valueOf</code> מחזירה את הערך של האובייקט שהיא נקראה עליו: </p>
-
-<ul>
- <li>הדפדפן תחילה בודק לראות האם לאובייקט <code>person1</code> יש את המתודה <code>()valueOf</code> זמינה עליו, כפי שמוגדר ב-constructor שלו, <code>()Person</code>. </li>
- <li>אם לא - הוא בודק האם לאב הטיפוס של <code>()Person</code>, יש את המתודה <code>()valueOf</code> זמינה עליו. יש לו ולכן היא זמינה עבור <code>person1</code>. </li>
-</ul>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אנחנו רוצים להדגיש את העבודה שמתודות ופרופ׳ <strong>לא</strong> מועתקים מאובייקט אחד לשני ב-prototype chain - הם זמינים עבורם באצעות הליכה על prototype chain כפי שהסברנו למעלה..</p>
-</div>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אין דרך רשמית להיכנס לאובייקט אב הטיפוס של אובייקט בצורה ישירה  הקשרים שבין הפריטים בשרשרת מוגדר בתוך פרופ׳ פנימי - שנקרא <code>[[prototype]]</code> במסמכים של השפה - ראו גם {{glossary("ECMAScript")}}. </p>
-
-<p>מרבית הדפדפנים המודרניים מכילים פרופ׳ שזמין שנקרא בשם <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/proto">__proto__</a></code>, אשר מכיל את האובייקט שהוא תבנית האב של האובייקט הרלוונטי. לדוגמא, נסו להזין <code>person1.__proto__</code> ו- <code>person1.__proto__.__proto__</code> לראות איך זה נראה. החל מ-ECMAScript 2015 אנחנו יכולים לגשת לאובייקט אב הטיפוס של אובייקט באמצעות <code>Object.getPrototypeOf(obj)</code>.</p>
-</div>
-
-<h2 id="The_prototype_property_היכן_שמגדירים_מה_מורישים">The prototype property: היכן שמגדירים מה מורישים</h2>
-
-<p>אז, היכן הפרופ׳ והמתודות שמורישים מוגדרים? אם אנחנו מסתכלים על הדף <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object">Object</a></code>, אנחנו נראה רשימה מצד של שמאל של פרופ׳ ומתודות - הרבה יותר מאלו שראינו שזמינות עבור <code>person1</code>. למה? מכיוון שחלקם הורשו ל-<code>person1</code> וחלקם לא. </p>
-
-<p>כפי שהוסבר למעלה, אלו שנורשו הם אלו שמוגדרים במאפיין (property) בשם <code>prototype</code> - כלומר אלו הם שמתחילים עם <code>.Object.prototype</code> ולא אלו שרק מתחילים עם <code>Object</code>. הערך של המאפיין <code>prototype</code> הוא אובייקט, אשר בעצם הוא מאחסן את כל הפרופ׳ והמתודות שאנחנו רוצים להוריש לאובייקטים בהמשך ה-prototype chain.</p>
-
-<p>כך לדוגמא, <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/watch">()Object.prototype.watch</a></code> ו- <code>()<a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/valueOf">Object.prototype.valueOf</a></code> זמינות עבור כל אובייקט שיירש מ-<code>Object.prototype</code>, כולל מופעים חדשים של אובייקטים מה-<code>()</code>constructor <code>Person</code>. </p>
-
-<p>לעומת זאת, <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/is">()Object.is</a></code> ו-<code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/keys">()Object.keys</a></code> לדוגמא, לא מוגדרים בתוך <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/keys">()</a></code> ולכן לא נוריש אותם לאובייקטים אשר יירשו מ-<code>Object.prototype</code>. הם מתודות ופרופ׳ אשר זמינים רק עבור ה-constructor <code>Object</code> עצמו. </p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>:  זה נראה מוזר - כיצד יכולה להיות מתודה שמוגדרת על ה-constructor, שהיא בעצמה פונקציה? פונקציות הם גם סוג של אובייקט - ראו הדף בנושא <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function">()Function</a></code> להמשך פרטים.</p>
-</div>
-
-<ol>
- <li>אתם יכולים לבדוק את הפרופ׳ בשם ה-prototype של האובייקטים הנוכחיים שלנו - חזרו לדוגמא הקודמת והקלידו את הקוד הבא בקונסולה:
- <pre class="brush: js">Person.prototype</pre>
- </li>
- <li>אתם לא תראו יותר מדי אפשרויות מכיוון שלא הגדרנו כלום בפרופ׳ בשם prototype של ה-constructor. כברירת מחדל, הפרופ׳ בשם prototype של ה-constructor תמיד מתחיל ריק.</li>
- <li>כעת, נסו להזין את הקוד הבא:
- <pre class="brush: js">Object.prototype</pre>
- </li>
-</ol>
-
-<p>אתם תראו מספר גדול של מתודות שמוגדרות ב-property בשם <code>prototype</code> של <code>Object</code>, אשר זמינות עבור אובייקטים שירשו מ-<code>Object</code> כפי שהסברנו למעלה.</p>
-
-<p>אתם תראו דוגמאות כאלו של שרשרת ההורשה - prototype chain inheritance בכל JavaScript - נסו לחפש אחר מתודות ופרופ׳ אשר מוגדרים בפרופ׳ של האובייקטים הגלובליים <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/String">String</a></code>, <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date">Date</a></code>, <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number">Number</a></code>, ו-<code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a></code>. לכולם יש מס׳ מתודות ופרופ׳ שמוגדרות באותו prototype. זו הסיבה לדוגמא שכשאר אנחנו יוצרים מחרוזת בצורה הבאה:</p>
-
-<pre class="brush: js">var myString = 'This is my string.';</pre>
-
-<p>ל-<code>myString</code> ישר יש מספר מתודות שימושיות שזמינות עבורו כמו <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/replace">()</a></code> <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/split">split()</a></code>, <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/indexOf">indexOf()</a></code>, <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/replace">replace</a></code> וכד׳. </p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אנו ממליצים לקרוא את המדריך המעמיק שלנו בנושא - <a href="/en-US/docs/Web/JavaScript/Inheritance_and_the_prototype_chain#Using_prototypes_in_JavaScript">Using prototypes in JavaScript</a> לאחר שהבנתם את החלק הזה. החלק הזה בכוונה נכתב בצורה פשוטה (יחסית) על מנת להסביר את הרעיון שעומד מאחורי הנושא.</p>
-</div>
-
-<div class="warning">
-<p><strong>חשוב</strong>: המאפיין (<code>prototype</code> (property הוא אחד מהחלקים המבלבלים ב-JavaScript. אתם עלולים לחשוב ש-<font face="consolas, Liberation Mono, courier, monospace"><span style="background-color: rgba(220, 220, 220, 0.498039);">this</span></font> מצביע על האובייקט אב טיפוס של האובייקט הנוכחי, אבל הוא לא (זה אובייקט פנימי שניתן לגשת אליו באמצעות <code>__proto__</code>, זוכרים? ).</p>
-
-<p>המאפיין <code>prototype</code> הוא בעצם property שמכיל אובייקט, אשר על אובייקט זה אנחנו מגדירים את המתודות והפרופ׳ שנרצו שיורשו.</p>
-</div>
-
-<h2 id="שימוש_במתודה_()create">שימוש במתודה ()create</h2>
-
-<p>מוקדם יותר ראינו כיצד מתודת <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/create">()</a><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/create">Object.create</a></code> יכולה לשמש על מנת ליצור אובייקט חדש:</p>
-
-<ol>
- <li>לדוגמא, נסו להזין בקונסולה של הדוגמא הקודמת את הקוד הבא:
- <pre class="brush: js">var person2 = Object.create(person1);</pre>
- </li>
- <li>מה ש-<code>()create</code> עושה בפועל היא ליצור אובייקט חדש מ-prototype מוגדר. כאן <code>person2</code> מיוצר כאובייקט חדש באמצעות שימוש ב-<code>person1</code> כאובייקט ה-prototype שלו, כאובייקט אב הטיפוס שלו. אתם יכולים לראות זאת באמצעות הזנת הקוד הבא בקונסולה:</li>
- <li>
- <pre class="brush: js">person2.__proto__</pre>
- </li>
-</ol>
-
-<p>זה יחזיר לנו <font face="consolas, Liberation Mono, courier, monospace"><span style="background-color: rgba(220, 220, 220, 0.5);">person1</span></font>.</p>
-
-<h2 id="המאפיין_(property)_בשם_constructor">המאפיין (property) בשם constructor</h2>
-
-<p>לכל constructor function יש מאפיין (property) בשם <code>prototype</code> אשר הערך שלו הוא אובייקט. אותו אובייקט מכיל מאפיין (property) בשם <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/constructor">constructor</a></code>. </p>
-
-<p>המאפיין <code>constructor</code> הזה, <strong>מצביע ל-constructor function המקורית</strong>. כפי שתראו בהמשך, כאשר properties שמוגדרים על Person.prototype property, או באופן כללי, על המאפיין <code>prototype</code> של constructor function, שהוא בעצמו הוא אובייקט, הם נהיים זמינים עבור כל האובייקטים שייווצרו באמצעות ה-constructor בשם ()Person. המאפיין <code>constructor</code> זמין גם עבור האובייקט <code>person1</code> וגם עבור האובייקט <code>person2</code>. </p>
-
-<ol>
- <li>לדוגמא, נסו להזין את השורות הבאות בקונסולה:
- <pre class="brush: js">person1.constructor
-person2.constructor</pre>
-
- <p>שתיהן אמורות להחזיר לנו ה-<code>Person()</code> constructor, שכן היא מכילה את ה-״הגדרה״ המקורית של אובייקטים אלו. טריק חכם הוא שניתן לשים סוגריים רגילות <code>()</code> בסוף המאפיין <code>constructor</code> (ובתוך הסוגריים להכניס פרמרטים הנדרשים ל-<code>constructor</code>, ככל ונדרשים), וואז נוצר לנו אובייקט חדש מאותו <code>constructor</code>. ה-<code>constructor</code> הוא בעצם פונקציה אחרי הכל, אז אפשר לקרוא לפונקציה באמצעות שימוש ב-<code>()</code> כמו שאנחנו יודעים. רק חשוב לשים את המילה השמורה <code>new</code> לפני, על מנת להגדיר שאנחנו רוצים שיווצר אובייקט חדש ולהשתמש בפונקציה הזו כ-<code>constructor</code> של אותו אובייקט. </p>
- </li>
- <li>נסו להזין את הקוד הבא בקונסולה:
- <pre class="brush: js">var person3 = new person1.constructor('Karen', 'Stephenson', 26, 'female', ['playing drums', 'mountain climbing']);</pre>
- </li>
- <li>כעת, נסו לגשת למתודות ולפרופ׳ של האובייקט החדש:
- <pre class="brush: js">person3.name.first
-person3.age
-person3.bio()</pre>
- </li>
-</ol>
-
-<p>זה עובד מצויין. אנחנו בדרך לא נשתמש באופציה שכזו, אבל זה יכול להיות שימושי כאשר אנחנו רוצים ליצור מופע אובייקט חדש ואין לנו הפנייה לקונסטרקטור המקורי בצורה פשוטה מכל סיבה שהיא. </p>
-
-<p>ה-property בשם <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/constructor">constructor</a></code> שימושי גם לדברים נוספים. לדוגמא, אם יש לנו אובייקט ואני רוצה להחזיר את שם ה-<code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/constructor">constructor</a></code> שהוא מופע שלו, כלומר שבנה אותו, אנחנו יכולים להזין את הקוד הבא:</p>
-
-<pre class="brush: js">instanceName.constructor.name</pre>
-
-<p>נסו לדוגמא להזין את הקוד הבא:</p>
-
-<pre class="brush: js">person1.constructor.name
-</pre>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>:  הערך של <code>constructor.name</code> יכול להשתנות (כתוצאה מ-prototypical inheritance, binding, preprocessors, transpilers, etc. ועד), אז לדוגמאות מורכבות יותר, אנחנו נרצה להתשמש באופרטור <code><a href="/en-US/docs/Web/JavaScript/Reference/Operators/instanceof">instanceof</a></code> במקום. </p>
-</div>
-
-<ol>
-</ol>
-
-<h2 id="שינוי_של_הפרופ׳_בשם_prototype_-_הוספההסרה_של_מתודות">שינוי של הפרופ׳ בשם prototype - הוספה/הסרה של מתודות</h2>
-
-<p>נסתכל כעת על דוגמא לשינוי של ה-property בשם <code>prototype</code> שנמצא ב-constructor function - מתודות שיתווספו ל-<code>prototype</code> יהיו זמינות עבור כל האובייקטים שנוצרו מאותה constructor function. בנקודה הזו אנחנו נוסיף מתודות ל-property בשם <code>prototype</code>של constructor function שלנו, כך שכל מה שנגדיר במאפיין <code>prototype</code> יהיה זמין עבור האובייקטים שייווצרו ממנו. </p>
-
-<ol>
- <li>חזרו לדוגמא המופיע בקישור <a href="http://mdn.github.io/learning-area/javascript/oojs/introduction/oojs-class-further-exercises.html">oojs-class-further-exercises.htm</a> וצרו עותק מקומי של קוד המקור <a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/introduction/oojs-class-further-exercises.html">source code</a>. מתחת לקוד הנוכחי של של JavaScript, הוסיפו את הקוד הבא, אשר יוצר מתודה חדשה במאפיין <code>prototype</code> של constructor function:</li>
- <li>
- <pre class="brush: js">Person.prototype.farewell = function() {
- alert(this.name.first + ' has left the building. Bye for now!');
-};</pre>
- </li>
- <li>שמרו את הקוד והעלו את הדף בדפדפן, ונסו להזין את הקוד הבא :
- <pre class="brush: js">person1.farewell();</pre>
- </li>
-</ol>
-
-<p>אתם אמורים לקבל הודעה קופצת מסוג alert, המכילה את שם ה-person שהוגדר ב-constructor. זה מאוד שימוש, אבל מה שיותר שימושי זה שכל שרשרת ההורשה עודכנה באופן דינאמי ואוטומטי והפכה את המתודה הזו לזמינה עבור כל האובייקטים שנוצרו באמצעות אותה constructor function. </p>
-
-<p>חשבו על זה לרגע, בקוד שלנו אנחנו הגדרנו את ה-constructor function, ואז יצרנו אובייקט מאותה constructor function, ואז הוספנו מתודה נוספות ל-<code>prototype</code> של אותה constructor function: </p>
-
-<pre class="brush: js">function Person(first, last, age, gender, interests) {
-
- // property and method definitions
-
-}
-
-var person1 = new Person('Tammi', 'Smith', 32, 'neutral', ['music', 'skiing', 'kickboxing']);
-
-Person.prototype.farewell = function() {
- alert(this.name.first + ' has left the building. Bye for now!');
-};</pre>
-
-<p>ומה שקרה זה שהמתודה שהגדרנו <code>()farewell</code> נהייתה זמינה עבור <code>person1</code> - והוא יכול לעשות בה שימוש, למרות שהוא הוגדר לפני שהגדרנו את המתודה החדשה. מגניב, לא?</p>
-
-<div class="note">
-<p><strong>לתשומת לב</strong>: אם אתם נתקלים בבעיות, ראו את הדוגמא <a href="https://github.com/mdn/learning-area/blob/master/javascript/oojs/advanced/oojs-class-prototype.html">פה</a> או כ<a href="http://mdn.github.io/learning-area/javascript/oojs/advanced/oojs-class-prototype.html">דף אינטרנט</a>.</p>
-</div>
-
-<p>יחד עם זאת, לעיתים נדירות נראה properties שמוגדרים ב-property ה<code>prototype</code> מכיוון שהם לא ממש גמישים כשהם מוגדרים בצורה הזו. לדוגמא, ניתן להוסיף property בצורה הזו: </p>
-
-<pre class="brush: js">Person.prototype.fullName = 'Bob Smith';</pre>
-
-<p>זה לא ממש מאפשר גמישות (שכן יכול להיות שקוראים לאובייקט person החדש בשם אחר), ולכן יהיה עדיף לבנות את המאפיין החדש בצורה הבאה: </p>
-
-<pre class="brush: js">Person.prototype.fullName = this.name.first + ' ' + this.name.last;</pre>
-
-<p>יחד עם זאת, זה לא יעבוד שכן <code>this</code> יפנה לסקופ הגלובלי במקרה הנוכחי ולא לסקופ של הפונקציה. קריאה למאפיין זה תחזיר ערך של <code>undefined undefined</code>.</p>
-
-<p>זה עובד מצוין על מתודה שהגדרנו למעלה ב-prototype מכיוון שהיא יושבת בתוך הסקופ של ה-function, והמתודה מועברת בתורה לסקופ של האובייקט שנוצר באמצעות constructor function. אז אולי נגדיר constant properties ב- prototype, כאלו שלא נשנה לעולם, אבל בכללי, זה עובד טוב יותר להגדיר properties בתוך ה-constructor. </p>
-
-<p>בעקרון, השימוש המקובל להגדרת אובייקטים הוא להגדיר את המאפיינים (properties) בתוך ה-constructor ואת המתודות בתוך ה-prototype. </p>
-
-<p>זה הופך הקוד לקל יותר לקריאה, שכן ה-constractor מכיל רק  את ההגדרות של properties ואילו המתודות מחולקות לבלוקים נפרדים. לדוגמא:</p>
-
-<pre class="brush: js">// Constructor with property definitions
-
-function Test(a, b, c, d) {
- // property definitions
-}
-
-// First method definition
-
-Test.prototype.x = function() { ... };
-
-// Second method definition
-
-Test.prototype.y = function() { ... };
-
-// etc.</pre>
-
-<p>ניתן לראות שימוש בפועל בדוגמא <a href="https://github.com/zalun/school-plan-app/blob/master/stage9/js/index.js">school plan app</a> של Piotr Zalewa.</p>
-
-<h2 id="לסיכום">לסיכום</h2>
-
-<p>מאמר זה כיסה את הנושא של JavaScript object prototypes, כולל כיצד prototype object chains מאפשרת לאובייקטים לירוש מתודות ופרופ׳ אחד מהשני, ראינו את ה-property בשם prototype וכיצד הוא יכול לשמש על מנת להוסיף מתודות ל-constructors וכן נושאים נוספים.</p>
-
-<p>במאמר הבא אנחנו נראה כיצד ניתן להחיל הורשה של פונצקיונליות בין שני אובייקטים שניצור. </p>
-
-<p>{{PreviousMenuNext("Learn/JavaScript/Objects/Object-oriented_JS", "Learn/JavaScript/Objects/Inheritance", "Learn/JavaScript/Objects")}}</p>
-
-<h2 id="במודול_זה">במודול זה</h2>
-
-<ul>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Basics">אובייקטים - עקרונות יסוד</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Object-oriented_JS">Object-oriented JavaScript למתחילים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Object_prototypes">Object prototypes</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Inheritance">הורשה ב-JavaScript</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/JSON">עבודה עם JSON data</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Object_building_practice">שיטות ליצירת אובייקטים</a></li>
- <li><a href="/he/docs/Learn/JavaScript/Objects/Adding_bouncing_balls_features">Adding features to our bouncing balls demo</a></li>
-</ul>
diff --git a/files/he/learn/server-side/express_nodejs/index.html b/files/he/learn/server-side/express_nodejs/index.html
deleted file mode 100644
index a8212504ce..0000000000
--- a/files/he/learn/server-side/express_nodejs/index.html
+++ /dev/null
@@ -1,64 +0,0 @@
----
-title: Express web framework (Node.js/JavaScript)
-slug: Learn/Server-side/Express_Nodejs
-translation_of: Learn/Server-side/Express_Nodejs
----
-<div>{{LearnSidebar}}</div>
-
-<p class="summary">Express is a popular unopinionated web framework, written in JavaScript and hosted within the Node.js runtime environment. This module explains some of the key benefits of the framework, how to set up your development environment and how to perform common web development and deployment tasks.</p>
-
-<h2 id="תנאים_מוקדמים">תנאים מוקדמים</h2>
-
-<p>לפני שתתחיל את המודל עליך להבין מה זה תכנות צד שרת ומה זה מסגרות אינטרנט (frameworks), מומלץ לקרוא על הנושא במדריך שלנו <a href="https://wiki.developer.mozilla.org/en-US/docs/Learn/Server-side/First_steps">צעדים ראשונים לתכנות האתר בצד שרת</a>. ידע כללי על מושגי תכנות ו- <a href="https://wiki.developer.mozilla.org/en-US/docs/Web/JavaScript">JavaScript</a> מומלץ מאוד, אך אינו חיוני להבנת מושגי הליבה.</p>
-
-<div class="note">
-<p><strong>Note</strong>: This website has many useful resources for learning JavaScript<em> in the context of client-side development</em>: <a href="/en-US/docs/Web/JavaScript">JavaScript</a>, <a href="/en-US/docs/Web/JavaScript/Guide">JavaScript Guide</a>, <a href="/en-US/docs/Learn/Getting_started_with_the_web/JavaScript_basics">JavaScript Basics</a>, <a href="/en-US/docs/Learn/JavaScript">JavaScript</a> (learning). The core JavaScript language and concepts are the same for server-side development on Node.js and this material will be relevant. Node.js offers <a href="https://nodejs.org/dist/latest-v10.x/docs/api/">additional APIs</a> for supporting functionality that is useful in browserless environments (e.g., to create HTTP servers and access the file system), but does not support JavaScript APIs for working with the browser and DOM.</p>
-
-<p>This guide will provide some information about working with Node.js and Express, and there are numerous other excellent resources on the Internet and in books — some of these linked from <a href="http://stackoverflow.com/a/5511507/894359">How do I get started with Node.js</a> (StackOverflow) and <a href="https://www.quora.com/What-are-the-best-resources-for-learning-Node-js?">What are the best resources for learning Node.js?</a> (Quora).</p>
-</div>
-
-<h2 id="מדריכים">מדריכים</h2>
-
-<dl>
- <dt><a href="https://wiki.developer.mozilla.org/en-US/docs/Learn/Server-side/Express_Nodejs/Introduction">מבוא-Node.js/Express</a></dt>
- <dd>In this first Express article we answer the questions "What is Node?" and "What is Express?" and give you an overview of what makes the Express web framework special. We'll outline the main features and show you some of the main building blocks of an Express application (although at this point you won't yet have a development environment in which to test it).</dd>
- <dt><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/development_environment">Setting up a Node (Express) development environment</a></dt>
- <dd>Now that you know what Express is for, we'll show you how to set up and test a Node/Express development environment on Windows, Linux (Ubuntu), and Mac OS X. Whatever common operating system you are using, this article should give you what you need to be able to start developing Express apps.</dd>
- <dt><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/Tutorial_local_library_website">Express Tutorial: The Local Library website</a></dt>
- <dd>The first article in our practical tutorial series explains what you'll learn and provides an overview of the "local library" example website we'll be working through and evolving in subsequent articles.</dd>
- <dt><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/skeleton_website">Express Tutorial Part 2: Creating a skeleton website</a></dt>
- <dd>This article shows how you can create a "skeleton" website project, which you can then go on to populate with site-specific routes, templates/views, and databases.</dd>
- <dt><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/mongoose">Express Tutorial Part 3: Using a Database (with Mongoose)</a></dt>
- <dd>This article briefly introduces databases for Node/Express. It then goes on to show how we can use <a href="http://mongoosejs.com/">Mongoose</a> to provide database access for the <em>LocalLibrary</em> website. It explains how object schema and models are declared, the main field types, and basic validation. It also briefly shows a few of the main ways you can access model data.</dd>
- <dt><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/routes">Express Tutorial Part 4: Routes and controllers</a></dt>
- <dd>In this tutorial we'll set up routes (URL handling code) with "dummy" handler functions for all the resource endpoints that we'll eventually need in the <em>LocalLibrary</em> website. On completion, we'll have a modular structure for our route handling code, that we can extend with real handler functions in the following articles. We'll also have a really good understanding of how to create modular routes using Express.</dd>
- <dt><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/Displaying_data">Express Tutorial Part 5: Displaying library data</a></dt>
- <dd>We're now ready to add the pages that display the <em>LocalLibrary</em> website books and other data. The pages will include a home page that shows how many records we have of each model type and list and detail pages for all of our models. Along the way, we'll gain practical experience in getting records from the database and using templates.</dd>
- <dt><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/forms">Express Tutorial Part 6: Working with forms</a></dt>
- <dd>In this tutorial we'll show you how to work with <a href="/en-US/docs/Web/Guide/HTML/Forms">HTML Forms</a> in Express, using Pug, and in particular how to write forms to create, update, and delete documents from the database.</dd>
- <dt><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/deployment">Express Tutorial Part 7: Deploying to production</a></dt>
- <dd>Now you've created an awesome <em>LocalLibrary</em> website, you're going to want to install it on a public web server so that it can be accessed by library staff and members over the Internet. This article provides an overview of how you might go about finding a host to deploy your website, and what you need to do in order to get your site ready for production.</dd>
-</dl>
-
-<h2 id="ראה_עוד">ראה עוד</h2>
-
-<dl>
- <dt><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/Installing_on_PWS_Cloud_Foundry">Installing LocalLibrary on PWS/Cloud Foundry</a></dt>
- <dd>This article provides a practical demonstration of how to install <em>LocalLibrary</em> on the <a href="http://run.pivotal.io">Pivotal Web Services PaaS cloud</a> — this is a full-featured, open source alternative to Heroku, the PaaS cloud service used in Part 7 of the tutorial, listed above. PWS/Cloud Foundry is definitely worth checking out if you are looking for an alternative to Heroku (or another PaaS cloud service), or simply feel like trying something different. </dd>
-</dl>
-
-<h2 id="Adding_more_tutorials">Adding more tutorials</h2>
-
-<div>
-<p>All existing tutorials are listed above, but if you would like to extend this module, some other interesting topics to cover include:</p>
-
-<ul>
- <li>Using sessions.</li>
- <li>User authentication.</li>
- <li>User authorization and permissions.</li>
- <li>Testing an Express web application.</li>
- <li>Web security for Express web applications.</li>
-</ul>
-
-<p>An assessment for the module would also make a wonderful addition!</p>
-</div>
diff --git a/files/he/learn/server-side/express_nodejs/introduction/index.html b/files/he/learn/server-side/express_nodejs/introduction/index.html
deleted file mode 100644
index 31be2705c0..0000000000
--- a/files/he/learn/server-side/express_nodejs/introduction/index.html
+++ /dev/null
@@ -1,542 +0,0 @@
----
-title: Express/Node introduction
-slug: Learn/Server-side/Express_Nodejs/Introduction
-translation_of: Learn/Server-side/Express_Nodejs/Introduction
----
-<div>{{LearnSidebar}}</div>
-
-<div>{{NextMenu("Learn/Server-side/Express_Nodejs/development_environment", "Learn/Server-side/Express_Nodejs")}}</div>
-
-<p class="summary">In this first Express article we answer the questions "What is Node?" and "What is Express?", and give you an overview of what makes the Express web framework special. We'll outline the main features, and show you some of the main building blocks of an Express application (although at this point you won't yet have a development environment in which to test it).</p>
-
-<table class="learn-box standard-table">
- <tbody>
- <tr>
- <th scope="row">תנאים מוקדמים:</th>
- <td>Basic computer literacy. A general understanding of <a href="https://developer.mozilla.org/en-US/docs/Learn/Server-side/First_steps">server-side website programming</a>, and in particular the mechanics of <a href="/en-US/docs/Learn/Server-side/First_steps/Client-Server_overview">client-server interactions in websites</a>.</td>
- </tr>
- <tr>
- <th scope="row">מטרה:</th>
- <td>To gain familiarity with what Express is and how it fits in with Node, what functionality it provides, and the main building blocks of an Express application.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="הכירו_את_Node">הכירו את Node</h2>
-
-<p><a href="https://nodejs.org/">Node</a> (or more formally <em>Node.js</em>) is an open-source, cross-platform runtime environment that allows developers to create all kinds of server-side tools and applications in <a href="/en-US/docs/Glossary/JavaScript">JavaScript</a>. The runtime is intended for use outside of a browser context (i.e. running directly on a computer or server OS). As such, the environment omits browser-specific JavaScript APIs and adds support for more traditional OS APIs including HTTP and file system libraries.</p>
-
-<p>From a web server development perspective Node has a number of benefits:</p>
-
-<ul>
- <li>Great performance! Node was designed to optimize throughput and scalability in web applications and is a good solution for many common web-development problems (e.g. real-time web applications).</li>
- <li>Code is written in "plain old JavaScript", which means that less time is spent dealing with "context shift" between languages when you're writing both client-side and server-side code.</li>
- <li>JavaScript is a relatively new programming language and benefits from improvements in language design when compared to other traditional web-server languages (e.g. Python, PHP, etc.) Many other new and popular languages compile/convert into JavaScript so you can also use TypeScript, CoffeeScript, ClojureScript, Scala, LiveScript, etc.</li>
- <li>The node package manager (NPM) provides access to hundreds of thousands of reusable packages. It also has best-in-class dependency resolution and can also be used to automate most of the build toolchain.</li>
- <li>Node.js is portable. It is available on Microsoft Windows, macOS, Linux, Solaris, FreeBSD, OpenBSD, WebOS, and NonStop OS. Furthermore, it is well-supported by many web hosting providers, that often provide specific infrastructure and documentation for hosting Node sites.</li>
- <li>It has a very active third party ecosystem and developer community, with lots of people who are willing to help.</li>
-</ul>
-
-<p>You can use Node.js to create a simple web server using the Node HTTP package.</p>
-
-<h3 id="Hello_Node.js">Hello Node.js</h3>
-
-<p>The following example creates a web server that listens for any kind of HTTP request on the URL <code>http://127.0.0.1:8000/</code> — when a request is received, the script will respond with the string: "Hello World". If you have already installed node, you can follow these steps to try out the example:</p>
-
-<ol>
- <li>Open Terminal (on Windows, open the command line utility)</li>
- <li>Create the folder where you want to save the program, for example, <code>test-node</code> and then enter it by entering the following command into your terminal:</li>
-</ol>
-
-<pre class="notranslate">cd test-node</pre>
-
-<ol start="3">
- <li>Using your favorite text editor, create a file called <code>hello.js</code> and paste the following code into it:</li>
-</ol>
-
-<pre class="brush: js notranslate">// Load HTTP module
-const http = require("http");
-
-const hostname = "127.0.0.1";
-const port = 8000;
-
-// Create HTTP server
-const server = http.createServer((req, res) =&gt; {
-
- // Set the response HTTP header with HTTP status and Content type
- res.writeHead(200, {'Content-Type': 'text/plain'});
-
- // Send the response body "Hello World"
- res.end('Hello World\n');
-});
-
-// Prints a log once the server starts listening
-server.listen(port, hostname, () =&gt; {
- console.log(`Server running at http://${hostname}:${port}/`);
-})
-</pre>
-
-<ol start="4">
- <li>Save the file in the folder you created above.</li>
- <li>Go back to the terminal and type the following command:</li>
-</ol>
-
-<pre class="brush: bash notranslate">node hello.js</pre>
-
-<p>Finally, navigate to <code>http://localhost:8000</code> in your web browser; you should see the text "<strong>Hello World</strong>" in the upper left of an otherwise empty web page.</p>
-
-<h2 id="Web_Frameworks">Web Frameworks</h2>
-
-<p>Other common web-development tasks are not directly supported by Node itself. If you want to add specific handling for different HTTP verbs (e.g. <code>GET</code>, <code>POST</code>, <code>DELETE</code>, etc.), separately handle requests at different URL paths ("routes"), serve static files, or use templates to dynamically create the response, Node won't be of much use on its own. You will either need to write the code yourself, or you can avoid reinventing the wheel and use a web framework!</p>
-
-<h2 id="Introducing_Express">Introducing Express</h2>
-
-<p><a href="https://expressjs.com/">Express</a> is the most popular <em>Node</em> web framework, and is the underlying library for a number of other popular <a href="https://expressjs.com/en/resources/frameworks.html">Node web frameworks</a>. It provides mechanisms to:</p>
-
-<ul>
- <li>Write handlers for requests with different HTTP verbs at different URL paths (routes).</li>
- <li>Integrate with "view" rendering engines in order to generate responses by inserting data into templates.</li>
- <li>Set common web application settings like the port to use for connecting, and the location of templates that are used for rendering the response.</li>
- <li>Add additional request processing "middleware" at any point within the request handling pipeline.</li>
-</ul>
-
-<p>While <em>Express</em> itself is fairly minimalist, developers have created compatible middleware packages to address almost any web development problem. There are libraries to work with cookies, sessions, user logins, URL parameters, <code>POST</code> data, security headers, and <em>many </em>more. You can find a list of middleware packages maintained by the Express team at <a href="http://expressjs.com/en/resources/middleware.html">Express Middleware</a> (along with a list of some popular 3rd party packages).</p>
-
-<div class="note">
-<p><strong>Note:</strong> This flexibility is a double edged sword. There are middleware packages to address almost any problem or requirement, but working out the right packages to use can sometimes be a challenge. There is also no "right way" to structure an application, and many examples you might find on the Internet are not optimal, or only show a small part of what you need to do in order to develop a web application.</p>
-</div>
-
-<h2 id="Where_did_Node_and_Express_come_from">Where did Node and Express come from?</h2>
-
-<p>Node was initially released, for Linux only, in 2009. The NPM package manager was released in 2010, and native Windows support was added in 2012. The current LTS release is Node v12.16.1 while the latest release is Node 13.11.0. This is a tiny snapshot of a rich history; delve into <a href="https://en.wikipedia.org/wiki/Node.js#History">Wikipedia</a> if you want to know more.</p>
-
-<p>Express was initially released in November 2010 and is currently on version 4.17.1 of the API. You can check out the <a href="https://expressjs.com/en/changelog/4x.html">changelog</a> for information about changes in the current release, and <a href="https://github.com/expressjs/express/blob/master/History.md">GitHub</a> for more detailed historical release notes.</p>
-
-<h2 id="כמה_פופלרי_Node_ו_Express">כמה פופלרי Node ו Express?</h2>
-
-<p>The popularity of a web framework is important because it is an indicator of whether it will continue to be maintained, and what resources are likely to be available in terms of documentation, add-on libraries, and technical support.</p>
-
-<p>There isn't any readily-available and definitive measure of the popularity of server-side frameworks (although sites like <a href="http://hotframeworks.com/">Hot Frameworks</a> attempt to assess popularity using mechanisms like counting the number of GitHub projects and StackOverflow questions for each platform). A better question is whether Node and Express are "popular enough" to avoid the problems of unpopular platforms. Are they continuing to evolve? Can you get help if you need it? Is there an opportunity for you to get paid work if you learn Express?</p>
-
-<p>Based on the number of <a href="https://expressjs.com/en/resources/companies-using-express.html">high profile companies</a> that use Express, the number of people contributing to the codebase, and the number of people providing both free and paid for support, then yes, <em>Express</em> is a popular framework!</p>
-
-<h2 id="Is_Express_opinionated">Is Express opinionated?</h2>
-
-<p>Web frameworks often refer to themselves as "opinionated" or "unopinionated".</p>
-
-<p>Opinionated frameworks are those with opinions about the "right way" to handle any particular task. They often support rapid development <em>in a particular domain </em>(solving problems of a particular type) because the right way to do anything is usually well-understood and well-documented. However they can be less flexible at solving problems outside their main domain, and tend to offer fewer choices for what components and approaches they can use.</p>
-
-<p>Unopinionated frameworks, by contrast, have far fewer restrictions on the best way to glue components together to achieve a goal, or even what components should be used. They make it easier for developers to use the most suitable tools to complete a particular task, albeit at the cost that you need to find those components yourself.<br>
- <br>
- Express is unopinionated. You can insert almost any compatible middleware you like into the request handling chain, in almost any order you like. You can structure the app in one file or multiple files, and using any directory structure. You may sometimes feel that you have too many choices!</p>
-
-<h2 id="What_does_Express_code_look_like">What does Express code look like?</h2>
-
-<p>In a traditional data-driven website, a web application waits for HTTP requests from the web browser (or other client). When a request is received the application works out what action is needed based on the URL pattern and possibly associated information contained in <code>POST</code> data or <code>GET</code> data. Depending on what is required it may then read or write information from a database or perform other tasks required to satisfy the request. The application will then return a response to the web browser, often dynamically creating an HTML page for the browser to display by inserting the retrieved data into placeholders in an HTML template.</p>
-
-<p>Express provides methods to specify what function is called for a particular HTTP verb (<code>GET</code>, <code>POST</code>, <code>SET</code>, etc.) and URL pattern ("Route"), and methods to specify what template ("view") engine is used, where template files are located, and what template to use to render a response. You can use Express middleware to add support for cookies, sessions, and users, getting <code>POST</code>/<code>GET</code> parameters, etc. You can use any database mechanism supported by Node (Express does not define any database-related behaviour).</p>
-
-<p>The following sections explain some of the common things you'll see when working with <em>Express</em> and <em>Node</em> code.</p>
-
-<h3 id="דוגמה_Hello_world">דוגמה Hello world</h3>
-
-<p>ראשית בואו נבחן דוגמה סטנדרטית של Express <a href="https://expressjs.com/en/starter/hello-world.html">Hello World</a> (בהמשך נסביר כל חלק בקוד כאן ובהמשך)</p>
-
-<div class="note">
-<p><strong>Tip:</strong> If you have Node and Express already installed (or if you install them as shown in the <a href="/en-US/docs/Learn/Server-side/Express_Nodejs/development_environment">next article</a>), you can save this code in a text file called <strong>app.js</strong> and run it in a bash command prompt by calling:   </p>
-
-<p><strong><code>node ./app.js</code></strong></p>
-</div>
-
-<pre class="brush: js notranslate">var express = require('express');
-var app = express();
-
-<strong>app.get('/', function(req, res) {
- res.send('Hello World!');
-});</strong>
-
-app.listen(3000, function() {
- console.log('Example app listening on port 3000!');
-});
-</pre>
-
-<p>שתי השורות הראשונות <code>require()</code> (מיבא) את מודול express ויוצר <a href="https://expressjs.com/en/4x/api.html#app">Express application</a>, אובייקט זה נקרא באופן מסורתי <code>app</code> זה מכיל מתודות לניתוב בקשות HTTP,</p>
-
-<p> configuring middleware, rendering HTML views, registering a template engine, and modifying <a href="https://expressjs.com/en/4x/api.html#app.settings.table">application settings</a> that control how the application behaves (e.g. the environment mode, whether route definitions are case sensitive, etc.)</p>
-
-<p>The middle part of the code (the three lines starting with <code>app.get</code>) shows a <em>route definition</em>. The <code>app.get()</code> method specifies a callback function that will be invoked whenever there is an HTTP <code>GET</code> request with a path (<code>'/'</code>) relative to the site root. The callback function takes a request and a response object as arguments, and simply calls <code><a href="https://expressjs.com/en/4x/api.html#res.send">send()</a></code> on the response to return the string "Hello World!"</p>
-
-<p>The final block starts up the server on port '3000' and prints a log comment to the console. With the server running, you could go to <code>localhost:3000</code> in your browser to see the example response returned.</p>
-
-<h3 id="ייבוא_ויצירת_מודלים">ייבוא ויצירת מודלים</h3>
-
-<p>A module is a JavaScript library/file that you can import into other code using Node's <code>require()</code> function. <em>Express</em> itself is a module, as are the middleware and database libraries that we use in our <em>Express</em> applications.</p>
-
-<p>The code below shows how we import a module by name, using the <em>Express</em> framework as an example. First we invoke the <code style="font-style: normal; font-weight: normal;">require()</code> function, specifying the name of the module as a string (<code>'express'</code>), and calling the returned object to create an <a href="https://expressjs.com/en/4x/api.html#app">Express application</a>. We can then access the properties and functions of the application object.</p>
-
-<pre class="brush: js notranslate">var express = require('express');
-var app = express();
-</pre>
-
-<p>You can also create your own modules that can be imported in the same way.</p>
-
-<div class="note">
-<p><strong>Tip:</strong> You will <em>want </em>to create your own modules, because this allows you to organise your code into managable parts — a monolithic single-file application is hard to understand and maintain. Using modules also helps you manage your namespace, because only the variables you explicitly export are imported when you use a module.</p>
-</div>
-
-<p>To make objects available outside of a module you just need to expose them as additional properties on the <code>exports</code> object. For example, the <strong>square.js</strong> module below is a file that exports <code>area()</code> and <code>perimeter()</code> methods:</p>
-
-<pre class="brush: js notranslate">exports.area = function(width) { return width * width; };
-exports.perimeter = function(width) { return 4 * width; };
-</pre>
-
-<p>We can import this module using <code>require()</code>, and then call the exported method(s) as shown:</p>
-
-<pre class="brush: js notranslate">var square = require('./square'); // Here we require() the name of the file without the (optional) .js file extension
-console.log('The area of a square with a width of 4 is ' + square.area(4));</pre>
-
-<div class="note">
-<p><strong>Note:</strong> You can also specify an absolute path to the module (or a name, as we did initially).</p>
-</div>
-
-<p>If you want to export a complete object in one assignment instead of building it one property at a time, assign it to <code>module.exports</code> as shown below (you can also do this to make the root of the exports object a constructor or other function):</p>
-
-<pre class="brush: js notranslate">module.exports = {
- area: function(width) {
- return width * width;
- },
-
- perimeter: function(width) {
- return 4 * width;
- }
-};
-</pre>
-
-<div class="note">
-<p><strong>Note:</strong> You can think of <code>exports</code> as a <a href="https://nodejs.org/api/modules.html#modules_exports_shortcut">shortcut</a> to <code>module.exports</code> within a given module. In fact, <code>exports</code> is just a variable that gets initialized to the value of <code>module.exports</code> before the module is evaluated. That value is a reference to an object (empty object in this case). This means that <code>exports</code> holds a reference to the same object referenced by <code>module.exports</code>. It also means that by assigning another value to <code>exports</code> it's no longer bound to <code>module.exports</code>.</p>
-</div>
-
-<p>For a lot more information about modules see <a href="https://nodejs.org/api/modules.html#modules_modules">Modules</a> (Node API docs).</p>
-
-<h3 id="Using_asynchronous_APIs">Using asynchronous APIs</h3>
-
-<p>JavaScript code frequently uses asynchronous rather than synchronous APIs for operations that may take some time to complete. A synchronous API is one in which each operation must complete before the next operation can start. For example, the following log functions are synchronous, and will print the text to the console in order (First, Second).</p>
-
-<pre class="brush: js notranslate">console.log('First');
-console.log('Second');
-</pre>
-
-<p>By contrast, an asynchronous API is one in which the API will start an operation and immediately return (before the operation is complete). Once the operation finishes, the API will use some mechanism to perform additional operations. For example, the code below will print out "Second, First" because even though <code>setTimeout()</code> method is called first, and returns immediately, the operation doesn't complete for several seconds.</p>
-
-<pre class="brush: js notranslate">setTimeout(function() {
- console.log('First');
- }, 3000);
-console.log('Second');
-</pre>
-
-<p>Using non-blocking asynchronous APIs is even more important on Node than in the browser because <em>Node</em> is a single-threaded event-driven execution environment. "Single threaded" means that all requests to the server are run on the same thread (rather than being spawned off into separate processes). This model is extremely efficient in terms of speed and server resources, but it does mean that if any of your functions call synchronous methods that take a long time to complete, they will block not just the current request, but every other request being handled by your web application.</p>
-
-<p>There are a number of ways for an asynchronous API to notify your application that it has completed. The most common way is to register a callback function when you invoke the asynchronous API, that will be called back when the operation completes. This is the approach used above.</p>
-
-<div class="note">
-<p><strong>Tip:</strong> Using callbacks can be quite "messy" if you have a sequence of dependent asynchronous operations that must be performed in order because this results in multiple levels of nested callbacks. This problem is commonly known as "callback hell". This problem can be reduced by good coding practices (see <a href="http://callbackhell.com/">http://callbackhell.com/</a>), using a module like <a href="https://www.npmjs.com/package/async">async</a>, or even moving to ES6 features like <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise">Promises</a>.</p>
-</div>
-
-<div class="note">
-<p><strong>Note:</strong> A common convention for Node and Express is to use error-first callbacks. In this convention, the first value in your <em>callback functions</em> is an error value, while subsequent arguments contain success data. There is a good explanation of why this approach is useful in this blog: <a href="http://fredkschott.com/post/2014/03/understanding-error-first-callbacks-in-node-js">The Node.js Way - Understanding Error-First Callbacks</a> (fredkschott.com).</p>
-</div>
-
-<h3 id="Creating_route_handlers">Creating route handlers</h3>
-
-<p>In our <em>Hello World</em> Express example (see above), we defined a (callback) route handler function for HTTP <code>GET</code> requests to the site root (<code>'/'</code>).</p>
-
-<pre class="brush: js notranslate">app.<strong>get</strong>('/', function(req, res) {
- res.send('Hello World!');
-});
-</pre>
-
-<p>The callback function takes a request and a response object as arguments. In this case, the method simply calls <code><a href="https://expressjs.com/en/4x/api.html#res.send">send()</a></code> on the response to return the string "Hello World!" There are a <a href="https://expressjs.com/en/guide/routing.html#response-methods">number of other response methods</a> for ending the request/response cycle, for example, you could call <code><a href="https://expressjs.com/en/4x/api.html#res.json">res.json()</a></code> to send a JSON response or <code><a href="https://expressjs.com/en/4x/api.html#res.sendFile">res.sendFile()</a></code> to send a file.</p>
-
-<div class="note">
-<p><strong>JavaScript tip:</strong> You can use any argument names you like in the callback functions; when the callback is invoked the first argument will always be the request and the second will always be the response. It makes sense to name them such that you can identify the object you're working with in the body of the callback.</p>
-</div>
-
-<p>The <em>Express application</em> object also provides methods to define route handlers for all the other HTTP verbs, which are mostly used in exactly the same way:</p>
-
-<p><code>checkout()</code>, <code>copy()</code>, <strong><code>delete()</code></strong>, <strong><code>get()</code></strong>, <code>head()</code>, <code>lock()</code>, <code>merge()</code>, <code>mkactivity()</code>, <code>mkcol()</code>, <code>move()</code>, <code>m-search()</code>, <code>notify()</code>, <code>options()</code>, <code>patch()</code>, <strong><code>post()</code></strong>, <code>purge()</code>, <strong><code>put()</code></strong>, <code>report()</code>, <code>search()</code>, <code>subscribe()</code>, <code>trace()</code>, <code>unlock()</code>, <code>unsubscribe()</code>.</p>
-
-<p>There is a special routing method, <code>app.all()</code>, which will be called in response to any HTTP method. This is used for loading middleware functions at a particular path for all request methods. The following example (from the Express documentation) shows a handler that will be executed for requests to <code>/secret</code> irrespective of the HTTP verb used (provided it is supported by the <a href="https://nodejs.org/api/http.html#http_http_methods">http module</a>).</p>
-
-<pre class="brush: js notranslate">app.all('/secret', function(req, res, next) {
- console.log('Accessing the secret section ...');
- next(); // pass control to the next handler
-});</pre>
-
-<p>Routes allow you to match particular patterns of characters in a URL, and extract some values from the URL and pass them as parameters to the route handler (as attributes of the request object passed as a parameter).</p>
-
-<p>Often it is useful to group route handlers for a particular part of a site together and access them using a common route-prefix (e.g. a site with a Wiki might have all wiki-related routes in one file and have them accessed with a route prefix of <em>/wiki/</em>). In <em>Express</em> this is achieved by using the <code><a href="http://expressjs.com/en/guide/routing.html#express-router">express.Router</a></code> object. For example, we can create our wiki route in a module named <strong>wiki.js</strong>, and then export the <code>Router</code> object, as shown below:</p>
-
-<pre class="brush: js notranslate">// wiki.js - Wiki route module
-
-var express = require('express');
-var router = express.Router();
-
-// Home page route
-router.get('/', function(req, res) {
- res.send('Wiki home page');
-});
-
-// About page route
-router.get('/about', function(req, res) {
- res.send('About this wiki');
-});
-
-module.exports = router;
-</pre>
-
-<div class="note">
-<p><strong>Note:</strong> Adding routes to the <code>Router</code> object is just like adding routes to the <code>app</code> object (as shown previously).</p>
-</div>
-
-<p>To use the router in our main app file we would then <code>require()</code> the route module (<strong>wiki.js</strong>), then call <code>use()</code> on the <em>Express</em> application to add the Router to the middleware handling path. The two routes will then be accessible from <code style="font-style: normal; font-weight: normal;">/wiki/</code> and <code style="font-style: normal; font-weight: normal;">/wiki/about/</code>.</p>
-
-<pre class="brush: js notranslate">var wiki = require('./wiki.js');
-// ...
-app.use('/wiki', wiki);</pre>
-
-<p>We'll show you a lot more about working with routes, and in particular about using the <code>Router</code>, later on in the linked section<a href="https://developer.mozilla.org/en-US/docs/Learn/Server-side/Express_Nodejs/routes"> Routes and controllers .</a></p>
-
-<h3 id="Using_middleware">Using middleware</h3>
-
-<p>Middleware is used extensively in Express apps, for tasks from serving static files to error handling, to compressing HTTP responses. Whereas route functions end the HTTP request-response cycle by returning some response to the HTTP client, middleware functions <em>typically</em> perform some operation on the request or response and then call the next function in the "stack", which might be more middleware or a route handler. The order in which middleware is called is up to the app developer.</p>
-
-<div class="note">
-<p><strong>Note:</strong> The middleware can perform any operation, execute any code, make changes to the request and response object, and it can<em> also end the request-response cycle</em>. If it does not end the cycle then it must call <code>next()</code> to pass control to the next middleware function (or the request will be left hanging).</p>
-</div>
-
-<p>Most apps will use <em>third-party</em> middleware in order to simplify common web development tasks like working with cookies, sessions, user authentication, accessing request <code>POST</code> and JSON data, logging, etc. You can find a <a href="http://expressjs.com/en/resources/middleware.html">list of middleware packages maintained by the Express team</a> (which also includes other popular 3rd party packages). Other Express packages are available on the NPM package manager.</p>
-
-<p>To use third party middleware you first need to install it into your app using NPM. For example, to install the <a href="http://expressjs.com/en/resources/middleware/morgan.html">morgan</a> HTTP request logger middleware, you'd do this:</p>
-
-<pre class="brush: bash notranslate"><code>$ npm install morgan
-</code></pre>
-
-<p>You could then call <code>use()</code> on the <em>Express application object</em> to add the middleware to the stack:</p>
-
-<pre class="brush: js notranslate">var express = require('express');
-<strong>var logger = require('morgan');</strong>
-var app = express();
-<strong>app.use(logger('dev'));</strong>
-...</pre>
-
-<div class="note">
-<p><strong>Note:</strong> Middleware and routing functions are called in the order that they are declared. For some middleware the order is important (for example if session middleware depends on cookie middleware, then the cookie handler must be added first). It is almost always the case that middleware is called before setting routes, or your route handlers will not have access to functionality added by your middleware.</p>
-</div>
-
-<p>You can write your own middleware functions, and you are likely to have to do so (if only to create error handling code). The <strong>only</strong> difference between a middleware function and a route handler callback is that middleware functions have a third argument <code>next</code>, which middleware functions are expected to call if they are not that which completes the request cycle (when the middleware function is called, this contains the <em>next</em> function that must be called).</p>
-
-<p>You can add a middleware function to the processing chain with either <code>app.use()</code> or <code>app.add()</code>, depending on whether you want to apply the middleware to all responses or to responses with a particular HTTP verb (<code>GET</code>, <code>POST</code>, etc). You specify routes the same in both cases, though the route is optional when calling <code>app.use()</code>.</p>
-
-<p>The example below shows how you can add the middleware function using both methods, and with/without a route.</p>
-
-<pre class="brush: js notranslate">var express = require('express');
-var app = express();
-
-// An example middleware function
-var a_middleware_function = function(req, res, <em>next</em>) {
-  // ... perform some operations
-  next(); // Call next() so Express will call the next middleware function in the chain.
-}
-
-// Function added with use() for all routes and verbs
-app.use(a_middleware_function);
-
-// Function added with use() for a specific route
-app.use('/someroute', a_middleware_function);
-
-// A middleware function added for a specific HTTP verb and route
-app.get('/', a_middleware_function);
-
-app.listen(3000);</pre>
-
-<div class="note">
-<p><strong>JavaScript Tip:</strong> Above we declare the middleware function separately and then set it as the callback. In our previous route handler function we declared the callback function when it was used. In JavaScript, either approach is valid.</p>
-</div>
-
-<p>The Express documentation has a lot more excellent documentation about <a href="https://expressjs.com/en/guide/using-middleware.html">using</a> and <a href="http://expressjs.com/en/guide/writing-middleware.html">writing</a> Express middleware.</p>
-
-<h3 id="Serving_static_files">Serving static files</h3>
-
-<p>You can use the <a href="http://expressjs.com/en/4x/api.html#express.static">express.static</a> middleware to serve static files, including your images, CSS and JavaScript (<code>static()</code> is the only middleware function that is actually <strong>part</strong> of <em>Express</em>). For example, you would use the line below to serve images, CSS files, and JavaScript files from a directory named '<strong>public'</strong> at the same level as where you call node:</p>
-
-<pre class="brush: js notranslate">app.use(express.static('public'));
-</pre>
-
-<p>Any files in the public directory are served by adding their filename (<em>relative</em> to the base "public" directory) to the base URL. So for example:</p>
-
-<pre class="notranslate"><code>http://localhost:3000/images/dog.jpg
-http://localhost:3000/css/style.css
-http://localhost:3000/js/app.js
-http://localhost:3000/about.html
-</code></pre>
-
-<p>You can call <code>static()</code> multiple times to serve multiple directories. If a file cannot be found by one middleware function then it will simply be passed on to the subsequent middleware (the order that middleware is called is based on your declaration order).</p>
-
-<pre class="brush: js notranslate">app.use(express.static('public'));
-app.use(express.static('media'));
-</pre>
-
-<p>You can also create a virtual prefix for your static URLs, rather than having the files added to the base URL. For example, here we <a href="http://expressjs.com/en/4x/api.html#app.use">specify a mount path</a> so that the files are loaded with the prefix "/media":</p>
-
-<pre class="brush: js notranslate">app.use('/media', express.static('public'));
-</pre>
-
-<p>Now, you can load the files that are in the <code>public</code> directory from the <code>/media</code> path prefix.</p>
-
-<pre class="notranslate"><code>http://localhost:3000/media/images/dog.jpg
-http://localhost:3000/media/video/cat.mp4
-http://localhost:3000/media/cry.mp3</code>
-</pre>
-
-<div class="blockIndicator note">
-<p><strong>Note</strong>: See also <a href="https://expressjs.com/en/starter/static-files.html">Serving static files in Express</a>.</p>
-</div>
-
-<h3 id="Handling_errors">Handling errors</h3>
-
-<p>Errors are handled by one or more special middleware functions that have four arguments, instead of the usual three: <code>(err, req, res, next)</code>. For example:</p>
-
-<pre class="brush: js notranslate">app.use(function(err, req, res, next) {
- console.error(err.stack);
- res.status(500).send('Something broke!');
-});
-</pre>
-
-<p>These can return any content required, but must be called after all other <code>app.use()</code> and routes calls so that they are the last middleware in the request handling process!</p>
-
-<p>Express comes with a built-in error handler, which takes care of any remaining errors that might be encountered in the app. This default error-handling middleware function is added at the end of the middleware function stack. If you pass an error to <code>next()</code> and you do not handle it in an error handler, it will be handled by the built-in error handler; the error will be written to the client with the stack trace.</p>
-
-<div class="note">
-<p><strong>Note:</strong> The stack trace is not included in the production environment. To run it in production mode you need to set the environment variable <code>NODE_ENV</code> to '<code>production'</code>.</p>
-</div>
-
-<div class="note">
-<p><strong>Note:</strong> HTTP404 and other "error" status codes are not treated as errors. If you want to handle these, you can add a middleware function to do so. For more information see the <a href="http://expressjs.com/en/starter/faq.html#how-do-i-handle-404-responses">FAQ</a>.</p>
-</div>
-
-<p>For more information see <a href="http://expressjs.com/en/guide/error-handling.html">Error handling</a> (Express docs).</p>
-
-<h3 id="Using_databases">Using databases</h3>
-
-<p><em>Express</em> apps can use any database mechanism supported by <em>Node</em> (<em>Express</em> itself doesn't define any specific additional behaviour/requirements for database management). There are many options, including PostgreSQL, MySQL, Redis, SQLite, MongoDB, etc.</p>
-
-<p>In order to use these you have to first install the database driver using NPM. For example, to install the driver for the popular NoSQL MongoDB you would use the command:</p>
-
-<pre class="brush: bash notranslate"><code>$ npm install mongodb
-</code></pre>
-
-<p>The database itself can be installed locally or on a cloud server. In your Express code you require the driver, connect to the database, and then perform create, read, update, and delete (CRUD) operations. The example below (from the Express documentation) shows how you can find "mammal" records using MongoDB.</p>
-
-<pre class="brush: js notranslate">//this works with older versions of mongodb version ~ 2.2.33
-var MongoClient = require('mongodb').MongoClient;
-
-MongoClient.connect('mongodb://localhost:27017/animals', function(err, db) {
- if (err) throw err;
-
- db.collection('mammals').find().toArray(function (err, result) {
- if (err) throw err;
-
- console.log(result);
- });
-});
-
-
-//for mongodb version 3.0 and up
-let MongoClient = require('mongodb').MongoClient;
-MongoClient.connect('mongodb://localhost:27017/animals', function(err, client){
- if(err) throw err;
-
-  let db = client.db('animals');
-  db.collection('mammals').find().toArray(function(err, result){
- if(err) throw err;
-  console.log(result);
-  client.close();
-  });
-});
-</pre>
-
-<p>Another popular approach is to access your database indirectly, via an Object Relational Mapper ("ORM"). In this approach you define your data as "objects" or "models" and the ORM maps these through to the underlying database format. This approach has the benefit that as a developer you can continue to think in terms of JavaScript objects rather than database semantics, and that there is an obvious place to perform validation and checking of incoming data. We'll talk more about databases in a later article.</p>
-
-<p>For more information see <a href="https://expressjs.com/en/guide/database-integration.html">Database integration</a> (Express docs).</p>
-
-<h3 id="Rendering_data_views">Rendering data (views)</h3>
-
-<p>Template engines (referred to as "view engines" by <em>Express</em>) allow you to specify the <em>structure</em> of an output document in a template, using placeholders for data that will be filled in when a page is generated. Templates are often used to create HTML, but can also create other types of documents. Express has support for <a href="https://github.com/expressjs/express/wiki#template-engines">a number of template engines</a>, and there is a useful comparison of the more popular engines here: <a href="https://strongloop.com/strongblog/compare-javascript-templates-jade-mustache-dust/">Comparing JavaScript Templating Engines: Jade, Mustache, Dust and More</a>.</p>
-
-<p>In your application settings code you set the template engine to use and the location where Express should look for templates using the 'views' and 'view engines' settings, as shown below (you will also have to install the package containing your template library too!)</p>
-
-<pre class="brush: js notranslate">const express = require('express');
-const path = require('path');
-const app = express();
-
-// Set directory to contain the templates ('views')
-app.set('views', path.join(__dirname, 'views'));
-
-// Set view engine to use, in this case 'some_template_engine_name'
-app.set('view engine', 'some_template_engine_name');
-</pre>
-
-<p>The appearance of the template will depend on what engine you use. Assuming that you have a template file named "index.&lt;template_extension&gt;" that contains placeholders for data variables named 'title' and "message", you would call <code><a href="http://expressjs.com/en/4x/api.html#res.render">Response.render()</a></code> in a route handler function to create and send the HTML response:</p>
-
-<pre class="brush: js notranslate">app.get('/', function(req, res) {
- res.render('index', { title: 'About dogs', message: 'Dogs rock!' });
-});</pre>
-
-<p>For more information see <a href="http://expressjs.com/en/guide/using-template-engines.html">Using template engines with Express</a> (Express docs).</p>
-
-<h3 id="File_structure">File structure</h3>
-
-<p>Express makes no assumptions in terms of structure or what components you use. Routes, views, static files, and other application-specific logic can live in any number of files with any directory structure. While it is perfectly possible to have the whole <em>Express</em> application in one file, typically it makes sense to split your application into files based on function (e.g. account management, blogs, discussion boards) and architectural problem domain (e.g. model, view or controller if you happen to be using an <a href="/en-US/docs/Glossary/MVC">MVC architecture</a>).</p>
-
-<p>In a later topic we'll use the <em>Express Application Generator</em>, which creates a modular app skeleton that we can easily extend for creating web applications.</p>
-
-<ul>
-</ul>
-
-<h2 id="Summary">Summary</h2>
-
-<p>Congratulations, you've completed the first step in your Express/Node journey! You should now understand Express and Node's main benefits, and roughly what the main parts of an Express app might look like (routes, middleware, error handling, and template code). You should also understand that with Express being an unopinionated framework, the way you pull these parts together and the libraries that you use are largely up to you!</p>
-
-<p>Of course Express is deliberately a very lightweight web application framework, so much of its benefit and potential comes from third party libraries and features. We'll look at those in more detail in the following articles. In our next article we're going to look at setting up a Node development environment, so that you can start seeing some Express code in action.</p>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li><a href="https://medium.com/@ramsunvtech/manage-multiple-node-versions-e3245d5ede44">Venkat.R - Manage Multiple Node versions</a></li>
- <li><a href="https://nodejs.org/api/modules.html#modules_modules">Modules</a> (Node API docs)</li>
- <li><a href="https://expressjs.com/">Express</a> (home page)</li>
- <li><a href="http://expressjs.com/en/starter/basic-routing.html">Basic routing</a> (Express docs)</li>
- <li><a href="http://expressjs.com/en/guide/routing.html">Routing guide</a> (Express docs)</li>
- <li><a href="http://expressjs.com/en/guide/using-template-engines.html">Using template engines with Express</a> (Express docs)</li>
- <li><a href="https://expressjs.com/en/guide/using-middleware.html">Using middleware</a> (Express docs)</li>
- <li><a href="http://expressjs.com/en/guide/writing-middleware.html">Writing middleware for use in Express apps</a> (Express docs)</li>
- <li><a href="https://expressjs.com/en/guide/database-integration.html">Database integration</a> (Express docs)</li>
- <li><a href="http://expressjs.com/en/starter/static-files.html">Serving static files in Express</a> (Express docs)</li>
- <li><a href="http://expressjs.com/en/guide/error-handling.html">Error handling</a> (Express docs)</li>
-</ul>
-
-<div>{{NextMenu("Learn/Server-side/Express_Nodejs/development_environment", "Learn/Server-side/Express_Nodejs")}}</div>
-
-<h2 id="In_this_module">In this module</h2>
-
-<ul>
- <li><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/Introduction">Express/Node introduction</a></li>
- <li><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/development_environment">Setting up a Node (Express) development environment</a></li>
- <li><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/Tutorial_local_library_website">Express Tutorial: The Local Library website</a></li>
- <li><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/skeleton_website">Express Tutorial Part 2: Creating a skeleton website</a></li>
- <li><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/mongoose">Express Tutorial Part 3: Using a Database (with Mongoose)</a></li>
- <li><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/routes">Express Tutorial Part 4: Routes and controllers</a></li>
- <li><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/Displaying_data">Express Tutorial Part 5: Displaying library data</a></li>
- <li><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/forms">Express Tutorial Part 6: Working with forms</a></li>
- <li><a href="/en-US/docs/Learn/Server-side/Express_Nodejs/deployment">Express Tutorial Part 7: Deploying to production</a></li>
-</ul>
diff --git a/files/he/learn/server-side/index.html b/files/he/learn/server-side/index.html
deleted file mode 100644
index 9816a95427..0000000000
--- a/files/he/learn/server-side/index.html
+++ /dev/null
@@ -1,50 +0,0 @@
----
-title: תכנות אתרים בצד שרת
-slug: Learn/Server-side
-translation_of: Learn/Server-side
----
-<div>ת{{LearnSidebar}}</div>
-
-<p class="summary">The <strong><em>Dynamic Websites </em></strong>–<em><strong> Server-side programming</strong></em> topic is a series of modules that show how to create dynamic websites; websites that deliver customised information in response to HTTP requests. The modules provide a general introduction to server-side programming, along with specific beginner-level guides on how to use the Django (Python) and Express (Node.js/JavaScript) web frameworks to create basic applications.</p>
-
-<p>Most major websites use some kind of server-side technology to dynamically display data as required. For example, imagine how many products are available on Amazon, and imagine how many posts have been written on Facebook. Displaying all of these using different static pages would be extremely inefficient, so instead such sites display static templates (built using <a href="/en-US/docs/Learn/HTML">HTML</a>, <a href="/en-US/docs/Learn/CSS">CSS</a>, and <a href="/en-US/docs/Learn/JavaScript">JavaScript</a>), and then dynamically update the data displayed inside those templates when needed, such as when you want to view a different product on Amazon.</p>
-
-<p>In the modern world of web development, learning about server-side development is highly recommended.</p>
-
-<h2 id="מסלול_למידה">מסלול למידה</h2>
-
-<p>תחילת הדרך עם תכנות בצד שרת זה בדרך כלל קל יותר מאשר תכנות בצד לקוח. בגלל שאתרים דינמיים לרוב מבצעים הרבה פעולות דומות מאוד (אחזור מידע ממסד נתונים והצגתם בעמוד, אימות נתונים שהוזנו ע"י משתמש ושמירתם במסד נתונים, בדיקת הרשאות משתמש וכניסת משתמש וכו') ונבנים באמצעות מסגרות אינטרנט (frameworks) המקלות על פעולות אלה ושאר שרתי האינטרנט הנפוצים.</p>
-
-<p>Basic knowledge of programming concepts (or of a particular programming language) is useful, but not essential. Similarly, expertise in client-side coding is not required, but a basic knowledge will help you work better with the developers creating your client-side web "front end".</p>
-
-<p>תצטרך להבין "כיצד הרשת עובדת". אנו ממליצים שקודם תקרא את הנושאים הבאים: </p>
-
-<ul>
- <li><a href="https://wiki.developer.mozilla.org/en-US/docs/Learn/Common_questions/What_is_a_web_server">מה זה שרת אינטרנט?</a></li>
- <li><a href="https://wiki.developer.mozilla.org/en-US/docs/Learn/Common_questions/What_software_do_I_need">באיזה תוכנה אני צריך להשתמש על מנת לבנות אתר?</a></li>
- <li><a href="https://wiki.developer.mozilla.org/en-US/docs/Learn/Common_questions/Upload_files_to_a_web_server">איך להעלות קובץ לשרת?</a></li>
-</ul>
-
-<p>With that basic understanding, you'll be ready to work your way through the modules in this section. </p>
-
-<h2 id="מודולים">מודולים</h2>
-
-<p>This topic contains the following modules. You should start with the first module, then go on to one of the following modules, which show how to work with two very popular server-side languages using appropriate web frameworks. </p>
-
-<dl>
- <dt><a href="/en-US/docs/Learn/Server-side/First_steps">Server-side website programming first steps</a></dt>
- <dd>This module provides technology-agnostic information about server-side website programming such as "what is it?", "how does it differ from client-side programming?", and "why is it useful?". This module also outlines some of the more popular server-side web frameworks and gives guidance on how to select the best one for your site. Lastly, an introduction to web server security is provided.</dd>
- <dt><a href="/en-US/docs/Learn/Server-side/Django">Django Web Framework (Python)</a></dt>
- <dd>Django is an extremely popular and fully featured server-side web framework, written in Python. The module explains why Django is such a good web server framework, how to set up a development environment and how to perform common tasks with it.</dd>
- <dt><a href="/en-US/docs/Learn/Server-side/Express_Nodejs">Express Web Framework (Node.js/JavaScript)</a></dt>
- <dd>Express is a popular web framework, written in JavaScript and hosted within the node.js runtime environment. The module explains some of the key benefits of this framework, how to set up your development environment and how to perform common web development and deployment tasks.</dd>
-</dl>
-
-<h2 id="ראה_עוד">ראה עוד</h2>
-
-<dl>
- <dt><a href="/en-US/docs/Learn/Server-side/Node_server_without_framework">Node server without framework</a></dt>
- <dd>This article provides a simple static file server built with pure Node.js, for those of you not wanting to use a framework.</dd>
- <dt><a href="/en-US/docs/Learn/Server-side/Configuring_server_MIME_types">Properly configuring server MIME types</a></dt>
- <dd>Configuring your server to send the correct {{Glossary("MIME types")}} (also known as media types or content types) to browsers is important for browsers to be able to properly process and display the content. It is also important to prevent malicious content from masquerading as benign content.</dd>
-</dl>
diff --git a/files/he/mdn/contribute/getting_started/index.html b/files/he/mdn/contribute/getting_started/index.html
deleted file mode 100644
index 4dd16bb2f1..0000000000
--- a/files/he/mdn/contribute/getting_started/index.html
+++ /dev/null
@@ -1,131 +0,0 @@
----
-title: יוצאים לדרך עם MDN
-slug: MDN/Contribute/Getting_started
-tags:
- - למתחילים
- - מבוא
- - מדריך
-translation_of: MDN/Contribute/Getting_started
----
-<div>{{MDNSidebar}}</div>
-
-<p id="What_is_MDN.3F" style="direction: rtl;">אנחנו קהילה פתוחה של מפתחים הבונים מקורות לאינטרנט טוב יותר, בלי חשיבות למותג, דפדפן, או פלטפורמה. כל אחד יכול לתרום וכל אדם הבוחר לעשות זאת מחזק אותנו. יחד אנחנו יכולים להמשיך לתמוך בחדשנות באינטרנט לשרת את טובת הכלל. זה מתחיל כאן, זה מתחיל אתך.</p>
-
-<p style="direction: rtl;">כל חלק ב-MDN (החל מהקוד שמפעיל את האתר הזה ועד לתיעוד, הדוגמאות וההדגמות) נוצר על ידי קהילה של מפתחים וכותבים. לכל אחד יש מה להציע, ואנחנו מקווים שתצטרף אלינו!</p>
-
-<h2 id="3_שלבים_פשוטים_אל_MDN" style="direction: rtl;"><span>3 שלבים פשוטים אל MDN</span></h2>
-
-<p style="direction: rtl;"><span class="seoSummary">MDN היא ויקי בה <strong>כל אחד</strong> יכול להוסיף ולערוך תוכן. אתה לא צריך להיות מתכנת או לדעת הרבה על טכנולוגיות. ישנם הרבה דברים שניתן לעשות, החל מהפשוטים (הגהה ותיקון טעויות הקלדה) ועד למורכבים (כתיבת תיעוד API).</span></p>
-
-<p style="direction: rtl;">התרומה היא פשוטה ובטוחה. אפילו אם אתה עושה טעות, ניתן לתקן אותה בקלות; אם אינך יודע איך בדיוק דברים צריכים להראות, או שהדקדוק שלך אינו כל-כך נהדר, אל תדאג! יש לנו צוות של אנשים שהתפקיד שלהם הוא להבטיח שהתכנים של MDN הם טובים ככל הניתן. יהיה מישהו שיבדוק שהעבודה שלך נקייה וכתובה היטב. שתף את מה שאתה יודע ודע את החזקות שלך, ובטח ששאר הקהילה תעזור להפוך את העבודה שלך להיות טובה אף יותר.</p>
-
-<h3 id="צעד_1_צור_חשבון_ב-MDN" style="direction: rtl;">צעד 1: צור חשבון ב-MDN</h3>
-
-<p style="direction: rtl;">כדי להתחיל לתרום ל-MDN, תחילה יש ליצור חשבון ב-MDN, לפרטים ראה <a href="/he/docs/MDN/Contribute/Howto/Create_an_MDN_account">איך ליצור חשבון</a>.</p>
-
-<h3 id="צעד_2_בחר_מטלה_להשלים" style="direction: rtl;">צעד 2: בחר מטלה להשלים</h3>
-
-<p style="direction: rtl;">עכשיו כשאתה מחובר, קרא את התיאורים של סוגי המטלות השונים ב{{anch("סוגי מטלות אפשריות", "רשימה מטה")}}, והחלט מה מהם מתאים לך. אתה יכול לבחור כל מטלה שתרצה ולהתחיל את התרומה שלך.</p>
-
-<h3 id="צעד_3_בצע_את_המטלה" style="direction: rtl;">צעד 3: בצע את המטלה</h3>
-
-<p style="direction: rtl;">ברגע שהחלטת איזה סוג מטלה אתה רוצה לעשות, בחר עמוד ספציפי, דוגמת קוד וכו' לעבוד עליו, ופשוט עשה זאת!</p>
-
-<p style="direction: rtl;">אל תדאג לגבי השלמת המשימה באופן מושלם; מתנדבי MDN אחרים כאן כדי לעזור לך לתקן טעויות שהשתרבבו פנימה. אם יש לך שאלות בעיצומה של מטלה, ראה את דף ה<a href="/he/docs/MDN/Community">קהילה</a> למידע על רשימות תפוצה וערוצי צ'אט בהם תוכל לקבל תשובות.</p>
-
-<div class="note">
-<p style="direction: rtl;"><strong>הערה: </strong>אם אתה רוצה להתנסות עם עריכה ב-MDN לפני שאתה עושה משהו "על אמת", יש לנו עמוד  <strong><a href="/he/docs/Sandbox">ארגז-חול</a></strong> בו ניתן לשחק. אנא הגבל את התנסויותך לעמוד זה. אנא אל תעשה שינויים לא-הכרחיים לעמודי תוכן רק כדי לראות מה קורה; זה רק יגרום לבלאגן שאחרים יצטרכו לנקות אחריך.</p>
-</div>
-
-<p style="direction: rtl;">כאשר סיימת עם המטלה שבחרת, הרגש חופשי לבחור דבר אחר, או ראה מטה <a href="#Other_things_you_can_do_on_MDN">דברים אחרים שאתה יכול לעשות ב-MDN</a>.</p>
-
-<h2 id="סוגי_מטלות_אפשריות" style="direction: rtl;">סוגי מטלות אפשריות</h2>
-
-<p style="direction: rtl;">ישנם דרכים רבות בהן תוכל לתרום ל-MDN, בהתאם לכישורים ולתחומי העניין שלך. אפילו שחלק מהמשימות עלולות להרתיע, יש לנו גם הרבה פעולות פשוטות זמינות. רבות מהן מצריכות רק חמש דקות (או פחות!) מזמנך. ביחד עם המטלות ותיאורן הקצר, תמצא את פרק הזמן המוערך שכל מטלה בדרך-כלל לוקחת.</p>
-
-<h3 id="אפשרות_1_אני_אוהב_מילים" style="direction: rtl;">אפשרות 1: אני אוהב מילים</h3>
-
-<p style="direction: rtl;">אתה יכול לעזור לנו לסקור או לערוך מסמכים קיימים, ולהצמיד תיוגים מתאימים עבורם.</p>
-
-<ul dir="rtl">
- <li style="direction: rtl;"><a href="/he/docs/MDN/Contribute/Howto/Set_the_summary_for_a_page">קבע סיכום לעמוד</a> (5-15 דקות)</li>
- <li><a href="/he/docs/MDN/Contribute/Howto/Do_an_editorial_review">סקירת ערכים</a> (5–30 דקות)</li>
- <li><a href="/he/docs/MDN/User_guide/Writing#Editing_an_existing_page">עדכון ערך קיים בעקבות מידע חדש</a> (5 דקות-1 שעה)</li>
- <li><a href="/he/docs/Project:MDN/Contributing/How_to/Write_a_new_entry_in_the_Glossary">כתוב ערך חדש במונחון</a> (15 דקות-1 שעה)</li>
- <li><a href="/he/docs/MDN/User_guide/Writing#Adding_a_new_page">כתוב מאמר אודות טכנולוגיה חדשה או API</a> (30 דקות-2 שעות)</li>
- <li><a href="/he/docs/Project:MDN/Contributing/How_to/Write_an_article_to_help_learning_the_web">כתוב מאמר לעזור לאנשים ללמוד אודות האינטרנט</a> (1-3 שעות)</li>
-</ul>
-
-<div class="note" style="direction: rtl;"><strong>הערה: </strong>אם אתה מסקר מאמרים או כותב מאמרים חדשים, אנו מבקשים שתעבור קודם כל על <a href="/he/docs/MDN/Contribute/Content/Style_guide">מדריך הסגנון</a>. זה יעזור להבטיח שהמאמרים עקביים.</div>
-
-<h3 id="אפשרות_2_אני_אוהב_קוד" style="direction: rtl;">אפשרות 2: אני אוהב קוד</h3>
-
-<p style="direction: rtl;">אנחנו זקוקים לעוד דוגמאות קוד! אתה גם יכול לעזור לבנות את פלטפורמת האתר שלנו, <a href="https://developer.mozilla.org/he/docs/MDN/Kuma">כומא</a>!</p>
-
-<ul dir="rtl">
- <li><a href="/he/docs/MDN/Contribute/Howto/Convert_code_samples_to_be_live">הפוך דוגמאות קוד להיות "חיות"</a> (30 דקות)</li>
- <li><a href="http://kuma.readthedocs.org/en/latest/installation.html">הקם סביבת עבודה לכומא</a> (1 שעה)</li>
- <li><a href="https://github.com/mozilla/kuma#readme">שלח טלאי קוד לבסיס הקוד של כומא</a> (1 שעה)</li>
- <li><a href="https://developer.mozilla.org/he/demos/submit">שלח הדגמה חדשה </a>(1 שעה)</li>
-</ul>
-
-<h3 id="אפשרות_3_אני_אוהב_גם_מילים_וגם_קוד" style="direction: rtl;">אפשרות 3: אני אוהב גם מילים וגם קוד</h3>
-
-<p style="direction: rtl;">יש לנו מטלות שדורשות גם כישורים טכניים וגם כישורי שפה, כמו כתיבת מאמרים חדשים, סיקור דיוק טכני, או התאמת מסמכים.</p>
-
-<ul dir="rtl">
- <li><a href="/he/docs/MDN/Contribute/Howto/Tag_JavaScript_pages">תייג דפי JavaScript</a> (5 דקות)</li>
- <li><a href="/he/docs/MDN/Promote">קדם את MDN באתר שלך</a> (5 דקות)</li>
- <li><a href="/he/docs/MDN/Contribute/Howto/Do_a_technical_review">סקירות טכניות</a> (30 דקות)</li>
- <li><a href="/he/docs/MDN/Contribute/Howto/Create_and_edit_pages">כתוב מאמר חדש בנושא בו אתה בקיא</a> (1 שעה או יותר)</li>
- <li><a href="/he/docs/MDN/Contribute/Howto/Create_an_interactive_exercise_to_help_learning_the_web">צור תרגיל אינטראקטיבי לעזור לאנשים ללמוד על האינטרנט</a> (1 שעה או יותר)</li>
- <li><a href="/he/docs/MDN/Contribute/Howto/Resolve_a_mentored_developer_doc_request">תקן שגיאת תיעוד</a> ב<a href="http://www.joshmatthews.net/bugsahoy/?mdn=1">קטגורית MDN ב- Bugs Ahoy</a> (1 שעה או יותר)</li>
-</ul>
-
-<h3 id="אפשרות_4_אני_רוצה_את_MDN_בשפה_שלי" style="direction: rtl;">אפשרות 4: אני רוצה את MDN בשפה שלי</h3>
-
-<p style="direction: rtl;">כל עבודות הלוקליזציה והתרגום שנעשו ב- MDN, נעשו על ידי הקהילת המתנדבים המדהימה שלנו.</p>
-
-<ul dir="rtl">
- <li><a href="/he/docs/MDN/Contribute/Localize/Translating_pages">תרגום עמודים</a> (שעתיים)</li>
- <li>התחבר עם לוקלייזרים אחרים הרשומים ב<a href="/he/docs/MDN/Contribute/Localize/Localization_projects">פרויקטי לוקליזציה</a> (30 דקות)</li>
-</ul>
-
-<h3 id="אפשרות_5_מצאתי_מידע_שגוי_אבל_אני_לא_יודע_כיצד_לתקנו" style="direction: rtl;">אפשרות 5: מצאתי מידע שגוי אבל אני לא יודע כיצד לתקנו</h3>
-
-<p style="direction: rtl;">אתה יכול לדווח על בעיות על ידי <a class="external" href="https://bugzilla.mozilla.org/enter_bug.cgi?product=Mozilla%20Developer%20Network">דיווח על באג בתיעוד</a>. (5 דקות)</p>
-
-<p style="direction: rtl;">השתמש בערכי השדות הללו:</p>
-
-<table class="standard-table" dir="rtl">
- <tbody>
- <tr>
- <td><strong>שדה באגזילה</strong></td>
- <td><strong>ערך</strong></td>
- </tr>
- <tr>
- <td><code>מוצר</code></td>
- <td><a href="https://bugzilla.mozilla.org/enter_bug.cgi?product=Developer+Documentation">תיעוד מפתח</a></td>
- </tr>
- <tr>
- <td><code>מרכיב</code></td>
- <td>[בחר איזור מתאים לנושא, או "כללי" אם אתה לא בטוח או אתה לא מוצא אחד מתאים]</td>
- </tr>
- <tr>
- <td><code>URL</code></td>
- <td>העמוד בו מצאת את הבעיה</td>
- </tr>
- <tr>
- <td><code>תיאור</code></td>
- <td>ככל שאתה יודע או שיש לך זמן לתאר אודות הבעיה והמקום למצוא את המידע הנכון. זה עשוי לכלול אנשים ("דבר עם פלוני ועם אלמוני") כמו גם קישורים לאתרים.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="דברים_אחרים_שאתה_יכול_לעשות_ב-_MDN" style="direction: rtl;">דברים אחרים שאתה יכול לעשות ב- MDN</h2>
-
-<ul dir="rtl">
- <li><a href="/he/docs/MDN/Community">הצטרף לקהילת MDN</a>.</li>
- <li><a href="/he/profile">מלא את הפרופיל שלך</a> כדי שאחרים יוכלו לדעת יותר עליך.</li>
- <li>למד עוד על איך אפשר <a href="/he/docs/MDN/Contribute">לתרום ל- MDN</a>.</li>
-</ul>
diff --git a/files/he/mdn/contribute/howto/index.html b/files/he/mdn/contribute/howto/index.html
deleted file mode 100644
index 2d2e665e4f..0000000000
--- a/files/he/mdn/contribute/howto/index.html
+++ /dev/null
@@ -1,18 +0,0 @@
----
-title: 'MDN web docs: How-to guides'
-slug: MDN/Contribute/Howto
-tags:
- - Documentation
- - Guide
- - Howto
- - Landing
- - MDN Meta
- - NeedsTranslation
- - TopicStub
-translation_of: MDN/Contribute/Howto
----
-<div>{{MDNSidebar}}{{IncludeSubnav("/en-US/docs/MDN")}}</div>
-
-<p class="summary"><span class="seoSummary">These articles provide step-by-step guides to accomplishing specific goals when contributing to MDN.</span></p>
-
-<p>{{LandingPageListSubpages}}</p>
diff --git a/files/he/mdn/contribute/index.html b/files/he/mdn/contribute/index.html
deleted file mode 100644
index 283b36785b..0000000000
--- a/files/he/mdn/contribute/index.html
+++ /dev/null
@@ -1,66 +0,0 @@
----
-title: תורמים לMDN
-slug: MDN/Contribute
-translation_of: MDN/Contribute
----
-<div>{{MDNSidebar}}</div>
-
-<p style="direction: rtl;"><span class="seoSummary">ברוך הבא! העצם ביקורך בעמוד זה, לקחת את הצעד הראשון לעבר הפיכה למתנדב MDN. המדריכים הרשומים כאן מכסים את כל היבטי ההתנדבות בMDN, כולל מדריכי סגנון, מדריכים לשימוש העורך וכליו, ועוד. בבקשה ודא שקראת (ושאתה מקיים את) <a href="https://www.mozilla.org/en-US/about/legal/terms/mozilla/">תנאי מוזילה</a> לפני שאתה עורך או מוסיף עמודים חדשים.</span></p>
-
-<div class="row topicpage-table">
-<div class="section">
-<h2 id="מדריכים_למתנדב" style="direction: rtl;">מדריכים למתנדב</h2>
-
-<dl>
- <dt style="direction: rtl;"><a href="/he/docs/MDN/Getting_started">מתחילים</a></dt>
- <dd style="direction: rtl;">מדריך מהיר להתחיל ולעשות את התרומה הראשונה שלך.</dd>
- <dt style="direction: rtl;"><a href="/en-US/docs/MDN/Contribute/Style_guide">מדריך תוכן וסגנון</a></dt>
- <dd style="direction: rtl;">מדריך MDN לתוכן ולסגנון מספק פרטים אודות סגנון כתיבה, פריסת עמוד, וסגנונות תוכן, כך שהתוכן שאתה כותב יתאים לשאר התוכן של MDN.</dd>
- <dt style="direction: rtl;"><a href="/en-US/docs/MDN/Contribute/Editor">מדריך עורך</a></dt>
- <dd style="direction: rtl;">מדריך שלם לשימוש בעורך של MDN.</dd>
- <dt style="direction: rtl;"><a href="/en-US/docs/MDN/Contribute/Reviewing_articles">סיקור מאמרים</a></dt>
- <dd style="direction: rtl;">מדריך לביצוע סיקור עריכתי וטכני של תוכן מאמרים, לעזור לנו להבטיח שכל התוכן בMDN הוא שימושי וקריא ככל הניתן.</dd>
- <dt style="direction: rtl;"><a href="/en-US/docs/MDN/Contribute/Conventions">טרמינולוגיה וקונבנציות</a></dt>
- <dd style="direction: rtl;">מדריכי הטרמינולוגיה והקונבנציות שלנו מספקים מידע שאתה יכול להשתמש כדי להבטיח שאתה משתמש בטרמינולוגיה הנכונה כאשר אתה מתאר דברים.</dd>
- <dt style="direction: rtl;"><a href="/en-US/docs/MDN/Contribute/Community">עבודה עם קהילת MDN</a></dt>
- <dd style="direction: rtl;">מדריך לעבודה עם הקהילה שלנו, מציאת עזרה, ותקשורת עם האנשים עם התשובות לשאלות שעולות כאשר אתה מתנדב בMDN.</dd>
- <dt style="direction: rtl;"><a href="/en-US/docs/MDN/Contribute/FAQ">תשובות לשאלות נפוצות</a></dt>
- <dd style="direction: rtl;">טיפים ותשובות לשאלות הכי שכיחות אודות התרומה לMDN.</dd>
-</dl>
-
-<dl>
- <dt style="direction: rtl;"><a href="/en-US/docs/MDN/Kuma/Contributing">תרומה לכומא</a></dt>
- <dd style="direction: rtl;">מדריך לתרומה לפרויקט כומא. כומא הוא הפלטפורמה המפעילה את האתר של MDN.</dd>
-</dl>
-</div>
-
-<div class="section">
-<h2 id="איך_ל..." style="direction: rtl;">איך ל...</h2>
-
-<p style="direction: rtl;"><a href="/en-US/docs/MDN/Contribute/Howto">מדריכי ה'איך-ל'</a> שלנו מספקים הוראות צעד-אחר-צעד לעזור לך להשלים מטלות ספציפיות בתרומה לMDN.</p>
-
-<dl>
- <dt style="direction: rtl;"><a href="/en-US/docs/MDN/Contribute/Howto/Document_a_CSS_property">איך לתעד תכונת CSS</a></dt>
- <dd style="direction: rtl;">מדריך לכתיבת תיעוד של תכונות CSS. כל תיעוד תכונת CSS צריכה להתאים לסגנון ולפריסה המתוארת במאמר.</dd>
- <dt style="direction: rtl;">איך לתעד אלמנט HTML</dt>
- <dd style="direction: rtl;">המדריך הזה לתיעוד אלמנטי HTML יבטיח שהמסמכים שאתה כותב יתאימו לאחרים בMDN.</dd>
- <dt style="direction: rtl;"><a href="/en-US/docs/MDN/Contribute/Howto/Tag">איך לתייג עמודים כמו שצריך</a></dt>
- <dd style="direction: rtl;">המדריך לתיוג עמודים מספק מידע אודות הסטנדרטים שלנו לתיוג, כולל רשימות של תיוגים בעלי משמעות סטנדרטית בMDN. מעקב אחר מדריך זה יבטיח שהתוכן שלך מקוטלג כמו שצריך, שניתן לחפש בו בקלות יתרה, ושמנגנון מסנני החיפוש שלנו עובדים כמו שצריך עם המאמרים שלך.</dd>
- <dt style="direction: rtl;"><a href="/en-US/docs/MDN/Contribute/Howto/Interpret_specifications">איך לפרש ספסיפיקציות</a></dt>
- <dd style="direction: rtl;">מדריך זה יעזור לך לפרש כמו שצריך ספסיפיקציות אינטרנט סטנדרטיות כמו שצריך; להיות מסוגל לקרוא כאלו יכול לההפך למלאכת אומנות, ולדעת איך לעשות את זה יעזור לך להפיק תיעוד טוב יותר.</dd>
-</dl>
-
-<h2 id="לוקליזציה" style="direction: rtl;">לוקליזציה</h2>
-
-<dl>
- <dt style="direction: rtl;"><a href="/en-US/docs/MDN/Contribute/Localize/Tour">סיור לוקליזציה מודרך</a></dt>
- <dd style="direction: rtl;">סיור מודרך זה ילמד אותך לעשות לוקליזציה של תוכן בMDN.</dd>
- <dt style="direction: rtl;"><a href="/en-US/docs/MDN/Contribute/Localize/Guide">מדריך לוקליזציה</a></dt>
- <dd style="direction: rtl;">מדריך זה יספק לך נתוניםאודות תהליך הלוקליזציה של תוכן MDN.</dd>
- <dt style="direction: rtl;"><a href="/en-US/docs/MDN/Contribute/Localize/Localization_projects">פרויקטי לוקליזציה</a></dt>
- <dd style="direction: rtl;">מצא את פרויקט הלוקליזציה של השפה שלך—או אם אין כזה, למד איך ליצור אחד חדש!</dd>
-</dl>
-</div>
-</div>
-
-<p> </p>
diff --git a/files/he/mdn/index.html b/files/he/mdn/index.html
deleted file mode 100644
index 44c51fa647..0000000000
--- a/files/he/mdn/index.html
+++ /dev/null
@@ -1,18 +0,0 @@
----
-title: פרויקט MDN
-slug: MDN
-translation_of: MDN
----
-<div>{{MDNSidebar}}</div>
-
-<div dir="rtl">
-<p dir="rtl"> <strong>רשת הפיתוח של מוזילה</strong> (MDN) היא ויקי בה אנו מתעדים את האינטרנט החופשי, טכנולוגיות מוזילה, Firefox OS ונושאי פיתוח אחרים. כל אחד מוזמן להוסיף ולערוך תוכן. אתה לא צריך להיות מתכנת או לדעת הרבה על טכנולוגיה; ישנם הרבה משימות שונות שצריכות להתבצע, החל מהפשוטות (הגהה ותיקון טעויות הקלדה) ועד המורכבות (כתיבת תיעוד API).</p>
-
-<div class="summary" dir="rtl">
-<p>המטרה של פרויקט MDN היא לתעד את האינטרנט החופשי, טכנולוגיות מוזילה, ופרויקטי מוזילה. אנו מזמינים אתכם לעזור!</p>
-</div>
-
-<p dir="rtl">אנו זקוקים לעזרתך! זה קל. אל תדאג לגבי בקשת רשות או לגבי עשיית טעויות. מצד שני, בבקשה למד להכיר את <a href="/en-US/docs/MDN/Community" title="/en-US/docs/MDN/Community">קהילת MDN</a>; אנחנו כאן כדי לעזור! התיעוד שמטה אמור לעזור לך להתחיל, אבל אל תהסס להצטרף לדיון ב{{IRCLink("mdn")}}, ערוץ ה<a href="https://wiki.mozilla.org/IRC">IRC</a> שלנו.</p>
-
-<p dir="rtl"></p><ul class="card-grid"><li><span><a href="/he/docs/MDN/Getting_started"> מדריך למתחיל</a></span><p>האם אתה חדש בMDN ורוצה ללמוד איך לעזור להפוך אותה לטובה יותר? התחל כאן!</p></li><li><span><a href="/he/docs/MDN/Contribute"> אני משתמש מתקדם</a></span><p>קבל גישה למדריך המלא והמעמיק למתנדבי MDN כדי לדעת עוד ברגע שאתה מתחיל להרגיש יותר בנוח.</p></li><li><span><a href="/he/docs/MDN/Promote"> הפץ את הבשורה</a></span><p>אם אתה אוהב את MDN, עזור להפיץ את הבשורה! מצא אומנות, כלים ומדריכים כדי לקדם את MDN.</p></li></ul><p></p>
-</div>
diff --git a/files/he/mozilla/add-ons/index.html b/files/he/mozilla/add-ons/index.html
deleted file mode 100644
index ca718d6324..0000000000
--- a/files/he/mozilla/add-ons/index.html
+++ /dev/null
@@ -1,104 +0,0 @@
----
-title: Add-ons
-slug: Mozilla/Add-ons
-tags:
- - Add-ons
- - Extension
- - Extensions
- - Landing
- - Mozilla
- - NeedsTranslation
- - TopicStub
-translation_of: Mozilla/Add-ons
----
-<p><span class="seoSummary">Add-ons allow developers to extend and modify the functionality of Firefox.</span> They are written using standard Web technologies - JavaScript, HTML, and CSS - plus some dedicated JavaScript APIs.</p>
-
-<p>Among other things, an add-on could:</p>
-
-<ul>
- <li>Change the appearance or content of particular websites</li>
- <li>Modify the Firefox user interface</li>
- <li>Add new features to Firefox</li>
-</ul>
-
-<p>There are several types of add-ons, but the most common type are extensions.</p>
-
-<h2 id="Developing_extensions">Developing extensions</h2>
-
-<p>In the past, there were several toolsets for developing Firefox extensions, but as of November 2017, extensions must be built using <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions">WebExtensions APIs</a>. Other toolsets, such as overlay add-ons, bootstrapped add-ons, and the Add-on SDK, are no longer supported.</p>
-
-<p>If you are writing a new extension, use <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions">WebExtensions APIs</a>.</p>
-
-<p>Extensions written using WebExtensions APIs for Firefox are designed to be cross-browser compatible. In most cases, it will run in Chrome, Edge, and Opera with few if any changes. They are also fully compatible with multiprocess Firefox.<br>
- <br>
- <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Browser_support_for_JavaScript_APIs">See the APIs currently supported in Firefox and other browsers</a>. We're continuing to design and implement new APIs in response to developer needs.<br>
- <br>
- Most of the WebExtensions APIs are also available on Firefox for Android.</p>
-
-<h3 id="Migrate_an_existing_extension">Migrate an existing extension</h3>
-
-<p>If you maintain a legacy extension, such as an XUL overlay, bootstrapped, or Add-on SDK-based extension, you can still port it to use WebExtension APIs. There are some <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Porting_a_legacy_Firefox_add-on">porting resources on MDN</a>.</p>
-
-<p>For more information about transition support, please visit our <a href="//wiki.mozilla.org/Add-ons/developer/communication">wiki page.</a></p>
-
-<h2 id="Publishing_add-ons">Publishing add-ons</h2>
-
-<p><a href="https://addons.mozilla.org">Addons.mozilla.org</a>, commonly known as "AMO," is Mozilla's official site for developers to list add-ons, and for users to discover them. By uploading your add-on to AMO, you can participate in our community of users and creators and find an audience for your add-on.</p>
-
-<p>You are not required to list your add-on on AMO, but your add-on must be signed by Mozilla else users will not be able to install it.</p>
-
-<p>For an overview for the process of publishing your add-on see, <a href="/en-US/docs/Mozilla/Add-ons/Distribution">Signing and distributing your add-on</a>.</p>
-
-<h2 id="Other_types_of_add-ons">Other types of add-ons</h2>
-
-<p>In addition to extensions, there are a few other add-on types that allow users to customize Firefox. Those add-ons include:</p>
-
-<ul>
- <li>
- <p><a href="/en-US/docs/Web/OpenSearch">Search engine plugins</a> add new search engines to the browser's search bar.</p>
- </li>
- <li>
- <p><a href="/en-US/docs/Mozilla/Creating_a_spell_check_dictionary_add-on">User dictionaries</a> let you spell-check in different languages.</p>
- </li>
- <li>
- <p><a href="https://support.mozilla.org/kb/use-firefox-interface-other-languages-language-pack">Language packs</a> let you have more languages available for the user interface of Firefox. </p>
- </li>
-</ul>
-
-<h2 id="Contact_us">Contact us</h2>
-
-<p>You can use the links below to get help, keep up to date with news around add-ons and give us feedback.</p>
-
-<h3 id="Add-ons_forum">Add-ons forum</h3>
-
-<p>Use the <a href="https://discourse.mozilla.org/c/add-ons">Add-ons Discourse forum</a> to discuss all aspects of add-on development and to get help.</p>
-
-<h3 id="Mailing_lists">Mailing lists</h3>
-
-<p>Use the <strong>dev-addons</strong> list to discuss development of the add-ons ecosystem, including the development of the WebExtensions system and of AMO:</p>
-
-<ul>
- <li><a href="https://mail.mozilla.org/listinfo/dev-addons">dev-addons list info</a></li>
- <li><a href="https://mail.mozilla.org/pipermail/dev-addons/">dev-addons archives</a></li>
-</ul>
-
-<h3 id="IRC">IRC</h3>
-
-<p>If you're a fan of IRC (Internet Relay Chat), you can get in touch at:</p>
-
-<ul>
- <li><a href="irc://irc.mozilla.org/addons">#addons</a> (discussion of the add-ons ecosystem)</li>
- <li><a href="irc://irc.mozilla.org/webextensions">#webextensions</a> (discussion around the WebExtensions API in particular)</li>
-</ul>
-
-<h3 id="Report_problems">Report problems</h3>
-
-<h4 id="Security_vulnerabilities">Security vulnerabilities</h4>
-
-<p>If you discover a security vulnerability in an add-on, even if it is not hosted on a Mozilla site, let us know and we will work with the developer to correct the issue. Please report them <a href="http://www.mozilla.org/projects/security/security-bugs-policy.html">confidentially </a>in <a href="https://bugzilla.mozilla.org/enter_bug.cgi?product=addons.mozilla.org&amp;component=Add-on%20Security&amp;maketemplate=Add-on%20Security%20Bug&amp;bit-23=1&amp;rep_platform=All&amp;op_sys=All">Bugzilla </a>or by emailing <a href="mailto:amo-admins@mozilla.com">amo-admins@mozilla.com</a>.</p>
-
-<h4 id="Bugs_on_addons.mozilla.org_(AMO)">Bugs on addons.mozilla.org (AMO)</h4>
-
-<p>If you find a problem with the site, we'd love to fix it. Please <a href="https://github.com/mozilla/addons/issues/new">file a bug report </a>and include as much detail as possible.</p>
-
-<div>{{AddonSidebar}}</div>
diff --git a/files/he/mozilla/add-ons/webextensions/anatomy_of_a_webextension/index.html b/files/he/mozilla/add-ons/webextensions/anatomy_of_a_webextension/index.html
deleted file mode 100644
index 049dfbd389..0000000000
--- a/files/he/mozilla/add-ons/webextensions/anatomy_of_a_webextension/index.html
+++ /dev/null
@@ -1,144 +0,0 @@
----
-title: אנטומיה של הרחבה
-slug: Mozilla/Add-ons/WebExtensions/Anatomy_of_a_WebExtension
-translation_of: Mozilla/Add-ons/WebExtensions/Anatomy_of_a_WebExtension
----
-<div>{{AddonSidebar}}</div>
-
-<p>הרחבה מורכבת מאוסף של קבצים, ארוזים להפצה והתקנה. במאמר זה, נסקור במהירות את הקבצים העשויים להיות נוכחים בהרחבה.</p>
-
-<h2 id="manifest.json">manifest.json</h2>
-
-<p>זהו הקובץ היחיד שחייב להימצא בכל הרחבה הוא כולל מטאדאטה בסיסית כגון שם, גירסה וההרשאות הדרושות. הוא גם מספק מצביעים לקבצים אחרים בהרחבה.</p>
-
-<p>מניפסט זה יכול לכלול גם מצביעים לעוד מספר טיפוסי קבצים </p>
-
-<ul>
- <li><a href="https://wiki.developer.mozilla.org/he/docs/Mozilla/Add-ons/WebExtensions/Anatomy_of_a_WebExtension#%D7%AA%D7%A1%D7%A8%D7%99%D7%98%D7%99_%D7%A8%D7%A7%D7%A2">תסריטי רקע</a>: מימוש לוגיקה לטווח רחוק.</li>
- <li>צלמיות להרחבות ולכל הכפתורים שיוגדרו. .</li>
- <li><a href="https://wiki.developer.mozilla.org/he/docs/Mozilla/Add-ons/WebExtensions/Anatomy_of_a_WebExtension#%D7%A1%D7%A8%D7%92%D7%9C%D7%99%D7%9D_%D7%A6%D7%93%D7%93%D7%99%D7%99%D7%9D_%D7%97%D7%9C%D7%95%D7%A0%D7%95%D7%AA_%D7%A7%D7%95%D7%A4%D7%A6%D7%99%D7%9D_%D7%93%D7%A4%D7%99_%D7%90%D7%95%D7%A4%D7%A6%D7%99%D7%95%D7%AA">סרגלים צדדיים, חלונות קופצים ודפי אופציות</a>: מסמכי HTML המספקים תוכן לרכיבי ממשק משתמש שונים.</li>
- <li><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Anatomy_of_a_WebExtension#Content_scripts">תסריטי תוכן</a>: ג'אווהסקריפט הכלול בהרחבה שלך, שיוחדרו לתוך דפי רשת.</li>
- <li><a href="https://wiki.developer.mozilla.org/he/docs/Mozilla/Add-ons/WebExtensions/Anatomy_of_a_WebExtension#%D7%A1%D7%A8%D7%92%D7%9C%D7%99%D7%9D_%D7%A6%D7%93%D7%93%D7%99%D7%99%D7%9D_%D7%97%D7%9C%D7%95%D7%A0%D7%95%D7%AA_%D7%A7%D7%95%D7%A4%D7%A6%D7%99%D7%9D_%D7%93%D7%A4%D7%99_%D7%90%D7%95%D7%A4%D7%A6%D7%99%D7%95%D7%AA">משאבים נגישים לרשת</a>: הכנת תוכן ארוז מגיש לדפי רשת ותסריטי תוכן.</li>
-</ul>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/13669/webextension-anatomy.png" style="display: block; height: 581px; margin-left: auto; margin-right: auto; width: 600px;"></p>
-
-<p>ראו דף סימוכין לממשק  <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json">manifest.json</a> לכל הפרטים.</p>
-
-<p>יחד עם כל אלה הרשומים במניפסט , הרחבה יכולה לכלול גם   <a dir="ltr" href="https://mdn.mozillademos.org/files/11553/browser-action.png">דפי הרחבה</a> נוספים וקבצים תומכים.</p>
-
-<h2 id="תסריטי_רקע">תסריטי רקע</h2>
-
-<p>הרחבות צריכות לעתים קרובות לשמור מצב ארוך טווח או לבצע םעולות ארוכות טווח ללא תלות בזמן החיים של דף רשת זה או אחר או בחלון דפדפן. בשביל זה יש תסריטי רקע.</p>
-
-<p>תסריטי רקע נטענים מייד כאשר ההרחבה נטענת ונשארים טעונים עד שההרחבה מושבתת או מוסרת. נתין להשתמש בכל אחד מ<a href="/en-US/Add-ons/WebExtensions/API">ממשקי פיתוח הרחבות הרשת</a> בתסריט, כל עוד ביקשת את ה<a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/permissions">הרשאות</a> הדרושות.</p>
-
-<h3 id="ציון_תסריטי_הרקע">ציון תסריטי הרקע</h3>
-
-<p>ניתן לכלול תסריט רקע באמצעות המפתח  <code>background</code>  ב-"manifest.json":</p>
-
-<pre class="brush: json">// manifest.json
-
-"background": {
- "scripts": ["background-script.js"]
-}</pre>
-
-<p>ניתן לציין מספר תסריטי רקע: אם תעשו כן, הם  ירוצו באותו הקשר. , בדיוק כמו תסריטים מרובים הנטענים לתוך דף רשת יחיד.</p>
-
-<p>במקום לציין תסריטי רקע, ניתן לציין דף רקע שיש לו יתרונות נוספים של תמיכה במודולי ES6:</p>
-
-<p style="margin-bottom: 0em;"><strong>manifest.json</strong></p>
-
-<pre class="brush: json">// manifest.json
-
-"background": {
- "page": "background-page.html"
-}</pre>
-
-<p style="margin-bottom: 0em;"><strong>background-page.html</strong></p>
-
-<pre class="brush: html">&lt;!DOCTYPE html&gt;
-&lt;html lang="en"&gt;
- &lt;head&gt;
- &lt;meta charset="utf-8"&gt;
- &lt;script type="module" src="background-script.js"&gt;&lt;/script&gt;
- &lt;/head&gt;
-&lt;/html&gt;</pre>
-
-<h3 id="סביבת_תסריטי_רקע">סביבת תסריטי רקע</h3>
-
-<h4 id="ממשקי_פיותח_DOM">ממשקי פיותח DOM</h4>
-
-<p>תסריטי רקע רצים בהקשר של דף מיוחד הקרוי דף רקע . זה נותן להם את המשתנה הגלובלי <code><a href="/en-US/docs/Web/API/Window">window</a></code>, יחד עם כל ממשקי פיתוח ה-  DOM המסופקים עם אובייקט זה</p>
-
-<div class="blockIndicator warning">
-<p> בפיירפוקס תסריטי רקע אינם תומכים בשימוש ב-, background pages do not support - <code><a href="https://developer.mozilla.org/en-US/docs/Web/API/Window/alert">alert()</a></code>, <code><a href="https://developer.mozilla.org/en-US/docs/Web/API/Window/confirm">confirm()</a></code>, או <code><a href="https://developer.mozilla.org/en-US/docs/Web/API/Window/prompt">prompt()</a></code>.</p>
-</div>
-
-<h4 id="ממשקי_פיתוח_הרחבות_רשת">ממשקי פיתוח הרחבות רשת</h4>
-
-<p>תסריטי רקע יכולים להשתמש בכל <a href="/en-US/Add-ons/WebExtensions/API">ממשקי פיתוח הרחבות הרשת</a> בתסריט, כל עוד להרחבה יש את <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/permissions">ההרשאות</a> הדרושות.</p>
-
-<h4 id="גישה_בין_מקורות">גישה בין מקורות</h4>
-
-<p>תסריטי רקע יכולים ליצור בקשות XHR לכל מארח עבורו יש להם  <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/permissions">הרשאות מארח</a>.</p>
-
-<h4 id="תוכן_ברשת">תוכן ברשת</h4>
-
-<p>תסריטי רקע אינם מקבלים גישה ישירה לדפי רשת. אולם הם יכולים לטעון,  <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Content_scripts">תסריטי תוכן</a> לתוך דפי רשת ויכולים  <a href="/en-US/Add-ons/WebExtensions/Content_scripts#Communicating_with_background_scripts">לתקשר עם תסריטי תוכן אלה באמצעות ממשקי פיתוח להעברת הודעות</a></p>
-
-<h4 id="מדיניות_אבטחת_תוכן">מדיניות אבטחת תוכן</h4>
-
-<p>תסריטי תוכן מוגבלים מביצוע פעולות בעלות פוטנציאל סיכון , כמו שימוש ב-<code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/eval">eval()</a></code> .דרך מדיניות אבטחת תוכן. ראו <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Content_Security_Policy">מדיניות אבטחת תוכן</a> לפרטים נוספים על כך.</p>
-
-<h2 id="סרגלים_צדדיים_חלונות_קופצים_דפי_אופציות">סרגלים צדדיים, חלונות קופצים, דפי אופציות</h2>
-
-<p>ההרחבה שלך יכולה לכלול רכיבי ממשק משתמש שונים שהתוכן שלהם מוגדר על ידי מסמך HTML :</p>
-
-<ul>
- <li> <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/user_interface/Sidebars">סרגל צדדי</a> הוא לוח המוצג בצד שמאל של חלון הדפדפן, על יד דף הרשת</li>
- <li> <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/user_interface/Popups">חלון קופץ</a> הוא דיאלוג שניתן להציג כאשר המשתמש/ת מקליקשה על  <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/user_interface/Browser_action">כפתור בסרגל הכלים</a> או <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/user_interface/Page_actions">כפתור בסרגל הכתובת</a></li>
- <li> <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/user_interface/Options_pages">דף אופציות</a> הינו דף המוצג כאשר המשתמש/ת ניגש/ת להעדפות שלך במנהל ההרחבות המקומי של הדפדפן.</li>
-</ul>
-
-<p>עבור כל אחד מרכיבים אלה ניתן ליצור קובץ HTML ולהצביע אליו באמצעות תכונה ספציפית ב-  <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json">manifest.json</a>. קובץ ה- HTML יכול לכלול  CSS וקבצי ג'אווהסקריפט, בדיוק כמו דף רשת נורמלי.</p>
-
-<p>כל אלה הם טיפוס של  <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/user_interface/Extension_pages">דפי הרחבה</a>, ושלא כמו דף רשת רגיל, הג'אווהסקריפט שלך יכול להשתמש בכל אותם ממשקי פיתוח פריבילגיים להרחבות רשת כמו תסריט הרקע. הם יכולים גם לגשת ישירות למשתנים בדך הרקע באמצעות  {{WebExtAPIRef("runtime.getBackgroundPage()")}}.</p>
-
-<h2 id="דפי_הרחבה">דפי הרחבה</h2>
-
-<p>ניתן לכלול בהרחבה שלך  גם מסמכי  HTML שאינם מחוברים לרכיב ממשק משתמש מוגדר מראש כלשהו . שלא כמו מסמכים שניתן לספק עבור סרגלים צדדיים, חלונות קופצים, או דפי אופציות, אין להם הגדרה ב- manifest.json. אולם , יש להם גישה לכל אותם ממשקי פיתוח הרחבות רשת פריבילגיים כמו תסריט הרקע שלך.</p>
-
-<p>באופן טיפוסי, דף כזה ייטען באמצעות  {{WebExtAPIRef("windows.create()")}} או {{WebExtAPIRef("tabs.create()")}}.</p>
-
-<p>ראו <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/user_interface/Extension_pages">דפי הרחבה</a> כדי ללמוד עוד.</p>
-
-<h2 id="Content_scripts">Content scripts</h2>
-
-<p>Use content scripts to access and manipulate web pages. Content scripts are loaded into web pages and run in the context of that particular page.</p>
-
-<p>Content scripts are extension-provided scripts which run in the context of a web page; this differs from scripts which are loaded by the page itself, including those which are provided in {{HTMLElement("script")}} elements within the page.</p>
-
-<p>Content scripts can see and manipulate the page's DOM, just like normal scripts loaded by the page.</p>
-
-<p>Unlike normal page scripts, they can:</p>
-
-<ul>
- <li>Make cross-domain XHR requests.</li>
- <li>Use a small subset of the <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API">WebExtension APIs</a>.</li>
- <li><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Content_scripts#Communicating_with_background_scripts">Exchange messages with their background scripts</a> and can in this way indirectly access all the WebExtension APIs.</li>
-</ul>
-
-<p>Content scripts cannot directly access normal page scripts but can exchange messages with them using the standard <code><a href="/en-US/docs/Web/API/Window/postMessage">window.postMessage()</a></code> API.</p>
-
-<p>Usually, when we talk about content scripts, we are referring to JavaScript, but you can inject CSS into web pages using the same mechanism.</p>
-
-<p>See the <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Content_scripts">content scripts</a> article to learn more.</p>
-
-<h2 id="משאבים_נגישים_לרשת">משאבים נגישים לרשת</h2>
-
-<p>משאבים נגישים לרשת עם משאבים כגון תמונות, HTML, CSS, ו- JavaScript הנכללים בהרחבה  וייתכן שתרצו לאפשר להם גישה לתסריטי תוכן ותסריטי דף. ניתן להפנות למשאבים הנוצרים נגישים לרשת על ידי תסריטי דף ותסריטי תוכן באמצעות סכמת   URI מיוחדת.</p>
-
-<p>לדוגמא, אם תסריט תוכן מעוניין להכניס קצת תמונות לתוך דפי רשת , ניתן לכלול אותם בהרחבה ולעשות אותם נגישים לרשת . אז תסריט התוכן יכול ליצור ולהוסיף תגיות   <code><a href="/en-US/docs/Web/HTML/Element/img">img</a></code> המפנות לתמונות דרך המאפיין <code>src</code>.</p>
-
-<p>כדי ללמוד עוד, אטו טת התיעוד עבור המפתח <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/web_accessible_resources">web_accessible_resources</a>  ב-manifest.json .</p>
diff --git a/files/he/mozilla/add-ons/webextensions/api/alarms/index.html b/files/he/mozilla/add-ons/webextensions/api/alarms/index.html
deleted file mode 100644
index 30a42d1d02..0000000000
--- a/files/he/mozilla/add-ons/webextensions/api/alarms/index.html
+++ /dev/null
@@ -1,60 +0,0 @@
----
-title: השכמות
-slug: Mozilla/Add-ons/WebExtensions/API/alarms
-tags:
- - API
- - הרחבות
- - הרחבות רשת
- - השכמות
- - ממשק
- - ממשק פיתוח
- - סימוכין
-translation_of: Mozilla/Add-ons/WebExtensions/API/alarms
----
-<div>{{AddonSidebar}}</div>
-
-<p>מתזמנות קוד לרוץ בזמן שצויין. זה כמו <code><a href="/en-US/docs/Web/API/WindowTimers/setTimeout">setTimeout()</a></code> ו- <code><a href="/en-US/docs/Web/API/WindowTimers/setInterval">setInterval()</a></code>, פרט לכך שפונקציות אלה לא עובדות עם דפי רקע הנטענים על פי דרישה. השכמות אינן מתמידות לאורך מפגשי הדפדפן.</p>
-
-<p>לשימוש בממשק פיתוח זה יש לכלול   <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/permissions">הרשאת</a> "alarms".</p>
-
-<h2 id="טיפוסים">טיפוסים</h2>
-
-<dl>
- <dt>{{WebExtAPIRef("alarms.Alarm")}}</dt>
- <dd>מידע אודות השכמה מסוימת.</dd>
-</dl>
-
-<h2 id="שיטות">שיטות</h2>
-
-<dl>
- <dt>{{WebExtAPIRef("alarms.clear()")}}</dt>
- <dd>מחק השכמה מסויימת בהינתן שמה.</dd>
- <dt>{{WebExtAPIRef("alarms.clearAll()")}}</dt>
- <dd>מחק את כל ההשכמות המתוזמנות.</dd>
- <dt>{{WebExtAPIRef("alarms.create()")}}</dt>
- <dd>צור השכמה חדשה.</dd>
- <dt>{{WebExtAPIRef("alarms.get()")}}</dt>
- <dd>שלוף השכמה מסויימת בהינתן שמה.</dd>
- <dt>{{WebExtAPIRef("alarms.getAll()")}}</dt>
- <dd>שלוף את כל ההשכמות המתוזמנות.</dd>
-</dl>
-
-<h2 id="אירועים">אירועים</h2>
-
-<dl>
- <dt>{{WebExtAPIRef("alarms.onAlarm")}}</dt>
- <dd>משוגר כאשר מגיע זמן ההשכמה.</dd>
-</dl>
-
-<p>{{WebExtExamples("h2")}}</p>
-
-<h2 id="תאימות_דפדפנים">תאימות דפדפנים</h2>
-
-<p>{{Compat("webextensions.api.alarms")}}</p>
-
-<div class="note"><strong>Acknowledgements</strong>
-
-<p>ממשק פיתוח זה מבוסס על ממשק הפיתוח <a href="https://developer.chrome.com/extensions/alarms"><code>chrome.alarms</code></a> של כרומיום.</p>
-
-<p>מידע התאימות של Microsoft Edge סופק על ידי תאגיד מיקרוסופט וכלול פה תחת רשיון Creative Commons Attribution 3.0 ארה"ב.</p>
-</div>
diff --git a/files/he/mozilla/add-ons/webextensions/api/browseraction/index.html b/files/he/mozilla/add-ons/webextensions/api/browseraction/index.html
deleted file mode 100644
index 195f81d304..0000000000
--- a/files/he/mozilla/add-ons/webextensions/api/browseraction/index.html
+++ /dev/null
@@ -1,124 +0,0 @@
----
-title: browserAction
-slug: Mozilla/Add-ons/WebExtensions/API/browserAction
-translation_of: Mozilla/Add-ons/WebExtensions/API/browserAction
----
-<div>{{AddonSidebar}}</div>
-
-<p>מוסיף כפתור לסרגל הכלים של הדפדפן.</p>
-
-<p> <a href="/he/docs/Mozilla/Add-ons/WebExtensions/Browser_action">פעולת דפדפן</a> הינה כפתור בסרגל הכלים של הדפדפן.</p>
-
-<p>ניתן לקשר חלון קופץ עם הכפתור. החלון הקופץ מצויין באמצעות HTML, CSS וג'אווה-סקריפט , בדומה לדף רשת רגיל. לקוד ג'אווה-סקריפט המורץ בחלון הקופץ גישה לכל ממשקי פיתוח היישומים של הרחבת הרשת כמו תסריטי הרקע שלך, אך ההקשר הגלובלי שלו הוא החלון הקופץ, ולא הדף הנוכחי המוצג על ידי הדפדפן. כדי להספיע לע הדפים מהרשת יש לתקשר איתם דרך  <a href="/en-US/Add-ons/WebExtensions/Modify_a_web_page#Messaging">messages</a>.</p>
-
-<p>If you specify a popup, it will be shown — and the content will be loaded — when the user clicks the icon. If you do not specify a popup, then when the user clicks the icon an event is dispatched to your extension.</p>
-
-<p>You can define most of a browser action's properties declaratively using the <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/browser_action">browser_action</a></code> key in the manifest.json.</p>
-
-<p>With the <code>browserAction</code> API, you can:</p>
-
-<ul>
- <li>use {{WebExtAPIRef("browserAction.onClicked")}} to listen for clicks on the icon.</li>
- <li>get and set the icon's properties — icon, title, popup, and so on. You can get and set these globally across all tabs, or for a specific tab by passing the tab ID as an additional argument.</li>
-</ul>
-
-<h2 id="Types">Types</h2>
-
-<dl>
- <dt>{{WebExtAPIRef("browserAction.ColorArray")}}</dt>
- <dd>An array of four integers in the range 0-255 defining an RGBA color.</dd>
- <dt>{{WebExtAPIRef("browserAction.ImageDataType")}}</dt>
- <dd>Pixel data for an image. Must be an <code><a href="/en-US/docs/Web/API/ImageData">ImageData</a></code> object (for example, from a {{htmlelement("canvas")}} element).</dd>
-</dl>
-
-<h2 id="Functions">Functions</h2>
-
-<dl>
- <dt>{{WebExtAPIRef("browserAction.setTitle()")}}</dt>
- <dd>Sets the browser action's title. This will be displayed in a tooltip.</dd>
- <dt>{{WebExtAPIRef("browserAction.getTitle()")}}</dt>
- <dd>Gets the browser action's title.</dd>
- <dt>{{WebExtAPIRef("browserAction.setIcon()")}}</dt>
- <dd>Sets the browser action's icon.</dd>
- <dt>{{WebExtAPIRef("browserAction.setPopup()")}}</dt>
- <dd>Sets the HTML document to be opened as a popup when the user clicks on the browser action's icon.</dd>
- <dt>{{WebExtAPIRef("browserAction.getPopup()")}}</dt>
- <dd>Gets the HTML document set as the browser action's popup.</dd>
- <dt>{{WebExtAPIRef("browserAction.openPopup()")}}</dt>
- <dd>Open the browser action's popup.</dd>
- <dt>{{WebExtAPIRef("browserAction.setBadgeText()")}}</dt>
- <dd>Sets the browser action's badge text. The badge is displayed on top of the icon.</dd>
- <dt>{{WebExtAPIRef("browserAction.getBadgeText()")}}</dt>
- <dd>Gets the browser action's badge text.</dd>
- <dt>{{WebExtAPIRef("browserAction.setBadgeBackgroundColor()")}}</dt>
- <dd>Sets the badge's background color.</dd>
- <dt>{{WebExtAPIRef("browserAction.getBadgeBackgroundColor()")}}</dt>
- <dd>Gets the badge's background color.</dd>
- <dt>{{WebExtAPIRef("browserAction.setBadgeTextColor()")}}</dt>
- <dd>Sets the badge's text color.</dd>
- <dt>{{WebExtAPIRef("browserAction.getBadgeTextColor()")}}</dt>
- <dd>Gets the badge's text color.</dd>
- <dt>{{WebExtAPIRef("browserAction.enable()")}}</dt>
- <dd>Enables the browser action for a tab. By default, browser actions are enabled for all tabs.</dd>
- <dt>{{WebExtAPIRef("browserAction.disable()")}}</dt>
- <dd>Disables the browser action for a tab, meaning that it cannot be clicked when that tab is active.</dd>
- <dt>{{WebExtAPIRef("browserAction.isEnabled()")}}</dt>
- <dd>Checks whether the browser action is enabled or not.</dd>
-</dl>
-
-<h2 id="Events">Events</h2>
-
-<dl>
- <dt>{{WebExtAPIRef("browserAction.onClicked")}}</dt>
- <dd>Fired when a browser action icon is clicked. This event will not fire if the browser action has a popup.</dd>
-</dl>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-<p>{{Compat("webextensions.api.browserAction")}}</p>
-
-<div class="hidden note">
-<p>The "Chrome incompatibilities" section is included from <a href="https://developer.mozilla.org/en-US/Add-ons/WebExtensions/Chrome_incompatibilities"> https://developer.mozilla.org/en-US/Add-ons/WebExtensions/Chrome_incompatibilities</a> using the <a href="/en-US/docs/Template:WebExtChromeCompat">WebExtChromeCompat</a> macro.</p>
-
-<p>If you need to update this content, edit <a href="https://developer.mozilla.org/en-US/Add-ons/WebExtensions/Chrome_incompatibilities">https://developer.mozilla.org/en-US/Add-ons/WebExtensions/Chrome_incompatibilities</a>, then shift-refresh this page to see your changes.</p>
-</div>
-
-<p>{{WebExtExamples("h2")}}</p>
-
-<div class="note"><strong>Acknowledgements</strong>
-
-<p>This API is based on Chromium's <a href="https://developer.chrome.com/extensions/browserAction"><code>chrome.browserAction</code></a> API. This documentation is derived from <a href="https://chromium.googlesource.com/chromium/src/+/master/chrome/common/extensions/api/browser_action.json"><code>browser_action.json</code></a> in the Chromium code.</p>
-
-<p>Microsoft Edge compatibility data is supplied by Microsoft Corporation and is included here under the Creative Commons Attribution 3.0 United States License.</p>
-</div>
-
-<div class="hidden">
-<pre class="notranslate">// Copyright 2015 The Chromium Authors. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the names of its
-// contributors may be used to endorse or promote products derived from
-// this software without specific prior written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-</pre>
-</div>
diff --git a/files/he/mozilla/add-ons/webextensions/api/index.html b/files/he/mozilla/add-ons/webextensions/api/index.html
deleted file mode 100644
index 4cbd4a2a8a..0000000000
--- a/files/he/mozilla/add-ons/webextensions/api/index.html
+++ /dev/null
@@ -1,55 +0,0 @@
----
-title: ממשקי פיתוח יישומים בג'אווה-סקריפט
-slug: Mozilla/Add-ons/WebExtensions/API
-tags:
- - NeedsTranslation
- - TopicStub
-translation_of: Mozilla/Add-ons/WebExtensions/API
----
-<div>{{AddonSidebar}}</div>
-
-<div>
-<p>בממשקי פיתוח היישומים עבור הרחבות רשת בג'אווה-סקריפט ניתן להשתמש בתוך</p>
-
-<p>  <a href="https://wiki.developer.mozilla.org/he/docs/Mozilla/Add-ons/WebExtensions/Anatomy_of_a_WebExtension#%D7%AA%D7%A1%D7%A8%D7%99%D7%98%D7%99_%D7%A8%D7%A7%D7%A2">תסריטי הרקע</a> של ההרחבה ובכל המסמכים האחרים הכלולים בהרחבה, כולל  <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Browser_action">browser action</a> or <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Page_actions">page action</a> popups, <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Sidebars">sidebars</a>, <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Options_pages">options pages</a>, or <a href="/en-US/Add-ons/WebExtensions/manifest.json/chrome_url_overrides">new tab pages</a>. A few of these APIs can also be accessed by an extension's <a href="https://developer.mozilla.org/en-US/Add-ons/WebExtensions/Anatomy_of_a_WebExtension#Content_scripts">content scripts</a> (see the <a href="https://developer.mozilla.org/en-US/Add-ons/WebExtensions/Content_scripts#WebExtension_APIs">list in the content script guide</a>).</p>
-
-<p>To use the more powerful APIs you need to <a href="https://developer.mozilla.org/en-US/Add-ons/WebExtensions/manifest.json/permissions">request permission</a> in your extension's manifest.json.</p>
-
-<p>You can access the APIs using the <code>browser</code> namespace:</p>
-
-<pre class="brush: js line-numbers language-js notranslate"><code class="language-js"><span class="keyword token">function</span> <span class="function token">logTabs</span><span class="punctuation token">(</span>tabs<span class="punctuation token">)</span> <span class="punctuation token">{</span>
- console<span class="punctuation token">.</span><span class="function token">log</span><span class="punctuation token">(</span>tabs<span class="punctuation token">)</span><span class="punctuation token">;</span>
-<span class="punctuation token">}</span>
-
-browser<span class="punctuation token">.</span>tabs<span class="punctuation token">.</span><span class="function token">query</span><span class="punctuation token">(</span><span class="punctuation token">{</span>currentWindow<span class="punctuation token">:</span> <span class="keyword token">true</span><span class="punctuation token">}</span><span class="punctuation token">,</span> logTabs<span class="punctuation token">)</span><span class="punctuation token">;</span></code></pre>
-</div>
-
-<div>
-<p>Many of the APIs are asynchronous, returning a <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise">Promise</a></code>:</p>
-
-<pre class="brush: js line-numbers language-js notranslate"><code class="language-js"><span class="keyword token">function</span> <span class="function token">logCookie</span><span class="punctuation token">(</span>c<span class="punctuation token">)</span> <span class="punctuation token">{</span>
- console<span class="punctuation token">.</span><span class="function token">log</span><span class="punctuation token">(</span>c<span class="punctuation token">)</span><span class="punctuation token">;</span>
-<span class="punctuation token">}</span>
-
-<span class="keyword token">function</span> <span class="function token">logError</span><span class="punctuation token">(</span>e<span class="punctuation token">)</span> <span class="punctuation token">{</span>
- console<span class="punctuation token">.</span><span class="function token">error</span><span class="punctuation token">(</span>e<span class="punctuation token">)</span><span class="punctuation token">;</span>
-<span class="punctuation token">}</span>
-
-<span class="keyword token">var</span> setCookie <span class="operator token">=</span> browser<span class="punctuation token">.</span>cookies<span class="punctuation token">.</span><span class="keyword token">set</span>okie<span class="punctuation token">.</span><span class="function token">then</span><span class="punctuation token">(</span>logCookie<span class="punctuation token">,</span> logError<span class="punctuation token">)</span><span class="punctuation token">;</span></code></pre>
-</div>
-
-<div>
-<p>Note that this is different from Google Chrome's extension system, which uses the <code>chrome</code> namespace instead of <code>browser</code>, and which uses callbacks instead of promises for asynchronous functions. As a porting aid, the Firefox implementation of WebExtensions APIs supports <code>chrome</code> and callbacks as well as <code>browser</code> and promises. Mozilla has also written a polyfill which enables code that uses <code>browser</code> and promises to work unchanged in Chrome: <a class="external external-icon" href="https://github.com/mozilla/webextension-polyfill">https://github.com/mozilla/webextension-polyfill</a>.</p>
-
-<p>Firefox also implements these APIs under the <code>chrome</code> namespace using callbacks. This allows code written for Chrome to run largely unchanged in Firefox for the APIs documented here.</p>
-
-<p>Microsoft Edge uses the <code>browser</code> namespace, but doesn't yet support promise-based asynchronous APIs. In Edge, for the time being, asynchronous APIs must use callbacks.</p>
-
-<p>Not all browsers support all the APIs: for the details, see <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Browser_support_for_JavaScript_APIs">Browser support for JavaScript APIs</a>.</p>
-
-<h2 id="JavaScript_API_listing">JavaScript API listing</h2>
-
-<p>See below for a complete list of JavaScript APIs:</p>
-</div>
-
-<div>{{SubpagesWithSummaries}}</div>
diff --git a/files/he/mozilla/add-ons/webextensions/api/storage/index.html b/files/he/mozilla/add-ons/webextensions/api/storage/index.html
deleted file mode 100644
index f866b07efa..0000000000
--- a/files/he/mozilla/add-ons/webextensions/api/storage/index.html
+++ /dev/null
@@ -1,102 +0,0 @@
----
-title: storage
-slug: Mozilla/Add-ons/WebExtensions/API/storage
-translation_of: Mozilla/Add-ons/WebExtensions/API/storage
----
-<div>{{AddonSidebar}}</div>
-
-<p>מאפשר להרחבות לאחסן ולשלוף נתונים, ולהאזין לשינויים בפריטים המאוחסנים.</p>
-
-<p>מערכת האחסון מבוססת על <a href="/he/docs/Web/API/Web_Storage_API">ממשק פיתוח היישומים Web Storage</a>, עם מספר הבדלים. בין ההבדלים ניתן למצוא כי:</p>
-
-<ul>
- <li>היא אסינכרונית.</li>
- <li>הערכים הם בתוחם של ההרחבה, לא של מתחם כלשהו (כלומר. אותה קבוצה של זוגות מפתח/ערך זמינה לכל התסריטים בהקשר הרקע ובתסריטי התוכן).</li>
- <li>הערכים המאוחסנים יכולים להיות כל ערך הניתן לסריאליזציית , לא רק <code><a href="/he/docs/Web/JavaScript/Reference/Global_Objects/String">String</a></code>. בין היתר, זה כולל: <code><a href="/he/docs/Web/JavaScript/Reference/Global_Objects/Array">Array</a></code> ו-<code><a href="/he/docs/Web/JavaScript/Reference/Global_Objects/Object">Object</a></code>, אך רק כשהתוכן שלהם יכול להיות מיוצג ב- JSON, שאינו כולל צמתי DOM. אין צורך בהסבת הערים למחרוזות JSON בטרם יאוחסנו, אך הם מיוצגים פנימית כערכי JSON, ולכן הדרישה כי יוכלו להיות מיוצגים בפורמט JSON.</li>
- <li>ניתן לקבוע ערכם של  זוגות מפתח/ערך מרובים יכולים  או לשלוף אותם באותה קריאה לממשק פיתוח היישומים.</li>
-</ul>
-
-<p>To use this API you need to include the <code>"storage"</code> <a href="https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/permissions">permission</a> in your <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json">manifest.json</a></code> file.</p>
-
-<p>Each extension has its own storage area, which can be split into different types of storage.</p>
-
-<p>Although this API is similar to {{domxref("Window.localStorage")}} it is recommended that you don't use <code>Window.localStorage</code> in the extension code to store extension-related data. Firefox will clear data stored by extensions using the localStorage API in various scenarios where users clear their browsing history and data for privacy reasons, while data saved using the <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/storage/local">storage.local</a></code> API will be correctly persisted in these scenarios.</p>
-
-<p>You can examine the stored data under the Extension Storage item in the <a href="/en-US/docs/">Storage Inspector</a> tab of the <a href="https://extensionworkshop.com/documentation/develop/debugging/">developer toolbox</a>, accessible from <code>about:debugging</code>.</p>
-
-<div class="note">The storage area is not encrypted and shouldn't be used for storing confidential user information.</div>
-
-<h2 id="Types">Types</h2>
-
-<dl>
- <dt>{{WebExtAPIRef("storage.StorageArea")}}</dt>
- <dd>An object representing a storage area.</dd>
- <dt>{{WebExtAPIRef("storage.StorageChange")}}</dt>
- <dd>An object representing a change to a storage area.</dd>
-</dl>
-
-<h2 id="Properties">Properties</h2>
-
-<p><code>storage</code> has three properties, which represent the different types of available storage area.</p>
-
-<dl>
- <dt>{{WebExtAPIRef("storage.sync")}}</dt>
- <dd>Represents the <code>sync</code> storage area. Items in <code>sync</code> storage are synced by the browser, and are available across all instances of that browser that the user is logged into, across different devices.</dd>
- <dt>{{WebExtAPIRef("storage.local")}}</dt>
- <dd>Represents the <code>local</code> storage area. Items in <code>local</code> storage are local to the machine the extension was installed on.</dd>
- <dt>{{WebExtAPIRef("storage.managed")}}</dt>
- <dd>Represents the <code>managed</code> storage area. Items in <code>managed</code> storage are set by the domain administrator and are read-only for the extension. Trying to modify this namespace results in an error.</dd>
-</dl>
-
-<h2 id="Events">Events</h2>
-
-<dl>
- <dt>{{WebExtAPIRef("storage.onChanged")}}</dt>
- <dd>Fired when one or more items change in a storage area.</dd>
-</dl>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-
-
-<p>{{Compat("webextensions.api.storage")}}</p>
-
-<p>{{WebExtExamples("h2")}}</p>
-
-<div class="note"><strong>Acknowledgements</strong>
-
-<p>This API is based on Chromium's <a href="https://developer.chrome.com/extensions/storage"><code>chrome.storage</code></a> API. This documentation is derived from <a href="https://chromium.googlesource.com/chromium/src/+/master/extensions/common/api/storage.json"><code>storage.json</code></a> in the Chromium code.</p>
-
-<p>Microsoft Edge compatibility data is supplied by Microsoft Corporation and is included here under the Creative Commons Attribution 3.0 United States License.</p>
-</div>
-
-<div class="hidden">
-<pre class="notranslate">// Copyright 2015 The Chromium Authors. All rights reserved.
-//
-// Redistribution and use in source and binary forms, with or without
-// modification, are permitted provided that the following conditions are
-// met:
-//
-// * Redistributions of source code must retain the above copyright
-// notice, this list of conditions and the following disclaimer.
-// * Redistributions in binary form must reproduce the above
-// copyright notice, this list of conditions and the following disclaimer
-// in the documentation and/or other materials provided with the
-// distribution.
-// * Neither the name of Google Inc. nor the names of its
-// contributors may be used to endorse or promote products derived from
-// this software without specific prior written permission.
-//
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-</pre>
-</div>
diff --git a/files/he/mozilla/add-ons/webextensions/browser_support_for_javascript_apis/index.html b/files/he/mozilla/add-ons/webextensions/browser_support_for_javascript_apis/index.html
deleted file mode 100644
index 90b11fb246..0000000000
--- a/files/he/mozilla/add-ons/webextensions/browser_support_for_javascript_apis/index.html
+++ /dev/null
@@ -1,24 +0,0 @@
----
-title: Browser support for JavaScript APIs
-slug: Mozilla/Add-ons/WebExtensions/Browser_support_for_JavaScript_APIs
-tags:
- - הרחבות רשת
- - סימוכין
-translation_of: Mozilla/Add-ons/WebExtensions/Browser_support_for_JavaScript_APIs
----
-<div>{{AddonSidebar}}</div>
-
-<div class="hidden">תאימות הטבלאות בעמוד זה מופקת מנתונים במבנה. אם ברצונך לתרום למידע זה,נא לשלוף קבצים לעריכה מ- <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> ולשלוח לנו בקשת משיכה..</div>
-
-<p>{{WebExtAllCompatTables}}</p>
-
-<div class="note"><strong>תודות</strong>
-
-<p>נתוני התאימות לדפדפן Microsoft Edge מסופקים על ידי תאגיד מיקרוסופט ונכללים כאם ץחת רשיון Creative Commons Attribution 3.0 ארה"ב.</p>
-</div>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Browser_compatibility_for_manifest.json">Browser compatibility for manifest.json</a></li>
-</ul>
diff --git a/files/he/mozilla/add-ons/webextensions/content_scripts/index.html b/files/he/mozilla/add-ons/webextensions/content_scripts/index.html
deleted file mode 100644
index 727114978d..0000000000
--- a/files/he/mozilla/add-ons/webextensions/content_scripts/index.html
+++ /dev/null
@@ -1,493 +0,0 @@
----
-title: תסריטי תוכן
-slug: Mozilla/Add-ons/WebExtensions/Content_scripts
-tags:
- - הרחבות רשת
-translation_of: Mozilla/Add-ons/WebExtensions/Content_scripts
----
-<div>{{AddonSidebar}}</div>
-
-<p>תסריט תוכן הוא חלק מההרחבה שלך שרץ בהקשר של דף מסויים ברשת  (בניגוד לתסריטי רקע שהם חלק מהרחבה, או תסריטים שהם חלק מאתר הרשת עצמו , כגון אלה הנטענים באמצעות אלמנט ה-{{HTMLElement("script")}} ).</p>
-
-<p><a href="/en-US/Add-ons/WebExtensions/Background_scripts">תסריטי רקע</a> יכולים לגשת לכל  <a href="/en-US/Add-ons/WebExtensions/API">ממשקי הפיתוח בג'אווהסקריפט של הרחבות הרשת</a>,   אך אינם ניגשים ישירות לתוכן של עמודי רשת.  לכן אם ההרחבה שלך צריכה לעשות זאת, עליך לכתוב תסריט תוכן.</p>
-
-<p>בדיוק כפי שהתסריטים נטענים על ידי דפי רשת נורמליים, תסריטי תוכן יכולים לקרוא ולשנות תוכן הדפים שלהם באמצעות ממשקי פיתוח יישומי DOM.</p>
-
-<p>תסריטי תוכן יכולים לגשת רק ל<a href="https://developer.mozilla.org/en-US/Add-ons/WebExtensions/Content_scripts#WebExtension_APIs">תת קבוצה קטנה של ממשקי פיתוח הרחבות הרשת</a>,   אך <a href="https://developer.mozilla.org/en-US/Add-ons/WebExtensions/Content_scripts#Communicating_with_background_scripts">לתקשר עם תסריטי רקע</a> באמצעות מערכת שליחת הודעות, ובאמצעותן לגשת בעקיפין לממשקי הפיתוח של הרחבות הרשת.</p>
-
-<div class="note">
-<p>לתשומת לבך תסריטי תוכן חסומים במתחמים הבאים:</p>
-
-<ul style="display: grid;">
- <li>accounts-static.cdn.mozilla.net</li>
- <li>accounts.firefox.com</li>
- <li>addons.cdn.mozilla.net</li>
- <li>addons.mozilla.org</li>
- <li>api.accounts.firefox.com</li>
- <li>content.cdn.mozilla.net</li>
- <li>content.cdn.mozilla.net</li>
- <li>discovery.addons.mozilla.org</li>
- <li>input.mozilla.org</li>
- <li>install.mozilla.org</li>
- <li>oauth.accounts.firefox.com</li>
- <li>profile.accounts.firefox.com</li>
- <li>support.mozilla.org</li>
- <li>sync.services.mozilla.com</li>
- <li>testpilot.firefox.com</li>
-</ul>
-
-<p>נסיון להחדיר תסריט תוכן לאתרים אלה ייכשל טהעמוד ירשום שגיאת  <a href="/en-US/docs/Web/HTTP/CSP">CSP</a> ללוג.</p>
-
-<p>משום שמגבלות אלו כוללות את  addons.mozilla.org, משתמשים עשויים לנסות להשתמש בהרחבה שלך מיד אחרי ההתקנה —רק כדי לגלות שאינה עובדת! ייתכן ותרצה/י להוסיף אזהרה הולמת, או   <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/onboarding_upboarding_offboarding_best_practices">דף onboarding</a> להרחיק משתמשים מ- addons.mozilla.org.</p>
-</div>
-
-<div class="note">
-<p>ערכים הנוספים לסקופ הגלובלי של תסריט תוכן באמצעות <code>var foo</code> או <code>window.foo = "bar"</code> עלולים להיעלם עקב באג <a href="https://bugzilla.mozilla.org/show_bug.cgi?id=1408996">1408996</a>.</p>
-</div>
-
-<h2 id="טעינת_תסריט_תוכן">טעינת תסריט תוכן</h2>
-
-<p>ניתן לטעון תסריט תוכן לאתר רשת בשלוש דרכים:</p>
-
-<ol>
- <li><strong>בעת ההתקנה, לתוך דפים התואמים תבניות URL:</strong> באמצעות מפתח ה-<code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/content_scripts">content_scripts</a></code> בקובץ ה-manifest.json שלך, ניתן  לבקש מהדפדפן לטעון תסריט תוכן בכל פעם שהדפדפן מעלה דף שה-URL שלו <a href="https://developer.mozilla.org/en-US/Add-ons/WebExtensions/Match_patterns">תואם תבנית נתונה</a>.</li>
- <li><strong>בזמן ריצה, לתוך דפים התואמים תבניתו URL :</strong> באמצעות ממשק פיתוח היישומים {{WebExtAPIRef("contentScripts")}} API, ניתן לבקש מהדפדפן לטעון  תסריט תוכן בכל ]עפ שהדפדפן טוען דף שה-URL שלו  <a href="https://developer.mozilla.org/en-US/Add-ons/WebExtensions/Match_patterns">תואם תבנית נתונה matches a given pattern</a>. זה בפשטות כמו בשיטה  (1), פרט לכך שניתן להוסיף ולהסיר תסריט תוכן בזמן ריצה.</li>
- <li><strong>בזמן ריצה, לתוך לשוניות מסוימות  into specific tabs:</strong> באמצאות צצשק הפיתוח  <code><a href="/en-US/Add-ons/WebExtensions/API/Tabs/executeScript">tabs.executeScript()</a></code> , ניתן לטעון תסריט תוכן בכל עת שיהיה ברצונך: למשל, סתגובה להקשת משתמש/ת על <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Browser_action">פעולת דפדפן</a>.</li>
-</ol>
-
-<p><em>קיים רק סקופ גלובלי אחד למסגרת, להרחבה</em>. זאת אומרת שניתן לגשת למשתני תסריט תוכן אחד ישירות על ידי תסריט תוכן אחר , ללא קשר לדרך בה נטען תסריט התוכן.</p>
-
-<p>באמצעות שיטות (1) ו- (2), ניתן לטעון תסריטים לתוך דפים שה- URL-ים שלהם  יכולים להיות מיוצגים באמצעות <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Match_patterns">תבניות התאמה</a>.</p>
-
-<p>באמצעות שיטה (3), ניתן גם לטעון תסריטים לתוך דפים ארוזים עם ההרחבה שלך, אך לא ניתן לטעון תסריטים לתוך דפי דפדפן בעלי פריבילגיה  (כגון "about:debugging" או "about:addons").</p>
-
-<h2 id="סביבת_תסריטי_תוכן">סביבת תסריטי תוכן</h2>
-
-<h3 id="גישה_ל-DOM">גישה ל-DOM</h3>
-
-<p>תסריטים יכולים לגשת ולשנות את ה-DOM של הדף , בדיוק כפי שיכולים לעשות זת תסריטי דף נורמליים. הם יכולים לראות גם שינווים שנעשו ב- DOM על ידי תסריטי דפים.</p>
-
-<p>אולם, תסריטי תוכן מקבלים "מראה נקי של ה-DOM". כלומר::</p>
-
-<ul>
- <li>תסריטי תוכן אינם יכולים לראות משתני ג'אווהסקריפט המוגדרים על ידי תסריטי דף.</li>
- <li>אם תסריט דף משנה תכונה מובנית ב- DOM , תפריט התוכן יראה את הגרסה המקורית של התכונה, ולא את הגרסה המוגדרת מחדש.</li>
-</ul>
-
-<p>בפיירפוקס התנהגות זו קרויה <a href="/en-US/docs/Xray_vision">ראיית רנטגן</a>.</p>
-
-<p>חשבו על דף רשת כזה:</p>
-
-<pre class="brush: html">&lt;!DOCTYPE html&gt;
-&lt;html&gt;
- &lt;head&gt;
- &lt;meta http-equiv="content-type" content="text/html; charset=utf-8" /&gt;
- &lt;/head&gt;
-
- &lt;body&gt;
- &lt;script src="page-scripts/page-script.js"&gt;&lt;/script&gt;
- &lt;/body&gt;
-&lt;/html&gt;</pre>
-
-<p>התסריט "page-script.js" עושה את זה:</p>
-
-<pre class="brush: js">// page-script.js
-
-// add a new element to the DOM
-var p = document.createElement("p");
-p.textContent = "This paragraph was added by a page script.";
-p.setAttribute("id", "page-script-para");
-document.body.appendChild(p);
-
-// define a new property on the window
-window.foo = "This global variable was added by a page script";
-
-// redefine the built-in window.confirm() function
-window.confirm = function() {
- alert("The page script has also redefined 'confirm'");
-}</pre>
-
-<p>כעת  הרחבה מחדירה תסריט תוכן לתוך הדף:</p>
-
-<pre class="brush: js">// content-script.js
-
-// can access and modify the DOM
-var pageScriptPara = document.getElementById("page-script-para");
-pageScriptPara.style.backgroundColor = "blue";
-
-// can't see page-script-added properties
-console.log(window.foo); // undefined
-
-// sees the original form of redefined properties
-window.confirm("Are you sure?"); // calls the original window.confirm()</pre>
-
-<p>אותו הדבר נכון גם להיפך: תסריטי דף אינם יכולים לראות משתני ג'אווהסקריפט  שנוספו על ידי תסריטי תוכן</p>
-
-<p>זאת אומרת שתסריטי תוכן יכולים להסתמך על תכונות  DOM שהתנהגותן צפויה. , בלי להיות מודאגים מהתנגשויות משתנים עם משתנים מתסריטי הדף.</p>
-
-<p>אחת ההשלכות המעשיות של התנהגות זו היא שלתסריט תוכן לא תהיה גישה לאף ספריית ד'אווהסקריפט שנטענה על ידי הדף. לכן לדוגמא, אם דף מכיל jQuery, תסריט התוכן לא יוכל לראותו.</p>
-
-<p>היה ותסריט תוכן כן רוצה להשתמש בספריית ג'אווהסקריפט, הספריה עצנה צריכה להיות מוחדרת כתסריט תוכן לצד תסריט התוכן המעוניין להשתמש בה::</p>
-
-<pre class="brush: json">"content_scripts": [
- {
- "matches": ["*://*.mozilla.org/*"],
- "js": ["jquery.js", "content-script.js"]
- }
-]</pre>
-
-<div class="blockIndicator note">
-<p><strong>לתשומת לבך:</strong> פיירפוקס <em>כן</em> מספק כמה ממשקי פיתוח יישומים המאפשרים לתסריטי תוכן לגשת לאובייקטי ג'אווהסקריפט הנוצרים על ידי תסריטי דף, ולחשוף את אובייקטי הג'אווהסקריפט שלהם לתסריטי דף.</p>
-
-<p>ראו  <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Sharing_objects_with_page_scripts">שיתוף אובייקטים עם תסריטי דף</a> לפרטים נוספים.</p>
-</div>
-
-<h3 id="ממשקי_פיתוח_יישומים_של_הרחבות_רשת">ממשקי פיתוח יישומים של הרחבות רשת</h3>
-
-<p>בנוסף לממשקי הפיתוח הסטנדרטיים של ה-DOM , ,תסריטי התוכן יכולים להשתמש בממשקי פיתוח היישומים הבאים של הרחבות הרשת:</p>
-
-<p>מתוך <code><a href="/en-US/Add-ons/WebExtensions/API/extension">extension</a></code>:</p>
-
-<ul>
- <li><code><a href="/en-US/Add-ons/WebExtensions/API/extension#getURL()">getURL()</a></code></li>
- <li><code><a href="/en-US/Add-ons/WebExtensions/API/extension#inIncognitoContext">inIncognitoContext</a></code></li>
-</ul>
-
-<p>מתוך <code><a href="/en-US/Add-ons/WebExtensions/API/runtime">runtime</a></code>:</p>
-
-<ul>
- <li><code><a href="/en-US/Add-ons/WebExtensions/API/runtime#connect()">connect()</a></code></li>
- <li><code><a href="/en-US/Add-ons/WebExtensions/API/runtime#getManifest()">getManifest()</a></code></li>
- <li><code><a href="/en-US/Add-ons/WebExtensions/API/runtime#getURL()">getURL()</a></code></li>
- <li><code><a href="/en-US/Add-ons/WebExtensions/API/runtime#onConnect">onConnect</a></code></li>
- <li><code><a href="/en-US/Add-ons/WebExtensions/API/runtime#onMessage">onMessage</a></code></li>
- <li><code><a href="/en-US/Add-ons/WebExtensions/API/runtime#sendMessage()">sendMessage()</a></code></li>
-</ul>
-
-<p>מתוך <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/i18n">i18n</a></code>:</p>
-
-<ul>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/i18n/getMessage">getMessage()</a></code></li>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/i18n/getAcceptLanguages">getAcceptLanguages()</a></code></li>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/i18n/getUILanguage">getUILanguage()</a></code></li>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/i18n/detectLanguage">detectLanguage()</a></code></li>
-</ul>
-
-<p>מתוך <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/menus">menus</a></code>:</p>
-
-<ul>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/menus/getTargetElement">getTargetElement</a></code></li>
-</ul>
-
-<p>הכל מתוך <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/storage">storage</a></code>.</p>
-
-<h3 id="XHR_ו-Fetch">XHR ו-Fetch</h3>
-
-<p>.תסריטי תוכן יכולים להכין בקשות באמצעות ממשקי פיתוח היישומים <code><a href="/en-US/docs/Web/API/XMLHttpRequest">window.XMLHttpRequest</a></code> ו- <code><a href="/en-US/docs/Web/API/Fetch_API">window.fetch()</a></code>.</p>
-
-<div class="blockIndicator note">
-<p>בפיירפוקס, בקשות תסריטי התוכן (לדוגמא, באמצעות <a href="/en-US/docs/Web/API/Fetch_API/Using_Fetch">fetch()</a>) קורות בהקשר של הרחבה, כך שיש לספק כתובת  URL מוחלטת  כדי להתייחס לתוכן דף. בכרום, בקשות אלה קורות בהקשר של דף, כך שכתובות ה-URL הן יחסיות,  לדוגמא, <code>/api</code> נשלחת ל- <code>https://[current page URL]/api</code>.</p>
-</div>
-
-<p>תסריטי תוכן מקבלים את אותן פריבילגיות חוצות מתחמים כמו שאר ההרחבות, כך שאם הרחבה בקשה גישה חוצת מתחמים עבור מתחם באמצעות מפתח  <code><a href="https://developer.mozilla.org/en-US/Add-ons/WebExtensions/manifest.json/permissions">permissions</a></code> ב- manifest.json, אזי תסריט התוכן יקבל גישה גם למתחם זה. </p>
-
-<p>זה יושג על ידי חשיפת יותר מופעי   XHR ו- fetch  בעלי יותר פריבילגיות בתסריט התוכן, להם תופעת הלוואי של אי הגדרת כותרות ה<code><a href="/en-US/docs/Web/HTTP/Headers/Origin">origin</a></code> והr<code><a href="/en-US/docs/Web/HTTP/Headers/Referer">eferer</a></code> כמו לבקשות מהדף עצמו, לעתים תכופות זה מועדף כדי למנוע מבקשה לחשוף את הטבע חוצה המקורות שלה.  מגרסה 58 ואילך  הרחבות הצריכות לבצע בקשות המתנהגות כאילו משלחו מהתוכן עצמו  יכולות להשתמש ב- <code>content.XMLHttpRequest</code> וב-<code>content.fetch()</code> במקום. להרחבות חוצות דפדפנים נוכחותן חייבת להיו מגולת תכונות.</p>
-
-<h2 id="תקשורת_עם_תסריטי_רקע">תקשורת עם תסריטי רקע</h2>
-
-<p>למרות שתסריטי תוכן אינם יכולים לגשת ישירות לממשקי פיתוח של הרחבות רשת, הם יכולים להתקשר עם תסריטי הרקע של ההרחבות באמצעות ממשקי הפיתוח של שליחת ההודעות ולכן יכולים לגשת בעקיפין לכל אותם הממשקים שתסריטי הרקע יכולים.</p>
-
-<p>קיימות שתי תבניות בסיסיות להתקשרות בין תסריטי הרקע לתסריטי התוכן: ניתן לשלוח הודעות בודדות, עם אפשרות למענה, או להגדיר התחברות לטווח יותר ארוך בין שני הצדדים, ולהחליף הודעות באמצעות התחברות זאת.</p>
-
-<h3 id="הודעות_בודדות">הודעות בודדות</h3>
-
-<p>לשליחת הודעה בודדת עם אפשרות למענה, ניתן להשתמש בממשקי הפיתוח הבאים:</p>
-
-<table class="fullwidth-table standard-table">
- <thead>
- <tr>
- <th scope="row"></th>
- <th scope="col">בתסריט התוכן</th>
- <th scope="col">בתסריט הרקע</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <th scope="row">שליחת הודעה</th>
- <td><code><a href="/en-US/Add-ons/WebExtensions/API/runtime/sendMessage">browser.runtime.sendMessage()</a></code></td>
- <td><code><a href="/en-US/Add-ons/WebExtensions/API/Tabs/sendMessage">browser.tabs.sendMessage()</a></code></td>
- </tr>
- <tr>
- <th scope="row">קבלת הודעה</th>
- <td><code><a href="/en-US/Add-ons/WebExtensions/API/runtime/onMessage">browser.runtime.onMessage</a></code></td>
- <td><code><a href="/en-US/Add-ons/WebExtensions/API/runtime/onMessage">browser.runtime.onMessage</a></code></td>
- </tr>
- </tbody>
-</table>
-
-<p>לדוגמא, להלן תסריט תוכן המאזין לאירועי להקלקה בדף הרשת.</p>
-
-<p>עם ההקלקה הייתה על קישור, יישלח URL המטרה לדף הרקע:</p>
-
-<pre class="brush: js">// content-script.js
-
-window.addEventListener("click", notifyExtension);
-
-function notifyExtension(e) {
- if (e.target.tagName != "A") {
- return;
- }
- browser.runtime.sendMessage({"url": e.target.href});
-}</pre>
-
-<p>תסריט הרקע מאזין להודעות האלה ומציג התראה באמצעוץ ממשק ה-<code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/notifications">notifications</a></code> :</p>
-
-<pre class="brush: js">// background-script.js
-
-browser.runtime.onMessage.addListener(notify);
-
-function notify(message) {
- browser.notifications.create({
- "type": "basic",
- "iconUrl": browser.extension.getURL("link.png"),
- "title": "You clicked a link!",
- "message": message.url
- });
-}
-</pre>
-
-<p>(הקוד לדוגמא מעובד קלות מהדוגמא <a href="https://github.com/mdn/webextensions-examples/tree/master/notify-link-clicks-i18n">notify-link-clicks-i18n</a>   ב-GitHub.)</p>
-
-<h3 id="טיפול_בהודעות_מבוסס_התחברות">טיפול בהודעות מבוסס התחברות</h3>
-
-<p>שליחת הודעות בודדות עלול להיות מסורבל אם מתבצעת תחלופה מרובה של הודעות בין תסריט רקע לתסריט תוכן. כך שעל תבנית חליפית להיווסד לצורך התחברות לטוח ארוך יותר בין שני ההקשרים, ולהשתמש בהתחברות זו לחילופי הודעות.</p>
-
-<p>לכל צד יש אובייקט <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/runtime/Port">runtime.Port</a></code>, המשמש החלפת הודעות.</p>
-
-<p>ליצירת התחברות:</p>
-
-<ul>
- <li>צד אחד מאזין להתחברויות באמצעות <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/runtime/onConnect">runtime.onConnect</a></code></li>
- <li>הצד השני קורא ל:
- <ul>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/tabs/connect">tabs.connect()</a></code> (אם מתחבר לתסריט תוכן); או</li>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/runtime/connect">runtime.connect()</a></code> (אם מתחבר לתסריט רקע).</li>
- </ul>
- </li>
-</ul>
-
-<p>זה מחזיר אובייקט מסוג <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/runtime/Port">runtime.Port</a></code>.</p>
-
-<ul>
- <li>מאזין ה-<code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/runtime/onConnect">runtime.onConnect</a></code> מועבר לאובייקט <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/runtime/Port">runtime.Port</a></code> משלו.</li>
-</ul>
-
-<p>ברגע שלכל צד יש פתחה , שני הצדדים יכולים:</p>
-
-<ul>
- <li>לשלוח הודעות באמצעות <code>runtime.Port.postMessage()</code>, וגם</li>
- <li>לקבל הודעות באמצעות <code>runtime.Port.onMessage()</code></li>
-</ul>
-
-<p>לדוגמא, מייד כשנטען, תסריט התוכן:</p>
-
-<ul>
- <li>מתחבר לתסריט הרקע</li>
- <li>מאחסן את ה-<code>Port</code> במשתנה <code>myPort</code></li>
- <li>מאזין להודעות על גבי <code>myPort</code>, ורושם אותן ליומן</li>
- <li>משתמש ב-<code>myPort</code> לשלוח הודעות לתסריט הרקע  כשהמתמש/ת מקליק/ה על המסמך</li>
-</ul>
-
-<pre class="brush: js">// content-script.js
-
-var myPort = browser.runtime.connect({name:"port-from-cs"});
-myPort.postMessage({greeting: "hello from content script"});
-
-myPort.onMessage.addListener(function(m) {
- console.log("In content script, received message from background script: ");
- console.log(m.greeting);
-});
-
-document.body.addEventListener("click", function() {
- myPort.postMessage({greeting: "they clicked the page!"});
-});</pre>
-
-<p>תסריט הרקע המכותב:</p>
-
-<ul>
- <li>מאזין לנסיונות ההתחברות של תסריט התוכן</li>
- <li>כשמקבל נסיון התחברות:
- <ul>
- <li>שומר את הפתחה במשתנה בשם <code>portFromCS</code></li>
- <li>שולח לתסריט התוכן הודעה באמצעות הפתחה</li>
- <li>מתחיל להאזין להודעות המתקבלות על גבי הפתחה, ורושם אותן ליומן</li>
- </ul>
- </li>
- <li>שולח הודעות לתסריט התוכן, using <code>portFromCS</code>, כשהמשתמש/ת מקליק/ה על פעולת הדפדפן של ההרחבה.</li>
-</ul>
-
-<pre class="brush: js">// background-script.js
-
-var portFromCS;
-
-function connected(p) {
- portFromCS = p;
- portFromCS.postMessage({greeting: "hi there content script!"});
- portFromCS.onMessage.addListener(function(m) {
- console.log("In background script, received message from content script");
- console.log(m.greeting);
- });
-}
-
-browser.runtime.onConnect.addListener(connected);
-
-browser.browserAction.onClicked.addListener(function() {
- portFromCS.postMessage({greeting: "they clicked the button!"});
-});
-</pre>
-
-<h4 id="תסריטי_תוכן_מרובים">תסריטי תוכן מרובים</h4>
-
-<p>אם יש לך תסריטי תוכן מרובים המתקשרים בו זמנית, ייתכן שתרצה/י לאחסן כל התחברות במערך.</p>
-
-
-
-<pre class="brush: js">// background-script.js
-
-var ports = []
-
-function connected(p) {
- ports[p.sender.tab.id]    = p
- //...
-}
-
-browser.runtime.onConnect.addListener(connected)
-
-browser.browserAction.onClicked.addListener(function() {
- ports.forEach(p =&gt; {
-        p.postMessage({greeting: "they clicked the button!"})
-    })
-});
-</pre>
-
-<ul>
-</ul>
-
-<h2 id="תקשורת_עם_דף_רשת">תקשורת עם דף רשת</h2>
-
-<p>למרות שכברירת מחדל תסריט תוכן אינם מקבלים הרשאת גישה לאובייקטים שנוצרו על ידי תסריטי דף, הם יכולים להתקשר עם תסריטי דף באמצעות ממשקי ה-DOM  <code><a href="/en-US/docs/Web/API/Window/postMessage">window.postMessage</a></code> ו-<code><a href="/en-US/docs/Web/API/EventTarget/addEventListener">window.addEventListener</a></code> .</p>
-
-<p>לדוגמא:</p>
-
-<pre class="brush: js">// page-script.js
-
-var messenger = document.getElementById("from-page-script");
-
-messenger.addEventListener("click", messageContentScript);
-
-function messageContentScript() {
- window.postMessage({
- direction: "from-page-script",
- message: "Message from the page"
- }, "*");</pre>
-
-<pre class="brush: js">// content-script.js
-
-window.addEventListener("message", function(event) {
- if (event.source == window &amp;&amp;
- event.data &amp;&amp;
- event.data.direction == "from-page-script") {
- alert("Content script received message: \"" + event.data.message + "\"");
- }
-});</pre>
-
-<p>לדוגמא שלמה עובדת של זה, <a href="https://mdn.github.io/webextensions-examples/content-script-page-script-messaging.html">בקרו בדף ההדגמה של- GitHub</a> ובצעו את ההוראות</p>
-
-<div class="warning">
-<p>יש לקחת בחשבון שכבל פעם שמתקשרים עם תוכן שאין בו אמון בדרך זו, יש לנקוט זהירות רבה. הרחבות הן קוד בעל פריבילגיות שיכולות להיות לו יכולות בעלות כוח עצום, ודפי תוכן עויינים יכולים לרמות אותם בקלות לדשת ליכולות אלה.</p>
-
-<p>לצורך דוגמא טריוויאלית, הניחו כי קוד של תסריט תוכן שמקבל את ההודעה עושה דבר כזה:</p>
-
-<pre class="brush: js">// content-script.js
-
-window.addEventListener("message", function(event) {
- if (event.source == window &amp;&amp;
- event.data.direction &amp;&amp;
- event.data.direction == "from-page-script") {
- eval(event.data.message);
- }
-});</pre>
-
-<p>כעת תסריט הדף יכול להריץ כל קוד עם כל הפריביליגיות של תסריט התוכן.</p>
-</div>
-
-<h2 id="שימוש_ב-_eval()_בתסריטי_תוכן">שימוש ב- <code>eval()</code> בתסריטי תוכן</h2>
-
-<p>בכרום, <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/eval">eval()</a></code> תמיד מריץ קוד בהקשר של תסריט התוכן, לא בהקשר של הדף.</p>
-
-<p>בפיירפוקס:</p>
-
-<ul>
- <li>אם נקראת הפונקציה <code>eval()</code>, היא מריצה קוד בהקשר של <strong>תסריט תוכן</strong>.</li>
- <li>אם נקראת הפונקציה <code>window.eval()</code>, היא מריצה קוד בהקשר של ה<strong>דף</strong>.</li>
-</ul>
-
-<p>לדוגמא, ניקח תסריט תוכן כזה:</p>
-
-<pre class="brush: js">// content-script.js
-
-window.eval('window.x = 1;');
-eval('window.y = 2');
-
-console.log(`In content script, window.x: ${window.x}`);
-console.log(`In content script, window.y: ${window.y}`);
-
-window.postMessage({
- message: "check"
-}, "*");</pre>
-
-<p>הקוד רק יוצר משתנים <code>x</code> ו- <code>y</code> באמצעות <code>window.eval()</code> ו-<code>eval()</code>, ואז רושם את ערכיהם ליומן, ואז שולח הודעה לדף.</p>
-
-<p>בהתקבל ההודעה, תסריט הדף רושם ליומן את אותם המשתנים:</p>
-
-<pre class="brush: js">window.addEventListener("message", function(event) {
- if (event.source === window &amp;&amp; event.data &amp;&amp; event.data.message === "check") {
- console.log(`In page script, window.x: ${window.x}`);
- console.log(`In page script, window.y: ${window.y}`);
- }
-});</pre>
-
-<p>בכרום, מופק פלט כזה:</p>
-
-<pre>In content script, window.x: 1
-In content script, window.y: 2
-In page script, window.x: undefined
-In page script, window.y: undefined</pre>
-
-<p>בפיירפוקס מופק הפלט הבא:</p>
-
-<pre>In content script, window.x: undefined
-In content script, window.y: 2
-In page script, window.x: 1
-In page script, window.y: undefined</pre>
-
-<p>אותו הדבר תקף עבור <code><a href="/en-US/docs/Web/API/WindowOrWorkerGlobalScope/setTimeout">setTimeout()</a></code>, <code><a href="/en-US/docs/Web/API/WindowOrWorkerGlobalScope/setInterval">setInterval()</a></code>, ו- <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function">Function()</a></code>.</p>
-
-<div class="blockIndicator warning">
-<p>בעת הרצת קוד בהקשר של דף, יש להיזהר מאוד. סביבת הדף נשלטת על ידי דפי רשת בעלי פוטנציאל לזדוניות, דבר היכול להגדיר מחדש אובייקטים איתם את/ה מתקשר/ת להתנהג בדרכים לא צפויות.</p>
-
-<pre class="brush: js">// page.js redefines console.log
-
-var original = console.log;
-
-console.log = function() {
-  original(true);
-}
-</pre>
-
-
-<pre class="brush: js">// content-script.js calls the redefined version
-
-window.eval('console.log(false)');
-</pre>
-</div>
diff --git a/files/he/mozilla/add-ons/webextensions/index.html b/files/he/mozilla/add-ons/webextensions/index.html
deleted file mode 100644
index 221ec714ca..0000000000
--- a/files/he/mozilla/add-ons/webextensions/index.html
+++ /dev/null
@@ -1,147 +0,0 @@
----
-title: הרחבות לדפדפנים
-slug: Mozilla/Add-ons/WebExtensions
-tags:
- - הרחבות
- - נחיתה
- - תוספים
-translation_of: Mozilla/Add-ons/WebExtensions
----
-<div>{{AddonSidebar}}</div>
-
-<p dir="rtl"><span class="seoSummary">הרחבות יכולות להרחיב ולשנות את יכולות הדפדפן. הרחבות של Firefox נבנות על-ידי <em>WebExtensions</em> API, מערכת חוצת-דפדפנים לפיתוח הרחבות.</span>המערכת תואמת ל- <a href="https://developer.chrome.com/extensions">extension API</a> הנתמך על-ידי Google Chrome ו- Opera ו- <a href="https://browserext.github.io/browserext/">W3C Draft Community Group</a> במידה נרחבת.</p>
-
-<p dir="rtl">הרחבות הנכתבות לדפדפנים אלה ירוצו ברוב המקרים ב- Firefox או ב-<a href="https://developer.microsoft.com/en-us/microsoft-edge/platform/documentation/extensions/">Microsoft Edge</a> עם <a href="/he/docs/Mozilla/Add-ons/WebExtensions/Porting_from_Google_Chrome">שינויים מועטים בלבד</a>. ה- API גם תואם באופן מלא <a href="/he/Firefox/Multiprocess_Firefox">multiprocess Firefox</a>.</p>
-
-<p dir="rtl">אם יש לך רעיונות או שאלות, או צורך בעזרה בהעברת תוספים ישנים ל-WebExtensions APIs, ניתן ליצור עימנו קשר ב-<a href="https://mail.mozilla.org/listinfo/dev-addons">רשימת התפוצה של dev-addons</a> או ב- <a dir="ltr" href="irc://irc.mozilla.org/webextensions">#webextensions</a> ב- <a href="https://wiki.mozilla.org/IRC">IRC</a>.</p>
-
-<div class="topicpage-table" dir="rtl">
-<div class="section">
-<h2 id="תחילת_עבודה">תחילת עבודה</h2>
-
-<ul>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/What_are_WebExtensions">מהן הרחבות?</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Your_first_WebExtension">ההרחבה הראשונה שלך</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Your_second_WebExtension">ההרחבה השנייה שלך</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Anatomy_of_a_WebExtension">האנטומיה של ההרחבה</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Firefox_workflow_overview">סקירת תזרים העבודה של Firefox</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Examples">הרחבות לדוגמא</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/What_next_">מה הלאה?</a></li>
-</ul>
-
-<h2 id="מושגים">מושגים</h2>
-
-<ul>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/API">סקירת JavaScript API</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Content_scripts">Content scripts</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Match_patterns">תבניות חיפוש</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Working_with_files">עבודה עם קבצים</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Internationalization">גלובליזציה</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Security_best_practices">שיטות אבטחה מומלצות</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Content_Security_Policy">מדיניות אבטחת תוכן</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Native_messaging">תקשורת עם Native</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Using_the_devtools_APIs">שימוש ב- devtools APIs</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/User_experience_best_practices">שיטות חווית משתמש מומלצות</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Native_manifests">Native manifests</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/User_actions">פעולות משתמש</a></li>
-</ul>
-
-<h2 id="ממשק_משתמש">ממשק משתמש</h2>
-
-<ul>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/user_interface">מבוא</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/user_interface/Browser_action">לחצן בסרגל כלים בדפדפן</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/user_interface/Popups">לחצן בסרגל כלים בדפדפן עם פופ-אפ</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/user_interface/Page_actions">לחצן בשורת הכתובת</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/user_interface/Popups">לחצן בשורת הכתובת עם פופ-אפ</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/user_interface/Context_menu_items">תפריט</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/user_interface/Sidebars">סרגלי צד</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/user_interface/Options_pages">עמוד האפשרויות</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/user_interface/Extension_pages">עמודי הרחבה</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/user_interface/Notifications">התרעות (נוטיפיקציות)</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/user_interface/Omnibox">הצעות לשורת הכתובת</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/user_interface/devtools_panels">פאנלים לכלי מפתחים</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/user_interface/Browser_styles">סגנונות דפדפנים</a></li>
-</ul>
-
-<h2 id="איך_לעשות">איך לעשות</h2>
-
-<ul>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Intercept_HTTP_requests">ליירט בקשות HTTP</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Modify_a_web_page">לשנות עמוד אינטרנט</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Add_a_button_to_the_toolbar">להוסיף לחצן לשורת הכלים</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Implement_a_settings_page">ליצור עמוד הגדרות</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Interact_with_the_clipboard">עבודה עם לוח ההעתקה</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Working_with_the_Tabs_API">עבודה עם טאבים (Tabs API)</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Work_with_the_Bookmarks_API">עבודה עם לשוניות (Bookmarks API)</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Work_with_the_Cookies_API">עבודה עם עוגיות (Cookies API)</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Work_with_contextual_identities">עבודה עם זהות הקשרית (contextual identities)</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Safely_inserting_external_content_into_a_page">להכניס תוכן חיצוני</a></li>
-</ul>
-
-<ul>
-</ul>
-
-<h2 id="הסבה">הסבה</h2>
-
-<ul>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Firefox_differentiators">מאבחני שונות של Firefox</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Porting_from_Google_Chrome">הסבת הרחבה של Google Chrome</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Porting_a_legacy_Firefox_add-on">הסבת הרחבה ישנה של Firefox</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Developing_WebExtensions_for_Firefox_for_Android">פיתוח ל- Firefox ב- Android</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Developing_WebExtensions_for_Thunderbird">פיתוח ל- Thunderbird</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Embedded_WebExtensions">WebExtensions מוטמעות</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Comparison_with_the_Add-on_SDK">השוואה מול Add-on SDK</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Comparison_with_XUL_XPCOM_extensions">השוואה מול הרחבות XUL/XPCOM</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Chrome_incompatibilities">חוסר תאימות עם Chrome</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Differences_between_desktop_and_Android">הבדלים בין שולחן עבודה (דסקטופ) ו- Android</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Differences_between_API_implementations">הבדלים בין מימושי API</a></li>
-</ul>
-
-<h2 id="תרשים_עבודה_של_Firefox">תרשים עבודה של Firefox</h2>
-
-<ul>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/User_experience_best_practices">חווית משתמש</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Temporary_Installation_in_Firefox">התקנה</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Debugging">ניפוי שגיאות (Debugging)</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Testing_persistent_and_restart_features">בדיקת אפשרויות מתמשכות ואתחול</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Getting_started_with_web-ext">תחילת עבודה עם web-ext</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/web-ext_command_reference">רשימת פקודות של web-ext</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/WebExtensions_and_the_Add-on_ID">מזהים של הרבחות ותוספים</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Distribution_options">אפשרויות הפצה</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Request_the_right_permissions">בקשת הרשאות נכונות</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Sharing_objects_with_page_scripts">שיתוף אובייקטים עם סקריפט עמוד</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Retiring_your_extension">סיום חיי ההרחבה שלך</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Tips">טיפים וטריקים</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Development_Tools">כלי פיתוח הרחבות לדפדפנים</a></li>
-</ul>
-</div>
-
-<div class="section">
-<h2 id="רשימת_מקורות">רשימת מקורות</h2>
-
-<h3 id="JavaScript_APIs">JavaScript APIs</h3>
-
-<ul>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/API">סקירת JavaScript API</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Browser_support_for_JavaScript_APIs">טבלאות השוואת תאימות של JavaScript APIs</a></li>
-</ul>
-
-<div class="twocolumns">{{ListSubpages("/en-US/docs/Mozilla/Add-ons/WebExtensions/API")}}</div>
-
-<h3 id="מפתחות_מניפסט">מפתחות מניפסט</h3>
-
-<ul>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/manifest.json">סקירת manifest.json</a></li>
- <li><a href="/he/docs/Mozilla/Add-ons/WebExtensions/Browser_compatibility_for_manifest.json">תאימות דפדפן ל- manifest.json</a></li>
-</ul>
-
-<div class="twocolumns">{{ListSubpages("/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json")}}</div>
-</div>
-</div>
-
-<div class="SnapLinksContainer" style="margin-left: 0px; margin-top: 0px; display: none;">
-<div class="SL_SelectionRect">
-<div class="SL_SelectionLabel"> </div>
-</div>
-</div>
diff --git a/files/he/mozilla/add-ons/webextensions/manifest.json/background/index.html b/files/he/mozilla/add-ons/webextensions/manifest.json/background/index.html
deleted file mode 100644
index cbd429b6f9..0000000000
--- a/files/he/mozilla/add-ons/webextensions/manifest.json/background/index.html
+++ /dev/null
@@ -1,116 +0,0 @@
----
-title: background
-slug: Mozilla/Add-ons/WebExtensions/manifest.json/background
-tags:
- - Manifest
- - WebExtensions
- - הרחבות
- - הרחבות רשת
- - עיון
- - תוספים
-translation_of: Mozilla/Add-ons/WebExtensions/manifest.json/background
----
-<div>{{AddonSidebar}}</div>
-
-<table class="fullwidth-table standard-table">
- <tbody>
- <tr>
- <th scope="row" style="width: 30%;">טיפוס</th>
- <td><code>Object</code></td>
- </tr>
- <tr>
- <th scope="row">חובה</th>
- <td>לא</td>
- </tr>
- <tr>
- <th scope="row">דוגמה</th>
- <td>
- <pre class="brush: json no-line-numbers notranslate">
-"background": {
- "scripts": ["background.js"]
-}</pre>
- </td>
- </tr>
- </tbody>
-</table>
-
-<p>השתמשו במפתח <code>background</code> כדי לכלול תסריט רקע אחד או יותר, עם אפשרות לדף רקע בהרחבתכם.</p>
-
-<p>תסריטי רקע הם המקום לשים קוד שצריך לתחזק מצב לטווח ארוך, או לבצע פעולות לטווח ארוך, ללא תלות בזמן החיים של דף מסוים מהרשת או חלון דפדפן.</p>
-
-<p>תסריטי רקע נטענים מיד כשההרחבה נטענת והם נשארים טעונים עד אשר ההרחבה מושבתת או מבוטלת, אלא אם <code>persistent</code> מקבל את הערך <code>false</code>. תוכלו להשתמש בכל אחד ממשקי פיתוח היישומים של הרחבות הרשת בתסריט, כל עוד ביקשתם את <a href="/he/docs/Mozilla/Add-ons/WebExtensions/manifest.json/permissions">ההרשאות</a> הנחוצות.</p>
-
-<p>ראו גם את הקטע "תסריטי רקע" ב- <a href="/he/docs/Mozilla/Add-ons/WebExtensions/Anatomy_of_a_WebExtension">אנטומיה של הרחבה</a> לפרטים נוספים.</p>
-
-<p>המפתח <code>background</code> הוא אובייקט שעשויות להיות לו שתי תכונות, ושתיהן אופציונליות:</p>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <td><code>scripts</code></td>
- <td>
- <p>מערך <code>(Array)</code> של מחרוזות ( <code>Strings</code>), שכל אחת מהן היא מסלול למקור בג'אווה-סקריפט. המסלול יחסי לקובץ manifest.json עצמו. אלה התסריטים שיבוצעו בדף הרקע של ההרחבה.</p>
-
- <p>התסריט משתף את אותו הקשר גלובלי  <code>window</code>.</p>
-
- <p>התסריטים נטענים על פי הסדר בו הם מופיעים במערך.</p>
-
- <p>אם תציינו ערך עבור <code>scripts</code>, דף ריק יווצר בו יורץ התסריט.</p>
-
- <div class="note">
- <p><strong>לתשומת לבך:</strong> אם ברצונך להביא תסריט ממיקום מרוחק עם התגית <code>&lt;script&gt;</code>  (לדוגמה,. <code>&lt;script src = "https://code.jquery.com/jquery-1.7.1.min.js"&gt;</code>), יהא עליך לשנות גם את המפתח <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/content_security_policy">content_security_policy</a></code> בקובץ manifest.json של ההרחבה שלך.</p>
- </div>
-
- <div class="note">
- <p><strong>לתשומת לבך:</strong> בגרסאות פיירפוקס שקדמו לגרסה 50, כשהדיבאגר היה פתוח, תסריטים לא תמיד נטענו על פי הסדר הניתן במערך . כדי לעקוף באג זה, ניתן להשתמש בתכונה <code>page</code> ולכלול תסריטי רקע מהדף באמצעות תגיות  <code>&lt;script&gt;</code>. באג זה תוקן בפיירפוקס 50. מנקודה זו ואילך,  תסריטים נטענים תמיד על פי הסדר הנתון במערך.</p>
- </div>
- </td>
- </tr>
- <tr>
- <td><code>page</code></td>
- <td>
- <p>אם יש לך צורך בתוכן כלשהו בדף, ניתן להגדיר דף משלך באמצעות התכונה  <code>page</code>, שהיא מחרוזת ( <code>String</code> ), המייצגת מסלול, יחסי לקובץ manifest.json, למסמך HTML הכלול בחבילת ההרחבה שלך.</p>
-
- <p>אם נעשה שימוש בתכונה זו, לא יהיה ניתן לציין תסריטי רקע באמצעות <code>scripts</code>, אך יהיה ניתן לכלול תסריטים משלך מהדף, בדיוק כשם שזה נעשה בדף רגיל מהרשת.</p>
- </td>
- </tr>
- </tbody>
-</table>
-
-<p>המפתח <code>background</code> יכול לכלול גם את התכונה האופציונלית הבאה:</p>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <td><code>persistent</code></td>
- <td>
- <p>ערך בוליאני( <code>Boolean</code> ).</p>
-
- <ul>
- <li><code>true</code> מציין כי דף הרקע נועד להישמר בזכרון מהרגע שההרחבה נטענה או שהדפדפן הופעל  עד שההרחבה מבוטלת או מושבתת, או שהדפדפן נסגר (כלומר, דף הרקע תמידי).</li>
- <li><code>false</code> מציין כי דף הרקע עשוי להיות מוסר מהזיכרון כשלא פעיל ולהיווצר מחדש במידת הצורך. דפי רקע כאלה קרויים לפעמים דפי אירוע כי הם נטענים לזיכרון כדי לאפשר לדף הרקע לטפל באירועים להם הוא הוסיף מאזינים. רישום המאזיננים הוא תמידי כאשר הדף מוסר מהזיכרון, אך ערכים אחרים אינם ץמידי. אם תרצו לשמור מידע תמידית בדף אירועים , תוכלו להשתמש ב  <a href="/he/docs/Mozilla/Add-ons/WebExtensions/API/storage">ממשק הפיתוח storage</a>.</li>
- </ul>
- </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="דוגמה">דוגמה</h2>
-
-<pre class="brush: json no-line-numbers notranslate">  "background": {
-    "scripts": ["jquery.js", "my-background.js"]
-  }</pre>
-
-<p>טוען שני תסריט רקע.</p>
-
-<pre class="brush: json notranslate"> "background": {
- "page": "my-background.html"
- }</pre>
-
-<p>תואן דף רקע מותאם אישית.</p>
-
-<h2 id="תאימות_דפדפנים">תאימות דפדפנים</h2>
-
-<p class="hidden">The compatibility table in this page is generated from structured data. If you'd like to contribute to the data, please check out <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> and send us a pull request.</p>
-
-<p>{{Compat("webextensions.manifest.background", 10)}}</p>
diff --git a/files/he/mozilla/add-ons/webextensions/manifest.json/index.html b/files/he/mozilla/add-ons/webextensions/manifest.json/index.html
deleted file mode 100644
index 13e7d0f8f8..0000000000
--- a/files/he/mozilla/add-ons/webextensions/manifest.json/index.html
+++ /dev/null
@@ -1,125 +0,0 @@
----
-title: manifest.json
-slug: Mozilla/Add-ons/WebExtensions/manifest.json
-tags:
- - Add-ons
- - Extensions
- - NeedsTranslation
- - Overview
- - TopicStub
- - WebExtensions
- - manifest.json
-translation_of: Mozilla/Add-ons/WebExtensions/manifest.json
----
-<p>{{AddonSidebar}}</p>
-
-<div class="blockIndicator note">
-<p>This article describes manifest.json for web extensions. If you are looking for information about the manifest.json in PWAs, check out the <a href="/en-US/docs/Web/Manifest">Web App Manifest</a> article.</p>
-</div>
-
-<p>The <code>manifest.json</code> file is the only file that every extension using WebExtension APIs must contain.</p>
-
-<p>Using <code>manifest.json</code>, you specify basic metadata about your extension such as the name and version, and can also specify aspects of your extension's functionality, such as background scripts, content scripts, and browser actions.</p>
-
-<p>It is a <a href="/en-US/docs/Glossary/JSON">JSON</a>-formatted file, with one exception: it is allowed to contain "<code>//</code>"-style comments.</p>
-
-<p><code>manifest.json</code> keys are listed below:</p>
-
-<div class="index">{{ListSubpages("/en-US/Add-ons/WebExtensions/manifest.json")}}</div>
-
-<p><code>"manifest_version"</code>, <code>"version"</code>, and <code>"name"</code> are the only mandatory keys. <code>"default_locale"</code> must be present if the "_locales" directory is present and must be absent otherwise. <code>"browser_specific_settings"</code> is not supported in Google Chrome.</p>
-
-<p>You can access your extension's manifest from the extension's JavaScript using the {{WebExtAPIRef("runtime.getManifest()")}} function:</p>
-
-<pre class="brush: js; no-line-numbers">browser.runtime.getManifest().version;</pre>
-
-<h2 id="Example">Example</h2>
-
-<p>The block below contains shows the basic syntax for some common manifest keys. Note that it is not intended to be used as a copy-paste-ready example: which keys you need will depend on the extension you are developing. For complete example extensions, see <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Examples">Example extensions</a>.</p>
-
-<pre class="brush: json;">{
- "browser_specific_settings": {
- "gecko": {
- "id": "addon@example.com",
- "strict_min_version": "42.0"
- }
- },
-
- "background": {
- "scripts": ["jquery.js", "my-background.js"],
- "page": "my-background.html"
- },
-
- "browser_action": {
- "default_icon": {
- "19": "button/geo-19.png",
- "38": "button/geo-38.png"
- },
- "default_title": "Whereami?",
- "default_popup": "popup/geo.html"
- },
-
- "commands": {
- "toggle-feature": {
-  "suggested_key": {
-    "default": "Ctrl+Shift+Y",
-    "linux": "Ctrl+Shift+U"
-  },
-     "description": "Send a 'toggle-feature' event"
- }
- },
-
- "content_security_policy": "script-src 'self' https://example.com; object-src 'self'",
-
- "content_scripts": [
- {
- "exclude_matches": ["*://developer.mozilla.org/*"],
- "matches": ["*://*.mozilla.org/*"],
- "js": ["borderify.js"]
- }
- ],
-
- "default_locale": "en",
-
- "description": "...",
-
- "icons": {
- "48": "icon.png",
- "96": "icon@2x.png"
- },
-
- "manifest_version": 2,
-
- "name": "...",
-
- "page_action": {
- "default_icon": {
- "19": "button/geo-19.png",
- "38": "button/geo-38.png"
- },
- "default_title": "Whereami?",
- "default_popup": "popup/geo.html"
- },
-
- "permissions": ["webNavigation"],
-
- "version": "0.1",
-
- "user_scripts": {
- "api_script": "apiscript.js",
- },
-
- "web_accessible_resources": ["images/my-image.png"]
-}</pre>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-<p>For a full overview of all manifest keys and their sub-keys, <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Browser_compatibility_for_manifest.json">see the full <code>manifest.json</code> browser compatibility table</a>.</p>
-
-
-
-<p>{{Compat("webextensions.manifest")}}</p>
-
-<h2 id="See_also">See also</h2>
-
-<p>{{WebExtAPIRef("permissions")}} JavaScript API</p>
diff --git a/files/he/mozilla/add-ons/webextensions/manifest.json/permissions/index.html b/files/he/mozilla/add-ons/webextensions/manifest.json/permissions/index.html
deleted file mode 100644
index b5ad7321b4..0000000000
--- a/files/he/mozilla/add-ons/webextensions/manifest.json/permissions/index.html
+++ /dev/null
@@ -1,199 +0,0 @@
----
-title: הרשאות
-slug: Mozilla/Add-ons/WebExtensions/manifest.json/permissions
-tags:
- - manifest.json
- - הפניה
- - הרחבות
- - הרחבות רשת
- - הרשאות
- - תוספים
-translation_of: Mozilla/Add-ons/WebExtensions/manifest.json/permissions
-original_slug: Mozilla/Add-ons/WebExtensions/manifest.json/הרשאות
----
-<p>{{AddonSidebar}}</p>
-
-<table class="fullwidth-table standard-table">
- <tbody>
- <tr>
- <th scope="row" style="width: 30%;">טיפוס</th>
- <td><code>Array</code></td>
- </tr>
- <tr>
- <th scope="row">חובה</th>
- <td>לא</td>
- </tr>
- <tr>
- <th scope="row">דוגמה</th>
- <td>
- <pre class="brush: json; no-line-numbers">
-"permissions": [
- "*://developer.mozilla.org/*",
- "webRequest"
-]</pre>
- </td>
- </tr>
- </tbody>
-</table>
-
-<p>השתמשו במפתח <code>permissions</code> לבקש כוחות מיוחדים עבור ההרחבה שלכם. מפתח זה הינו מערך של מחרוזות, וכל אחת ממחרוזות אלו היא בקשת הרשאה.</p>
-
-<p>אם תבקשו הרשאות באמצעות מפתח זה, אזי הדפדפן עשוי  לדווח למשתמש/ת בעת ההתקנה שההרבה מבקשת פריבילגיות מסויימות, ולבקש ממנו/ה לאשר כי  ישמח/תשמח להעניק פריבילגיות אלו. הדפדפן עשוי גם להתיר למשתמש/ץ לבדוק פריבילגיות ההרחבה אחרי ההתקנה. כשם שהבקשה להעניק פריבילגיות עשויה להשפיע על נכונות המשתמש/ת להתקין את ההרחבה, בקשת פריבילגיות שווה הפעלה זהירה של שיקול דעת.  לדוגמה, אם תרצו להימנע מלבקש הרשאות לא נחוצות  ותרצו לספק מידע עודות הסיבה לבקשת הרשאות בתיאור המוצר של ההרחבה שלכם. מידע נוסף על העניינים שיש לקחת בחשבון תוכלו למצוא במאמר  <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Request_the_right_permissions">Request the right permissions</a>.</p>
-
-<p>למידע נוסף כיצד לבחון ולצפות בבקשת הרשאות ראו <a href="https://extensionworkshop.com/documentation/develop/test-permission-requests/">Test permission requests</a>  באתר Extension Workshop site.</p>
-
-<p>המפתח יכול להכיל שלושה סוגי הרשאות:</p>
-
-<ul>
- <li>הרשאות מארח</li>
- <li>הרשאות ממשק פיתוח יישומים</li>
- <li>הרשאות לשונית פעילה</li>
-</ul>
-
-<h2 id="הרשאות_מארח">הרשאות מארח</h2>
-
-<p>הרשאות מארח מפורטות ב- <a href="https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/Match_patterns">match patterns</a>, וכל תבנית מזהה קבוצה של כתובות  URLs עבורן ההרחבה מבקשת פריבילגיות נוספות. לדוגמה, בקשת מארח יכולה להיות  <code>"*://developer.mozilla.org/*"</code>.</p>
-
-<p>פריבילגיות נוספות כוללות:</p>
-
-<ul>
- <li><a href="/en-US/docs/Web/API/XMLHttpRequest">גישת XMLHttpRequest</a> ו- <a href="/en-US/docs/Web/API/Fetch_API">fetch</a> למקורות ללא  מגבלות בין מקורות (אפילו עבור בקשות שנעשו מתוך תסריטי תוכן)</li>
- <li>היכולת להחדיר תסריטים על ידי תכנות (באמצעות <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/tabs/executeScript">tabs.executeScript</a>) לתוך דפים המוגשים מתמקורות אלו.</li>
- <li>היכולת לקבל אירועים מתוך ממשקי הפיתוח של  <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/webRequest">webRequest</a> עבור מארחים אלה</li>
- <li>היכולת לקבל עוגיות עבור אותו מארח באמצעות ממשק הפיתוח של  <a href="/en-US/Add-ons/WebExtensions/API/cookies">cookies</a> , כל עוד גם הרשאות ממשק הפיתוח "cookies" כלולות.</li>
- <li>עקיפת ההגנות מפני  מעקב אם המארח הוא שם מתחם מלא בלי ג'וקרים . לא עובד עם <code>&lt;all_urls&gt;</code>.</li>
-</ul>
-
-<p>בפירפוקס, מגירסה 56 ואילך, הרחבות מקבלות אוטומטית הרשאות מארח  עבור המקור של עצמן, שהוא בצורה:</p>
-
-<pre><code>moz-extension://60a20a9b-1ad4-af49-9b6c-c64c98c37920/</code></pre>
-
-<p>כש-  <code>60a20a9b-1ad4-af49-9b6c-c64c98c37920</code> הוא המזהה הפנימי של ההרחבה. ההרחבה יכולה לקבל את ה- URL תכנותית על ידי קריאה ל- <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/extension/getURL">extension.getURL()</a>:</p>
-
-<pre class="brush: js;">browser.extension.getURL("");
-// moz-extension://60a20a9b-1ad4-af49-9b6c-c64c98c37920/
-</pre>
-
-<h2 id="הרשאות_ממשק_פיתוח_יישומים">הרשאות ממשק פיתוח יישומים</h2>
-
-<p>הרשאות ממשק פיתוח היישומים מפורטות כמילות מפתח, וכל מילת מפתח מהווה שם של  <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API">WebExtension API</a> שההרחבה מעוניינת להשתמש בו.</p>
-
-<p>כעת זמינות מילות המפתח הבאות:</p>
-
-<ul>
- <li><code>activeTab</code></li>
- <li><code>alarms</code></li>
- <li><code>background</code></li>
- <li><code>bookmarks</code></li>
- <li><code>browserSettings</code></li>
- <li><code>browsingData</code></li>
- <li><code>clipboardRead</code></li>
- <li><code>clipboardWrite</code></li>
- <li><code>contentSettings</code></li>
- <li><code>contextMenus</code></li>
- <li><code>contextualIdentities</code></li>
- <li><code>cookies</code></li>
- <li><code>debugger</code></li>
- <li><code>dns</code></li>
- <li><code>downloads</code></li>
- <li><code>downloads.open</code></li>
- <li><code>find</code></li>
- <li><code>geolocation</code></li>
- <li><code>history</code></li>
- <li><code>identity</code></li>
- <li><code>idle</code></li>
- <li><code>management</code></li>
- <li><code>menus</code></li>
- <li><code>menus.overrideContext</code></li>
- <li><code>nativeMessaging</code></li>
- <li><code>notifications</code></li>
- <li><code>pageCapture</code></li>
- <li><code>pkcs11</code></li>
- <li><code>privacy</code></li>
- <li><code>proxy</code></li>
- <li><code>search</code></li>
- <li><code>sessions</code></li>
- <li><code>storage</code></li>
- <li><code>tabHide</code></li>
- <li><code>tabs</code></li>
- <li><code>theme</code></li>
- <li><code>topSites</code></li>
- <li><code>unlimitedStorage</code></li>
- <li><code>webNavigation</code></li>
- <li><code>webRequest</code></li>
- <li><code>webRequestBlocking</code></li>
-</ul>
-
-<p>ברוב המקרים ההרשאה רק מעניקה גישה לממשק פיתוח היישומים, עם יוצאי הדופן הבאים:</p>
-
-<ul>
- <li><code>tabs</code> מאפשר לך גישה ל <a href="/en-US/Add-ons/WebExtensions/API/tabs">חלקים בעלי הפריבילגיות של ממשק ה-t<code>abs </code> </a>:<code>Tab.url</code>, <code>Tab.title</code>, ו- <code>Tab.faviconUrl</code>. בפיירפוקס, יש צורך ב- <code>tabs</code> אם ברצונך לכלול גם  <code>url</code> בפרמטר <code>queryInfo</code>  ל-<code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/tabs/query">tabs.query()</a></code>. בכל יתר ממשק הפחתוח של  <code>tabs</code> ניתן להשתמש בלי לבקש כל הרשאה.</li>
- <li><code>webRequestBlocking</code> מאפשר לך להשתמש גם בארגומנט "blocking", כך שיהיה ניתן  <a href="/en-US/Add-ons/WebExtensions/API/WebRequest">לשנות ולבטל הרשאות</a>.</li>
- <li><code>downloads.open</code> מאפשר לך להשתמש ב- {{WebExtAPIRef("downloads.open()")}} API.</li>
- <li><code>tabHide</code> מאפשר לך להשתמש ב- {{WebExtAPIRef("tabs.hide()")}} API.</li>
-</ul>
-
-<h2 id="הרשאת_activeTab">הרשאת activeTab</h2>
-
-<p>הרשאה זו מצויינת כ- <code>"activeTab"</code>. אם להרחבה יש הרשאה זו , אזי בעת תקשורת בין משתמש/ת להרחבה, מוענקות להרחבה פריבילגיות  נוספות ללשונית הפעילה בלבד.</p>
-
-<p>"תקשורת עם המשתמש" כוללת:</p>
-
-<ul>
- <li>כאשר המשתמש/ת מקיש.ה על פעולת הדפדפן או פעולת הדף של ההרחבה</li>
- <li>כאשר המשתמש/ת בוחר'ת את פריט תפריט ההקשר שלה.</li>
- <li>the user activates a keyboard shortcut defined by the extension</li>
-</ul>
-
-<p>הפריבילגיות הנוספות הן:</p>
-
-<ul>
- <li>היכולת להחדיר JavaScript או CSS באמצעות תכנות לתוך הלשונית באמצעות,  <code><a href="/en-US/Add-ons/WebExtensions/API/tabs/executeScript">browser.tabs.executeScript</a></code> ו-<code><a href="/en-US/Add-ons/WebExtensions/API/tabs/insertCSS">browser.tabs.insertCSS</a></code></li>
- <li>גישה לחלקים הפריבילגיים של ממשק פיתוח הלשונית עבור הלשונית הנוכחית: <code>Tab.url</code>, <code>Tab.title</code>, ו-<code>Tab.faviconUrl</code>.</li>
-</ul>
-
-<p>הכוונה בהרשאה זו היא לאפשר להרחבות להגשים מקרה שימוש נפוץ, ללא הצורך לתת להן הרשאות בעלות כוח רב מדי. הרשאות רבוטת יהיו מעונינות "לעשות משהו לדף הנוכחי כאשר המשתמש/ת מבקש/ת". לדוגמה, קחו בחשבון הרחבה המבקשת להריץ תסריט בדף הנוכחי כאשר המשתמש/ת מקישה על פעולת דפדפן. אם ההרשאה  <code>activeTab</code> לא הייתה קיימת, ההרחבה הייתה צריכה לבקש את ההרשאת המארח   <code>&lt;all_urls&gt;</code>. אבל זה נותן להרחבה יותר כוח ממה שדרוש לה:  היא הייתה יכולה כעת לבצע תסריטים בכל לשונית, בכל עת שתרצה, במקום רק בלשונית הפעילה ורק בתגובה לפעולת משתמש/ת.</p>
-
-<p>שימו לב כי תוכלו לקבל גישה רק ללשונית/מידע שכבר שם, כאשר ההתקשרות מצד המשתמש/ת התקיימה (למשל. ההקשה). כאשר הלשונית הפעילה מנווטת למקום אחר, למשל עקב סיום טעינה או אירוע אחר כלשהו, ההרשאה אינה מעניקה לך יותר גישה ללשונית.</p>
-
-<p>בדרך כלל הלשונית המקבלת את הרשאת <code>activeTab</code> היא רק הלשונית הפעילה באותו רגע, פרט למקרה אחד. ממשק היישומים <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/menus">menus</a></code> מאפשר להרחבה ליצור פריט תפריט המוצג כאשר המשתמש/ת מקיש/ה הקשת הקשר בלשונית  (כלומר, על הרכיב בפס הלשוניות המשאפשר למשתמש/ת לעבור מלשונית ללשונית). אם המשתמש/ת מקיש/ה על פריט כזה, אזי הרשאת  <code>activeTab</code> מוענקת ללשונית שהוקש עליה, אף אם זו אינה הלשונית הפעילה (נכון לפיירפוקס 63, {{bug(1446956)}}).</p>
-
-<h2 id="גישה_ללוח_הגזירים">גישה ללוח הגזירים</h2>
-
-<p>קיימות שתי הרשאות המאפשרות להרחבה  לתקשר עם לוח הגזירים:</p>
-
-<ul>
- <li><code>clipboardWrite</code>: כותבת ללוח הגזירים באמצעות {{DOMxRef("Clipboard.write()")}}, {{DOMxRef("Clipboard.writeText()")}}, <code>document.execCommand("copy")</code> or <code>document.execCommand("cut")</code></li>
- <li><code>clipboardRead</code>: קוראת מלוח הגזירים באמצעות {{DOMxRef("Clipboard.read()")}}, {{DOMxRef("Clipboard.readText()")}} or <code>document.execCommand("paste")</code></li>
-</ul>
-
-<p>ראו <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Interact_with_the_clipboard">Interact with the clipboard</a> לכל הפרטים אודות הדבר.</p>
-
-<h2 id="אחסון_ללא_הגבלה">אחסון ללא הגבלה</h2>
-
-<p>הרשאת <code>unlimitedStorage</code>:</p>
-
-<ul>
- <li>מאפשרת להרחבה לחרוג מכל מכסה הנאכפת על ידי ממשק היישומים  {{WebExtAPIRef("storage.local")}}</li>
- <li>בפיירפוקס, מאפשרת להרחבה ליצור  <a href="/en-US/docs/Web/API/IndexedDB_API/Browser_storage_limits_and_eviction_criteria#Firefox_specifics">"persistent" IndexedDB database</a>, מבלי שהדפדפן יעצור לקבלת הרשאות מהמשתמ/ת בעת יצירת בסיב הנתונים.</li>
-</ul>
-
-<h2 id="דוגמה">דוגמה</h2>
-
-<pre class="brush: json no-line-numbers"> "permissions": ["*://developer.mozilla.org/*"]</pre>
-
-<p>לבקשת הרשאה בעלת פריבילגיה  לדפים תחת developer.mozilla.org.</p>
-
-<pre class="brush: json no-line-numbers"> "permissions": ["tabs"]</pre>
-
-<p>לבקשת גישה לחלקים בעלי פריבילגיה של ממשק הפיתוח  <code>tabs</code>.</p>
-
-<pre class="brush: json no-line-numbers"> "permissions": ["*://developer.mozilla.org/*", "tabs"]</pre>
-
-<p>לבקשת שתי ההרשאות שלעיל.</p>
-
-<h2 id="תאימות_דפדפנים">תאימות דפדפנים</h2>
-
-<p class="hidden">טבלת התאימות בדף זה נוצרת ממידע ממובנה. אם תרצה לתרום לנתונים, נא לשלוף <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> ולשלוח לנו בקשת משיכה.</p>
-
-<p>{{Compat("webextensions.manifest.permissions")}}</p>
diff --git a/files/he/mozilla/add-ons/webextensions/modify_a_web_page/index.html b/files/he/mozilla/add-ons/webextensions/modify_a_web_page/index.html
deleted file mode 100644
index 8ad3ab8cc5..0000000000
--- a/files/he/mozilla/add-ons/webextensions/modify_a_web_page/index.html
+++ /dev/null
@@ -1,252 +0,0 @@
----
-title: שינוי דפים מהרשת
-slug: Mozilla/Add-ons/WebExtensions/Modify_a_web_page
-translation_of: Mozilla/Add-ons/WebExtensions/Modify_a_web_page
----
-<div>{{AddonSidebar}}</div>
-
-<p>אחד השימושים הנפוצים להרחגה הוא לשנות דף מהרשת. לדוגמה,  הרחבה עשויה לרצות שלנות את הסגנון שבשימוש הדף , להסתיר צמתי DOM מסויימים, או להחדיר צמתי DOM נוןספים לדף.</p>
-
-<p>קיימות שתי דרכים לעשות זאת עם ממשקי פיתוח הרחבות הרשת:</p>
-
-<ul>
- <li><strong>הצהרתית</strong>: על ידי הגדרת תבנית התואמת קבוצה של כתובות URL, וטעינת קבוצה של תסריטים לתוך בדפים שכתובת ה-URL שלהם תואמת את התבנית.</li>
- <li><strong>תכנותית</strong>: באמתעות ממשקי פיתוח יישומי ג'אווה-סקריפט, טעינת התסריט לתוך הדף המאורח בלשונית מסויימת.</li>
-</ul>
-
-<p>בכל דרך, תסריטים אלה קרויים תסריטי תוכן, והם שונים מתסריטים אחרים שההרחבה עשויה מהם:</p>
-
-<ul>
- <li>יש להם גישה רק לקבוצה קטנה של ממשקי פיתוח ההרחבות הרשת.</li>
- <li>יש להם גישה ישירה לדפי הרשת אליהם הם נטענו.</li>
- <li>הם מתקשרים עם שאר ההרחבה באמצעות ממשק פיתוח היישמוים של מערכת ההודעות.</li>
-</ul>
-
-<p>במאמר זה נתבונן בשתי השיטות של טעינת תסריט.</p>
-
-<h2 id="שינויים_בדפים_התואמים_תבנית_URL">שינויים בדפים התואמים תבנית URL</h2>
-
-<p>קודם כל, צרו תיקייה חדשה בשם "modify-page". בתיקייה זו, צרו קובץ בשם   "manifest.json", המכיל את התוכן הבא:</p>
-
-<pre class="brush: json notranslate">{
-
- "manifest_version": 2,
- "name": "modify-page",
- "version": "1.0",
-
- "content_scripts": [
- {
- "matches": ["https://developer.mozilla.org/*"],
- "js": ["page-eater.js"]
- }
- ]
-
-}</pre>
-
-<p>המפתח <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/content_scripts">content_scripts</a></code> הוא הדרך לטעון תסריטים לתוך דפים התואמים תבניות  URL  במקרה זה, <code>content_scripts</code> מורה לדפדפן לטעון תסריט בשם   "page-eater.js" לתוך כל הדפים תחת <a href="https://developer.mozilla.org/">https://developer.mozilla.org/</a>.</p>
-
-<div class="note">
-<p>מאחר שהתכונה <code>"js"</code> של  <code>content_scripts</code> היא מערך, תוכלו להשתמש בה כדי להחדיר יותר מתסריט אחד לתוך דפים תואמים . אם תעשו זאת דף יחלוק את אותו התחום, כשם שתסריטים מרובים הנטענים על ידי דף, והם ייטענו בסדר שנרשמו בתוך המערך.</p>
-</div>
-
-<div class="note">
-<p>למפתח <code>content_scripts</code> יש גם תכונת <code>"css"</code> בה תוכלו להשתמש כדי להחסיר דפי סגנונות המקודדים ב-CSS</p>
-</div>
-
-<p>כעת, צרו קובץ בשם "page-eater.js" בתוך התיקייה "modify-page" , ושימו בו את התוכן הבא:</p>
-
-<pre class="brush: js notranslate">document.body.textContent = "";
-
-var header = document.createElement('h1');
-header.textContent = "This page has been eaten";
-document.body.appendChild(header);</pre>
-
-<p>כעת <a href="https://developer.mozilla.org/en-US/Add-ons/WebExtensions/Temporary_Installation_in_Firefox">iהתקינו את ההרחבה</a>, ובקרו בדף <a href="https://developer.mozilla.org/">https://developer.mozilla.org:/</a></p>
-
-<p>{{EmbedYouTube("lxf2Tkg6U1M")}}</p>
-
-<div class="note">
-<p>שימו לב כי למרות שבסרטון מוצג תסריט תוכן הפועל ב- <a href="https://addons.mozilla.org/en-US/firefox/">addons.mozilla.org</a>, תסריטי תוכן לעת עתה חסומים באתר זה.</p>
-</div>
-
-<h2 id="שינוי_דפים_תכנותית">שינוי דפים תכנותית</h2>
-
-<p>מה אם תרצו לאכול דפים, אבל רק כשהמשתמש/ת מבקש/ת זאת? הבה נעדכן את הדוגמה הבאה כך שנחדיר תסריט תוכן כאשר משתמש/ת מקיש/ה על פריט מתפריט ההקשר.</p>
-
-<p>תחילה, עדכנו את  "manifest.json" כך שיכיל את התוכן הבא:</p>
-
-<pre class="brush: json notranslate">{
-
- "manifest_version": 2,
- "name": "modify-page",
- "version": "1.0",
-
- "permissions": [
- "activeTab",
- "contextMenus"
- ],
-
- "background": {
- "scripts": ["background.js"]
- }
-
-}</pre>
-
-<p>כאן, הוצאנו את המפתח <code>content_scripts</code>, והוספנו שני מפתחות חדשים:</p>
-
-<ul>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/permissions">permissions</a></code>: להחדיר תסריטים לתוך דפים שדרושות הרשאות לדפים שאנו מעדכנים. ההרשאה <a href="/he/docs/Mozilla/Add-ons/WebExtensions/manifest.json/הרשאות#הרשאות_ממשק_פיתוח_יישומים"><code>activeTab</code></a> היא דרך להשיג זאת זמנית עבור הלשונית הפעילה באותו רגע . דרושה לנו גם ההרשאה <code>contextMenus</code> כדי שנוכל להוסיף פריטים לתפריט ההקשר.</li>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/background">background</a></code>: We're using this to load a persistent <a href="/en-US/Add-ons/WebExtensions/Anatomy_of_a_WebExtension#Background_scripts">"background script"</a> called "background.js", in which we'll set up the context menu and inject the content script.</li>
-</ul>
-
-<p>Let's create this file. Create a new file called "background.js" in the "modify-page" directory, and give it the following contents:</p>
-
-<pre class="brush: js notranslate">browser.contextMenus.create({
- id: "eat-page",
- title: "Eat this page"
-});
-
-browser.contextMenus.onClicked.addListener(function(info, tab) {
- if (info.menuItemId == "eat-page") {
- browser.tabs.executeScript({
- file: "page-eater.js"
- });
- }
-});
-</pre>
-
-<p>In this script we're creating a <a href="/en-US/Add-ons/WebExtensions/API/ContextMenus/create">context menu item</a>, giving it a specific id and title (the text to be displayed in the context menu). Then we set up an event listener so that when the user clicks a context menu item, we check to see if it is our <code>eat-page</code> item. If it is, we inject "page-eater.js" into the current tab using the <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/tabs/executeScript">tabs.executeScript()</a></code> API. This API optionally takes a tab ID as an argument: we've omitted the tab ID, which means that the script is injected into the currently active tab.</p>
-
-<p>At this point the extension should look like this:</p>
-
-<pre class="line-numbers language-html notranslate"><code class="language-html">modify-page/
- background.js
- manifest.json
- page-eater.js</code></pre>
-
-<p>Now <a href="https://developer.mozilla.org/en-US/Add-ons/WebExtensions/Temporary_Installation_in_Firefox#Reloading_a_temporary_add-on">reload the extension</a>, open a page (any page, this time) activate the context menu, and select "Eat this page":</p>
-
-<p>{{EmbedYouTube("zX4Bcv8VctA")}}</p>
-
-<div class="note">
-<p>Note that although this video shows the content script working in <a href="https://addons.mozilla.org/en-US/firefox/">addons.mozilla.org</a>, content scripts are currently blocked for this site.</p>
-</div>
-
-<h2 id="Messaging">Messaging</h2>
-
-<p>Content scripts and background scripts can't directly access each other's state. However, they can communicate by sending messages. One end sets up a message listener, and the other end can then send it a message. The following table summarises the APIs involved on each side:</p>
-
-<table class=" fullwidth-table standard-table">
- <thead>
- <tr>
- <th scope="row"></th>
- <th scope="col">In content script</th>
- <th scope="col">In background script</th>
- </tr>
- <tr>
- <th scope="row">Send a message</th>
- <td><code><a href="/en-US/Add-ons/WebExtensions/API/runtime#sendMessage()">browser.runtime.sendMessage()</a></code></td>
- <td><code><a href="/en-US/Add-ons/WebExtensions/API/Tabs/sendMessage">browser.tabs.sendMessage()</a></code></td>
- </tr>
- <tr>
- <th scope="row">Receive a message</th>
- <td><code><a href="/en-US/Add-ons/WebExtensions/API/runtime/onMessage">browser.runtime.onMessage</a></code></td>
- <td><code><a href="/en-US/Add-ons/WebExtensions/API/runtime#onMessage">browser.runtime.onMessage</a></code></td>
- </tr>
- </thead>
-</table>
-
-<div class="blockIndicator note">
-<p>In addition to this method of communication, which sends one-off messages, you can also use a <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Content_scripts#Connection-based_messaging">connection-based approach to exchange messages</a>. For advice on choosing between the options, see <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Content_scripts#Choosing_between_one-off_messages_and_connection-based_messaging">Choosing between one-off messages and connection-based messaging</a>.</p>
-</div>
-
-<p>Let's update our example to show how to send a message from the background script.</p>
-
-<p>First, edit "background.js" so that it has these contents:</p>
-
-<pre class="brush: js notranslate">browser.contextMenus.create({
- id: "eat-page",
- title: "Eat this page"
-});
-
-function messageTab(tabs) {
- browser.tabs.sendMessage(tabs[0].id, {
- replacement: "Message from the extension!"
- });
-}
-
-function onExecuted(result) {
-    var querying = browser.tabs.query({
-        active: true,
-        currentWindow: true
-    });
-    querying.then(messageTab);
-}
-
-browser.contextMenus.onClicked.addListener(function(info, tab) {
- if (info.menuItemId == "eat-page") {
- let executing = browser.tabs.executeScript({
- file: "page-eater.js"
- });
- executing.then(onExecuted);
- }
-});
-</pre>
-
-<p>Now, after injecting "page-eater.js", we use <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/tabs/query">tabs.query()</a></code> to get the currently active tab, and then use <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/tabs/sendMessage">tabs.sendMessage()</a></code> to send a message to the content scripts loaded into that tab. The message has the payload <code>{replacement: "Message from the extension!"}</code>.</p>
-
-<p>Next, update "page-eater.js" like this:</p>
-
-<pre class="brush: js notranslate">function eatPageReceiver(request, sender, sendResponse) {
- document.body.textContent = "";
- var header = document.createElement('h1');
- header.textContent = request.replacement;
- document.body.appendChild(header);
-}
-browser.runtime.onMessage.addListener(eatPageReceiver);
-</pre>
-
-<p>Now instead of just eating the page right away, the content script listens for a message using <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/runtime/onMessage">runtime.onMessage</a></code>. When a message arrives, the content script runs essentially the same code as before, except that the replacement text is taken from <code>request.replacement</code>.</p>
-
-<p>Since <code><a href="/en-US/Add-ons/WebExtensions/API/tabs/executeScript">tabs.executeScript()</a></code> is an asynchronous function, and to ensure we send message only after listener has been added in "page-eater.js", we use <code>onExecuted</code> which will be called after "page-eater.js" executed.</p>
-
-<div class="note">
-<p>Press Ctrl+Shift+J (or Cmd+Shift+J on a Mac) OR <code>web-ext run --bc</code> to open <a href="/en-US/docs/Tools/Browser_Console">Browser Console</a> to view <code>console.log</code> in background script. Alternatively use <a href="/en-US/Add-ons/Add-on_Debugger">Add-on Debugger</a>  which allows you set breakpoint. There is currently no way to <a href="https://github.com/mozilla/web-ext/issues/759">start Add-on Debugger directly from web-ext</a>.</p>
-</div>
-
-<p>If we want send messages back from the content script to the background page,  we would use <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/runtime/sendMessage">runtime.sendMessage()</a></code> instead of <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/tabs/sendMessage">tabs.sendMessage()</a></code>, e.g.:</p>
-
-<pre class="brush: js notranslate">browser.runtime.sendMessage({
- title: "from page-eater.js"
-});</pre>
-
-<div class="note">
-<p>These examples all inject JavaScript; you can also inject CSS programmatically using the <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/tabs/insertCSS">tabs.insertCSS()</a></code> function.</p>
-</div>
-
-<h2 id="Learn_more">Learn more</h2>
-
-<ul>
- <li><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Content_scripts">Content scripts</a> guide</li>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/content_scripts">content_scripts</a></code> manifest key</li>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/permissions">permissions</a></code> manifest key</li>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/tabs/executeScript">tabs.executeScript()</a></code></li>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/tabs/insertCSS">tabs.insertCSS()</a></code></li>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/tabs/sendMessage">tabs.sendMessage()</a></code></li>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/runtime/sendMessage">runtime.sendMessage()</a></code></li>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/runtime/onMessage">runtime.onMessage</a></code></li>
- <li>Examples using <code>content_scripts</code>:
- <ul>
- <li><a class="external external-icon" href="https://github.com/mdn/webextensions-examples/tree/master/borderify">borderify</a></li>
- <li><a class="external external-icon" href="https://github.com/mdn/webextensions-examples/tree/master/emoji-substitution" rel="noopener">emoji-substitution</a></li>
- <li><a class="external external-icon" href="https://github.com/mdn/webextensions-examples/tree/master/notify-link-clicks-i18n">notify-link-clicks-i18n</a></li>
- <li><a class="external external-icon" href="https://github.com/mdn/webextensions-examples/tree/master/page-to-extension-messaging">page-to-extension-messaging</a></li>
- </ul>
- </li>
- <li>Examples using <code>tabs.executeScript()</code>:
- <ul>
- <li><a class="external external-icon" href="https://github.com/mdn/webextensions-examples/tree/master/beastify">beastify</a></li>
- <li><a class="external external-icon" href="https://github.com/mdn/webextensions-examples/tree/master/context-menu-copy-link-with-types">context-menu-copy-link-with-types</a></li>
- </ul>
- </li>
-</ul>
diff --git a/files/he/mozilla/add-ons/webextensions/tips/index.html b/files/he/mozilla/add-ons/webextensions/tips/index.html
deleted file mode 100644
index 35b36bd5ae..0000000000
--- a/files/he/mozilla/add-ons/webextensions/tips/index.html
+++ /dev/null
@@ -1,58 +0,0 @@
----
-title: טיפים וטריקים
-slug: Mozilla/Add-ons/WebExtensions/Tips
-tags:
- - ECMAScript
- - אקמהסקריפט
- - הרחבות רשת
- - טיפים
- - טיפים וטריקים
- - טריקים
-translation_of: Mozilla/Add-ons/WebExtensions/Tips
-original_slug: Mozilla/Add-ons/WebExtensions/טיפום
----
-<p>{{AddonSidebar}}</p>
-
-<p>עמוד זה מכיל טיפים וטריקים שוניםהאמורים להיות שימושיים לאנשים רבים המפתחים הרחבות באמצעות ממשקי הפיתוח של הרחבות רשת.</p>
-
-<h2 id="שימוש_בתכונות_ג'אווהסקריפט_מתקדמות_מתוך_ECMAScript_2015_ו-2016">שימוש בתכונות ג'אווהסקריפט מתקדמות  מתוך ECMAScript 2015 ו-2016</h2>
-
-<p>פיירפוקס <a href="/Web/JavaScript/New_in_JavaScript/ECMAScript_6_support_in_Mozilla">תומך בתכונות רבות של  ECMAScript 2015</a> מלוץ לקופסה. תכונות חדשות ונסיוניות אחדות, לעומת זאת, אינן זמינות לרשת או להרחבות רשת כברירת מחדל.   ,אם ברצונך להשתמש בתכונות אלו, הטוב ביותר יהיה לתרגן את הקוד שלך על ידי שימוש בכלי כמו  <a href="https://babeljs.io/">Babel</a>.</p>
-
-<p>יש לתת את הדעת לכך שכל דבר תחת  לשורה זו הינו מידע לא מעודכן והוצא מ-Babel 6.</p>
-
-<p>Babel מספק טרנספורמציות לרוב הרחב של תכונות ES2015, ומאפשר אותן כברירת מחדל. מאחר ופיירפוקס כבר תומך באופן מלא ברובן, הטוב ביותר יהיה לקנפג את Babel להתעלם מהן. אנו ממליצים ליצור  קובץ<code> .babelrc</code> או מקטע <code>babel</code> בקובץ ה-<code>package.json</code> של הפרוייקט המכיל את הקוד הבא"</p>
-
-<pre class="brush: js">{
- "env": {
- "firefox": {
- "sourceMaps": "inline",
- "blacklist": [
- "es5.properties.mutators",
- "es6.arrowFunctions",
- "es6.destructuring",
- "es6.forOf",
- "es6.parameters",
- "es6.properties.computed",
- "es6.properties.shorthand",
- "es6.spec.symbols",
- "es6.spread",
- "es6.tailCall",
- "es6.templateLiterals",
- "es6.regex.sticky",
- "es6.regex.unicode"
- ]
- }
- }
-}
-</pre>
-
-<p>ואז, בשביל לקמפל תסרעט אינדיבידואלי, יש פשוט להריץ:</p>
-
-<pre class="brush: sh">BABEL_ENV=firefox babel &lt;filename&gt;
-</pre>
-
-<p>או, כדי לקמפל כל קובץ ג'אווהסקריפט תחת התיקיה <code>src</code> ולמקם את הקבצים המקומפלים ב-<code>compiled</code>, תוך העתקה על קבצים שאינם בג'אווהסקריפט, להריץ</p>
-
-<pre class="brush: sh">BABEL_ENV=firefox babel -Dd compiled src
-</pre>
diff --git a/files/he/mozilla/add-ons/webextensions/user_interface/browser_action/index.html b/files/he/mozilla/add-ons/webextensions/user_interface/browser_action/index.html
deleted file mode 100644
index d3ae50e9d9..0000000000
--- a/files/he/mozilla/add-ons/webextensions/user_interface/browser_action/index.html
+++ /dev/null
@@ -1,51 +0,0 @@
----
-title: כפתור בסרגל הכלים
-slug: Mozilla/Add-ons/WebExtensions/user_interface/Browser_action
-tags:
- - WebExtension
- - הרחבת רשת
-translation_of: Mozilla/Add-ons/WebExtensions/user_interface/Browser_action
----
-<div>{{AddonSidebar}}</div>
-
-<p>קרוי בשימוש נפוץ <a href="/he/docs/Mozilla/Add-ons/WebExtensions/API/browserAction">פכולת דפדפן</a>, אפשרות זו של ממשק המשתמש  היא כפתור המתוסף לסרגל הכלים של הדפדפן. המשתמשים מקישים על הכפתור כדי לתקשר עם ההרחבה שלך.<br>
- <img alt="" src="https://mdn.mozillademos.org/files/15751/browser-action.png" style="display: block; height: 182px; margin-left: auto; margin-right: auto; width: 350px;"></p>
-
-<p>הכפתור בסרגל הכלים (פעולת דפדפן) דומה לכפתור של שur, הכתובת (פעולת דף). להבדלים ולהדרכה מתי להשתמש במה,ראו <a href="/en-US/Add-ons/WebExtensions/user_interface/Page_actions#Page_actions_and_browser_actions">Page actions and browser actions</a>.</p>
-
-<h2 id="Specifying_the_browser_action">Specifying the browser action</h2>
-
-<p>You define the browser action's properties using the <code><a href="https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/browser_action">browser_action</a></code> key in manifest.json:</p>
-
-<pre class="brush: json notranslate"><code class="language-json">"browser_action": {
- "default_icon": {
- "19": "button/geo-19.png",
- "38": "button/geo-38.png"
- },
- "default_title": "Whereami?"
-}</code></pre>
-
-<p>The only mandatory key is <code>default_icon</code>.</p>
-
-<p>There are two ways to specify a browser action: with or without a <a href="/en-US/Add-ons/WebExtensions/Popups">popup</a>. If you don't specify a popup, when the user clicks the button an event is dispatched to the extension, which the extension listens for using <a href="https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/API/BrowserAction/onClicked" title="Fired when a browser action icon is clicked. This event will not fire if the browser action has a popup."><code>browserAction.onClicked</code></a>:</p>
-
-<pre class="brush: js line-numbers language-js notranslate"><code class="language-js">browser.browserAction.onClicked.addListener(<var>handleClick</var>);</code></pre>
-
-<p>If you specify a popup, the click event is not dispatched: instead, the popup is shown when the user clicks the button. The user is able to interact with the popup and it closes automatically when the user clicks outside it. See the <a href="/en-US/Add-ons/WebExtensions/Popups">Popup</a> article for more details on creating and managing popups.</p>
-
-<p>Note that your extension can have only one browser action.</p>
-
-<p>You can change many of the browser action properties programmatically using the <code><a href="https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/API/browserAction">browserAction</a></code> API.</p>
-
-<h2 id="Icons">Icons</h2>
-
-<p>For details on how to create icons to use with your browser action, see <a href="https://design.firefox.com/photon/visuals/iconography.html">Iconography</a> in the <a class="grey-90 no-underline hover-no-underline" href="https://design.firefox.com/photon/index.html">Photon Design System</a> documentation.</p>
-
-<h2 id="Examples">Examples</h2>
-
-<p>The <code><a href="https://github.com/mdn/webextensions-examples">webextensions-examples</a></code> repository on GitHub contains two examples of extensions that implement browser actions:</p>
-
-<ul>
- <li><a href="https://github.com/mdn/webextensions-examples/blob/master/bookmark-it/">bookmark-it</a> uses a browser action without a popup</li>
- <li><a href="https://github.com/mdn/webextensions-examples/tree/master/beastify">beastify</a> uses a browser action with a popup</li>
-</ul>
diff --git a/files/he/mozilla/add-ons/webextensions/user_interface/index.html b/files/he/mozilla/add-ons/webextensions/user_interface/index.html
deleted file mode 100644
index 78b988a523..0000000000
--- a/files/he/mozilla/add-ons/webextensions/user_interface/index.html
+++ /dev/null
@@ -1,97 +0,0 @@
----
-title: User interface
-slug: Mozilla/Add-ons/WebExtensions/user_interface
-tags:
- - Landing
- - NeedsTranslation
- - TopicStub
- - User Interface
- - WebExtensions
-translation_of: Mozilla/Add-ons/WebExtensions/user_interface
----
-<div>{{AddonSidebar}}</div>
-
-<p>Extensions that use WebExtension APIs are provided with several user interface options so that their functionality can be made available to the user. A summary of those options is provided below, with a more detailed introduction to each user interface option in this section.</p>
-
-<div class="note">
-<p>For advice on using these UI components to create a great user experience in your extension, please see the <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/User_experience_best_practices">User experience best practices</a> article.</p>
-</div>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">UI option</th>
- <th scope="col">Description</th>
- <th scope="col" style="width: 350px;">Example</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td><a href="/Add-ons/WebExtensions/user_interface/Browser_action">Toolbar button</a> (browser action)</td>
- <td>A button on the browser toolbar that dispatches an event to the extension when clicked. By default, the button is visible in all tabs.</td>
- <td><img alt="Example showing a toolbar button (browser action)." src="https://mdn.mozillademos.org/files/15751/browser-action.png" style="height: 364px; width: 700px;"></td>
- </tr>
- <tr>
- <td>Toolbar button with a <a href="https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/user_interface/Popups">popup</a></td>
- <td>A popup on a button in the browser toolbar that opens when the button is clicked. The popup is defined in an HTML document that handles the user interaction.</td>
- <td><img alt="Example of the pop-up on a toolbar button" src="https://mdn.mozillademos.org/files/15753/popup-shadow.png" style="height: 624px; width: 700px;"></td>
- </tr>
- <tr>
- <td><a href="/Add-ons/WebExtensions/user_interface/Page_actions">Address bar button</a> (page action)</td>
- <td>A button on the browser address bar that dispatches an event to the extension when clicked. By default, the button is hidden in all tabs.</td>
- <td><img alt="Example showing an address bar button (page action) " src="https://mdn.mozillademos.org/files/15745/address_bar_button.png" style="height: 348px; width: 700px;"></td>
- </tr>
- <tr>
- <td>Address bar button with a <a href="https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/user_interface/Popups">popup</a></td>
- <td>A popup on a button in the browser address bar that opens when the button is clicked. The popup is defined in an HTML document that handles the user interaction.</td>
- <td><img alt="Example of a popup on the address bar button" src="https://mdn.mozillademos.org/files/15747/page_action_popup.png" style="height: 524px; width: 700px;"></td>
- </tr>
- <tr>
- <td><a href="https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/user_interface/Context_menu_items">Context menu item</a></td>
- <td>Menu items, checkboxes, and radio buttons on one or more of the browser's context menus. Also, menus can be structured by adding separators. When menu items are clicked, an event is dispatched to the extension.</td>
- <td><img alt="Example of content menu items added by a WebExtension, from the context-menu-demo example" src="https://mdn.mozillademos.org/files/15756/context_menu_example.png" style="height: 942px; width: 864px;"></td>
- </tr>
- <tr>
- <td><a href="https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/user_interface/Sidebars">Sidebar</a></td>
- <td>
- <p dir="ltr">An HTML document displayed next to a web page, with the option for unique content per page. The sidebar is opened when the extension is installed, then obeys the user's sidebar visibility selection. User interaction within the sidebar is handled by its HTML document.</p>
- </td>
- <td><img alt="Example of a sidebar" src="https://mdn.mozillademos.org/files/15755/bookmarks-sidebar.png" style="height: 846px; width: 700px;"></td>
- </tr>
- <tr>
- <td><a href="https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/user_interface/Options_pages">Options page</a></td>
- <td>A page that enables you to define preferences for your extension that your users can change. The user can access this page from the browser's add-ons manager.</td>
- <td><img alt="Example showing the options page content added in the favorite colors example." src="https://mdn.mozillademos.org/files/15748/options_page.png"></td>
- </tr>
- <tr>
- <td><a href="/Add-ons/WebExtensions/user_interface/Extension_pages">Extension page</a></td>
- <td>Use web pages included in your extension to provide forms, help, or any other content required, within windows or tabs.</td>
- <td><img alt="Example of a simple bundled page displayed as a detached panel." src="https://mdn.mozillademos.org/files/15752/bundled_page_as_panel_small.png" style="height: 432px; width: 700px;"></td>
- </tr>
- <tr>
- <td><a href="https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/user_interface/Notifications">Notification</a></td>
- <td>Transient notifications displayed to the user through the underlying operating system's notifications mechanism. Dispatches an event to the extension when the user clicks a notification, or when a notification closes (either automatically or at the user's request).</td>
- <td><img alt="Example of an extension triggered system notification" src="https://mdn.mozillademos.org/files/15754/notify-shadowed.png" style="height: 294px; width: 780px;"></td>
- </tr>
- <tr>
- <td><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/user_interface/Omnibox">Address bar suggestion</a></td>
- <td>Offer custom address bar suggestions when the user enters a keyword.</td>
- <td><img alt="Example showing the result of the firefox_code_search WebExtension's customization of the address bar suggestions." src="https://mdn.mozillademos.org/files/15749/omnibox_example_small.png" style="height: 464px; width: 700px;"></td>
- </tr>
- <tr>
- <td><a href="https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/user_interface/devtools_panels">Developer tools panel</a></td>
- <td>A tab with an associated HTML document that displays in the browser's developer tools.</td>
- <td><img alt="Example showing the result of the firefox_code_search WebExtension's customization of the address bar suggestions." src="https://mdn.mozillademos.org/files/15746/developer_panel_tab.png" style="height: 224px; width: 700px;"></td>
- </tr>
- </tbody>
-</table>
-
-<p>The following how-to guides provide step-by-step guidance to creating some of these user interface options:</p>
-
-<ul>
- <li><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/user_interface/Accessibility_guidelines">Accessibility guidelines</a></li>
- <li><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Add_a_button_to_the_toolbar">Add a button to the toolbar</a></li>
- <li><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/user_interface/Browser_styles">Browser styles</a></li>
- <li><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Extending_the_developer_tools">Extending the developer tools</a></li>
- <li><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Implement_a_settings_page">Implement a settings page</a></li>
-</ul>
diff --git a/files/he/mozilla/add-ons/webextensions/what_are_webextensions/index.html b/files/he/mozilla/add-ons/webextensions/what_are_webextensions/index.html
deleted file mode 100644
index 2dbe632f44..0000000000
--- a/files/he/mozilla/add-ons/webextensions/what_are_webextensions/index.html
+++ /dev/null
@@ -1,59 +0,0 @@
----
-title: מהן הרחבות?
-slug: Mozilla/Add-ons/WebExtensions/What_are_WebExtensions
-tags:
- - הרחבות
- - הרחבות רשת
-translation_of: Mozilla/Add-ons/WebExtensions/What_are_WebExtensions
----
-<div>{{AddonSidebar}}</div>
-
-<p>הרחבה מוסיפה תכונות ותפקודים לדפדפן. היא נוצרת באמצעות טכנולוגיות מוכרות מבוססות רשת—HTML, CSS, וג'אווהסקריפט. החא משתמשת באותם ממשקי פיתוח לרשת כמו ג'אווה סקריפט  בדף רשת, אך בנוסף ההרחבה ניגשת לקבוצת ממשקי פיתוח בג'אווהסקריפט משלה. . זאת אומרת שניתן לעשות הרבה יותר בהרחבה מאשר עם קוד בדף הרשת. . הנה לפניכם מספר דוגמאות של דברים שניתן לעשות:</p>
-
-<p><strong>שדרוג או השלמה של אתר</strong>: השתמשו בתוסף למסור תכונות פנים דפדפן או מידע מתוך האתר שלכם. הרשו למשתמשים לאסוף פרטים מתוך דפים שהם מבקרים בהם כדי לשפר את השירות שאתם מציעים.</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/15808/Amazon_add_on.png"></p>
-
-<p>Examples: <a href="https://addons.mozilla.org/en-US/firefox/addon/amazon-browser-bar/">Amazon Assistant for Firefox</a>, <a href="https://addons.mozilla.org/en-US/firefox/addon/onenote-clipper/">OneNote Web Clipper</a>, and <a href="https://addons.mozilla.org/en-US/firefox/addon/grammarly-1/">Grammarly for Firefox</a></p>
-
-<p><strong>לתת למשתמשים להציג את האישיות שלהם</strong>: הרחבות דפדפן יכולות לטפל בתוכן של דפים ברשת; לדוגמא, לתת למשתמשים להוסיף את הלוגו או התמונה המועדפים עליהם כרקע לכל דף שהם מבקרים בו. הרחבות יכולות גם לאפשר למשתמשים לעדכן את המראה של ממשק משתמש פיירפוקס, באותה דרך שמאפשרים זאת  <a href="https://developer.mozilla.org/en-US/Add-ons/Themes/Theme_concepts">תוסף ערכת נושא </a> עצמאיים.</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/15809/MyWeb_New_Tab_add_on.png" style="height: 398px; width: 540px;"></p>
-
-<p>לדוגמא:: <a href="https://addons.mozilla.org/en-US/firefox/addon/myweb-new-tab/">MyWeb New Tab</a>, <a href="https://addons.mozilla.org/en-US/firefox/addon/tabliss/">Tabliss</a>, ו-<a href="https://addons.mozilla.org/en-US/firefox/addon/vivaldifox/">VivaldiFox</a></p>
-
-<p><strong>להוסיף או להסיר תוכן מדפים ברשת</strong>: ייתכן ותרצו לעזור למשתמשים לחסום פרסומות פולשניותמהדפים ברשת , לספק גישה למדריך טיולים בכל עת בה ארץ או עיר מוזכרים בדף ברשת, או לעצב מחדש תוכן עמוד כדי להציע חוויית קריאה עקבית . עם היכולת לגשת ולעדכן הן את ה-HTML והן את ה CSS של הדף, הרחבות יכולות לאפשר למשתמשים לראות את הרשת כפי שירצו.</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/15807/ublock_origin_add_on.png" style="height: 480px; width: 640px;"></p>
-
-<p>דוגמאות: <a href="https://addons.mozilla.org/en-US/firefox/addon/ublock-origin/">uBlock Origin</a>, <a href="https://addons.mozilla.org/en-US/firefox/addon/reader/">Reader</a>, ו-<a href="https://addons.mozilla.org/en-US/firefox/addon/toolbox-google-play-store/">Toolbox for Google Play Store™</a></p>
-
-<p><strong>להוסיף כלים ותכונות דפדפן חדשים</strong>: הוסיפו תכונות חדשות ללוח מטלות, או צרו תמונות קוד QR מכתובות  URL, קישורים לאינטרנט, או טקסט דף. עם אפשרויות  UI גמישות והכוח של  <a href="/en-US/Add-ons/WebExtensions">ממשקי פיתוח של הרחבות רשת</a> תוכלו להוסיף בקלות  תכונות חדשות לדפדפן . כמו כן, תוכלו לשדרג כממעט עכל תכונת אתר אינטרנט או תפקודו, הוא לא חייב להיות האתר שלכם.</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/15806/QR_Code_Image_Generator_add_on.png"></p>
-
-<p>דוגמאות: <a href="https://addons.mozilla.org/en-US/firefox/addon/qr-code-image-generator/">QR Code Image Generator</a>, <a href="https://addons.mozilla.org/en-US/firefox/addon/swimlanes-for-trello/">Swimlanes for Trello</a>, ו-<a href="https://addons.mozilla.org/en-US/firefox/addon/tomato-clock/">Tomato Clock</a></p>
-
-<p><strong>משחקים</strong>: הציעו משחקי מחשב מסורתיים עם תכונות משחק לא-מקוונות , או גלו אפשרויות משחק חדשות; לדוגמא, על ידי שילוב המשחק בגלישה היום יומית.</p>
-
-<p> <img alt="" src="https://mdn.mozillademos.org/files/15805/Asteroids_in_Popup_add_on%20.png" style="height: 438px; width: 700px;"></p>
-
-<p>דוגמאות: <a href="https://addons.mozilla.org/en-US/firefox/addon/asteroids-in-popup/">Asteroids in Popup</a>, <a href="https://addons.mozilla.org/en-US/firefox/addon/solitaire-card-game-new-tab/">Solitaire Card Game New Tab</a>, ו-<a href="https://addons.mozilla.org/en-US/firefox/addon/2048-prime/">2048 Prime</a>.</p>
-
-<p><strong>הוספת כלי פיתוח</strong>: ייתכן שתרצו להספק כלי פיתוח לרשת כעסק שלכם או פיתחתם טכניקה או גישה שימושיות לפיתוח לרשת שתרצו לשתף. בכל אחת מהדרכים, תוכלו לשדרג את כלי הפיתוח המובנים של פיירפוקס על ידי הוספת לשונית חדשה לסרגל הכלים של המפתח/ת.</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/15804/aXe_Developer_Tools_add_on.png" style="height: 261px; width: 700px;"></p>
-
-<p>דוגמאות: <a href="https://addons.mozilla.org/en-US/firefox/addon/web-developer/">Web Developer</a>, <a href="https://addons.mozilla.org/en-US/firefox/addon/react-devtools/">Web React Developer Tools</a>, ו-<a href="https://addons.mozilla.org/en-US/firefox/addon/axe-devtools/">aXe Developer Tools</a></p>
-
-<p>הרחבות לפיירפוקס נבנות באמצעות <a href="/en-US/Add-ons/WebExtensions">ממשקי הפיתוח להרחבות רשת</a>, מערכת לדפדפנים שוניםלפיתוח הרחבות. במידה רבה , tממשק הפיתוח תואם ל-<a class="external external-icon" href="https://developer.chrome.com/extensions">extension API</a> הנתמכים על ידי כרום ואופרה. הרחבות הנכתבותעבור דפדפנים אלה ירוצו ברוב המקרים על פיירפוקס will in most cases run inאו  פ Microsoft Edge ב<a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Porting_a_Google_Chrome_extension">שינויים</a> קלים בלבד. ממשק הפיתוח גם תואם באופן מלא ל<a href="/en-US/Firefox/Multiprocess_Firefox">פיירפוקס מרובה תהליכים</a>.</p>
-
-<p>אם יש לך הצעות אושאלות, או שיש לך צורך בעזרה לעבור מתוסף מהדור הישן לממשקח הפיתוח של הרחבות הרשת , ניתון להשיגנו ב- <a class="external external-icon" href="https://mail.mozilla.org/listinfo/dev-addons">dev-addons mailing list</a> או בערוץ <a href="irc://irc.mozilla.org/extdev">#addons</a> ב-<a class="external external-icon" href="https://wiki.mozilla.org/IRC">IRC</a>.</p>
-
-<h2 id="מה_הלאה">מה הלאה?</h2>
-
-<ul>
- <li>הדרכה צעד צעד לפיתוח הרחבה פשוטה ב- <a href="/he-IL/docs/Mozilla/Add-ons/WebExtensions/Your_first_WebExtension">ההרחבה הראשונה שלך.</a></li>
- <li>למדו על מבנה ההרחבה ב <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Anatomy_of_a_WebExtension">אנטומיה של הרחבה</a>.</li>
- <li>נסו עוד הרחבות לדוגמא ב<a href="/en-US/Add-ons/WebExtensions/Examples">הרחבות לדוגמא</a>.</li>
-</ul>
diff --git a/files/he/mozilla/add-ons/webextensions/your_first_webextension/index.html b/files/he/mozilla/add-ons/webextensions/your_first_webextension/index.html
deleted file mode 100644
index a167a224b4..0000000000
--- a/files/he/mozilla/add-ons/webextensions/your_first_webextension/index.html
+++ /dev/null
@@ -1,153 +0,0 @@
----
-title: Your first extension
-slug: Mozilla/Add-ons/WebExtensions/Your_first_WebExtension
-tags:
- - הרחבות רשת
- - מדריך
-translation_of: Mozilla/Add-ons/WebExtensions/Your_first_WebExtension
----
-<div>{{AddonSidebar}}</div>
-
-<p>במאמר זה נעבור שלב שלב בפיתוח הרחבה לפיירפוקס, מההתחלה ועד הסיום. כל מה שההרחבה עושה הוא להוסיף רקע אדום לכל דף הנטען מ-"mozilla.org" או כל אחד מתת-המתחמים שלו.</p>
-
-<p>קוד המקור לדוגמא זו נמצא ב- GitHub: <a href="https://github.com/mdn/webextensions-examples/tree/master/borderify">https://github.com/mdn/webextensions-examples/tree/master/borderify</a>.</p>
-
-<p>תחילה, יש צורך בפיירפוקס מגירסה 45 ומעלה.</p>
-
-<h2 id="כתיבת_ההרחבה">כתיבת ההרחבה</h2>
-
-<p>יש ליצור תיקייה חדשה ולנווט לתוכה. לדוגמה, משורת הפקודה\מסוף ניתן לבצע זאת כך:</p>
-
-<pre class="brush: bash">mkdir borderify
-cd borderify</pre>
-
-<h3 id="manifest.json">manifest.json</h3>
-
-<p>כעת, יש ליצור קובץ בשם  "manifest.json" ישירות תחת התיקייה  "borderify" . שימו בו את התוכן הבא:</p>
-
-<pre class="brush: json">{
-
- "manifest_version": 2,
- "name": "Borderify",
- "version": "1.0",
-
- "description": "Adds a red border to all webpages matching mozilla.org.",
-
- "icons": {
- "48": "icons/border-48.png"
- },
-
- "content_scripts": [
- {
- "matches": ["*://*.mozilla.org/*"],
- "js": ["borderify.js"]
- }
- ]
-
-}</pre>
-
-<ul>
- <li>שלושת המפתחות הראשונים: <code><a href="/en-US/Add-ons/WebExtensions/manifest.json/manifest_version">manifest_version</a></code>, <code><a href="/en-US/Add-ons/WebExtensions/manifest.json/name">name</a></code>, ו- <code><a href="/en-US/Add-ons/WebExtensions/manifest.json/version">version</a></code>, הם חובה ומכילים מטאדאטה בסיסית עבור ההרחבה</li>
- <li><code><a href="/en-US/Add-ons/WebExtensions/manifest.json/description">description</a></code> הוא אופציונאלי, אך מומלץ: הוא מוצג בבמנהל התוספים</li>
- <li><code><a href="/en-US/Add-ons/WebExtensions/manifest.json/icons">icons</a></code> הוא אופציונאלי, אך מומלץ : הוא מאפשר לך לציין צלמית עבור ההרחבה, שתוצג במנהל התוספים.</li>
-</ul>
-
-<p>המפתח המעניין ביותר כאן הוא  <code><a href="/en-US/Add-ons/WebExtensions/manifest.json/content_scripts">content_scripts</a></code>, המגדיר לפיירפוקס איך לטעון תסריט לתוך דפי רשת שכתובת ה-  URL שלהם תואמת תבנית מסויימת. במקרה זה, מבקשים מפיירפוקס לטעון תסריט ששמו  "borderify.js" אל תוך כל דפי ה-HTTP או HTTPS המוגשים על ידי  "mozilla.org" או כל תתי המתחמים שלו.</p>
-
-<ul>
- <li><a href="/en-US/Add-ons/WebExtensions/Content_scripts">למדו עוד על תסריטי תוכן.</a></li>
- <li><a href="/en-US/Add-ons/WebExtensions/Match_patterns">למדו עוד על תבניות התאמה</a>.</li>
-</ul>
-
-<div class="warning">
-<p><a href="/en-US/Add-ons/WebExtensions/WebExtensions_and_the_Add-on_ID#When_do_you_need_an_add-on_ID">בכמה מצבים ייתכן ותצטרכו לציין ID עבור ההרחבה</a>. אם יש צורך לציין מזהה תוסף, כללו את המפתח  <code><a href="/en-US/Add-ons/WebExtensions/manifest.json/applications">applications</a></code> ב-<code>manifest.json</code> והגדירו את התכונה <code>gecko.id</code> שלו:</p>
-
-<pre class="brush: json">"applications": {
- "gecko": {
- "id": "borderify@example.com"
- }
-}</pre>
-</div>
-
-<h3 id="iconsborder-48.png">icons/border-48.png</h3>
-
-<p>ההרחבה צריכה לכלול צלמית. היא תוצג על יד רישום ההרחבה במנהל ההרחבות. הקובץ manifest.json הבטיח שתהיה לנו צלמית ב-"icons/border-48.png".</p>
-
-<p>צרו את התיקייה "icons" ישירות תחת התיקייה  "borderify" . שמרו שם צלמית בשם "border-48.png".  תוכלו להשתמש  <a href="https://github.com/mdn/webextensions-examples/blob/master/borderify/icons/border-48.png">בזאת מתוך הדוגמא שלנו</a>, הלקוחה מתוך  the Google Material Design iconset, ובשימוש תחת תנאי רשיון ה-<a href="https://creativecommons.org/licenses/by-sa/3.0/">Creative Commons Attribution-ShareAlike</a> .</p>
-
-<p>אם תבחרו לספק צלמית משלכם, היא צריכה להיות בגודל  48x48 פיקסלים. תוכלו לספק גם צלמית בגודל 96x96 פיקסלים, לצורך תצוגות ברזולוציה יותר גבוהה,  ואם תעשו זאת היא תצויין כתכונת ה-<code>96</code> באובייקט <code>icons</code> אשר ב-manifest.json:</p>
-
-<pre class="brush: json">"icons": {
- "48": "icons/border-48.png",
- "96": "icons/border-96.png"
-}</pre>
-
-<p>לחלופין, תוכלו לספק כאן קובץ  SVG , ומימדיו ישונו בהתאם. (למרות ב: אם תשתמשו ב- SVG והצלמית תכלול טקסט, ייתכן שתרצו להשתמש בכלי   "convert to path"  של עורך ה-SVG כדי לשטח את הטקס , כך שהמידות יותאמו עם size/position עקביים.)</p>
-
-<ul>
- <li><a href="/en-US/Add-ons/WebExtensions/manifest.json/icons">למדו עוד על ציון צלמיות.</a></li>
-</ul>
-
-<h3 id="borderify.js">borderify.js</h3>
-
-<p>לסיום, צרו קובץ בשם  "borderify.js" ישירות תחת התיקייה "borderify" . שימו בו את התוכן הזה:</p>
-
-<pre class="brush: js">document.body.style.border = "5px solid red";</pre>
-
-<p>תסריט זה ייטעאן לתוך דפים התואמים את התבנית הנתונה  במפתח   <code>content_scriptsב-m</code>anifest.json . לתסריט יש גישה ישירה למסמך כמו לתסקיטים הנטענים על ידי הדף עצמ .</p>
-
-<ul>
- <li><a href="/en-US/Add-ons/WebExtensions/Content_scripts">למדו עוד על תסריטי תוכן.</a></li>
-</ul>
-
-<h2 id="לבדוק_שזה_עובד">לבדוק שזה עובד</h2>
-
-<p>תחילה, בדקו היטב שכל הקבצים נמצאים במקומות הנכונים:</p>
-
-<pre>borderify/
- icons/
- border-48.png
- borderify.js
- manifest.json</pre>
-
-<h3 id="התקנה">התקנה</h3>
-
-<p>פתחו את  "about:debugging" בפיירפוקס, , הקליקו  "טעינת תוספות זמניות..." and ובחרו כל קובץ שהוא  בתיקיית ההרחבה:</p>
-
-<p>{{EmbedYouTube("cer9EUKegG4")}}</p>
-
-<p>כעת ההרחבה תותקן, ותישאר עד שתתחילו מחדש את פיירפוקס.</p>
-
-<p>לחלופין, תועלו להריץ את ההרחבה משורת הפקודה באמצעות הכלי <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Getting_started_with_web-ext">web-ext</a>.</p>
-
-<h3 id="בדיקה">בדיקה</h3>
-
-<p>כעת נסו לבקר בעמוד תחת  "mozilla.org", ותראו רקע אדום מסביב לדף :</p>
-
-<p>{{EmbedYouTube("rxBQl2Z9IBQ")}}</p>
-
-<div class="note">
-<p>אך אל תנסו זאת ב- addons.mozilla.org! תסריטי תוכן בשלב זה חסומים באותו מתחם.</p>
-</div>
-
-<p>ערכו ניסוי קטן. ערכו את תסריט התוכן לשנות את צבע הרקע, או עשו משהו אחר לתוכן הדף. שמרו את תוכן התסריט , ואז טענו את קבצי ההרחבה בהקלקה על קישור  ה "טעינה מחדש" ב- about:debugging. תוכלו לראות את השינויים מיד:</p>
-
-<p>{{EmbedYouTube("NuajE60jfGY")}}</p>
-
-<ul>
- <li><a href="/en-US/Add-ons/WebExtensions/Temporary_Installation_in_Firefox">למדו עוד על טעינת הרחבות</a></li>
-</ul>
-
-<h2 id="אריזה_ופרסום">אריזה ופרסום</h2>
-
-<p>כדי לאפשר לאחרים להשתמש בהרחבתך, יש לארוז אותה ולשלוח למוזילה לחתימה. כדי ללמוד עוד, יש לראות <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Publishing_your_WebExtension">"פרסום ההרחבה שלך"</a>.</p>
-
-<h2 id="מה_הלאה">מה הלאה?</h2>
-
-<p>כעת יש לך מושג בנושא תהליך הפיתוח של הרחבות רשת לפיירפוקס , נסה/י:</p>
-
-<ul>
- <li><a href="/en-US/Add-ons/WebExtensions/Anatomy_of_a_WebExtension">קריאה נוספת אודות האנטומיה של הרחבה</a></li>
- <li><a href="/en-US/Add-ons/WebExtensions/Your_second_WebExtension">כתיבת הרחבות יותר מורכבות</a></li>
- <li><a href="/en-US/Add-ons/WebExtensions/API">קריאה אודות ממשקי פיתוח בג'אווהסקריפט הזמינים להרחבות.</a></li>
-</ul>
diff --git a/files/he/mozilla/add-ons/webextensions/your_second_webextension/index.html b/files/he/mozilla/add-ons/webextensions/your_second_webextension/index.html
deleted file mode 100644
index 528daff645..0000000000
--- a/files/he/mozilla/add-ons/webextensions/your_second_webextension/index.html
+++ /dev/null
@@ -1,458 +0,0 @@
----
-title: ההרחבה השניה שלך
-slug: Mozilla/Add-ons/WebExtensions/Your_second_WebExtension
-tags:
- - הרחבות רשת
-translation_of: Mozilla/Add-ons/WebExtensions/Your_second_WebExtension
----
-<div>{{AddonSidebar}}
-<p>אם כבר עברת את המאמר <a href="/he-IL/docs/Mozilla/Add-ons/WebExtensions/Your_first_WebExtension">ההרחבה הראשונה שלך</a> , כבר קיבלת מושג איך לכתוב הרחבה. <span class="seoSummary">במאמר זה, נכתוב הרחבה קצת יותר מורכבת המדגימה עוד קצת מממשקי הפיתוח.</span></p>
-
-<p>ההרחבה מוסיפה כפתור חדש לסרגל הכלים של פיירפוקס. כשהמשתמש/ת מקליק/ה על הכפתור, נציג חלון קופץ המאפשר לבחור חיה. בהיבחר חיה, נחליף את תוכן הדף בחיה שנבחרה</p>
-
-<p>כדי לממש זאת, אנו:</p>
-
-<ul>
- <li><strong>נגדיר <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/Browser_action">פעולת דפדפן</a>, שהיא כפתור המחובר לסרגל הכלים של פיירפוקס</strong>.<br>
- לכפתור זה נספק:
- <ul>
- <li>צלמית בשם "beasts-32.png"</li>
- <li>חלון קופץ שייפתח כשהכפתור נלחץ. החלון הקופץ יכיל HTML, CSS, ו- JavaScript.</li>
- </ul>
- </li>
- <li><strong>נגדיר צלמית עבור ההרחבה</strong>, ושמה "beasts-48.png". היא תהיה מוצגת  ב"ניהול ההרחבות שלך".</li>
- <li><strong>נכתוב תסריט תוכן, "beastify.js" שיוחדר לתוך דפי הרשת</strong>.<br>
- זה הקוד שמשנה בפועל את הדפים.</li>
- <li><strong>נארוז כמה תמונות של חיות, להחליף תץמונות בדף הרשת</strong>.<br>
- נכין את התמונות "web accessible resources" כך שדף הרשת יפנה אליהן.</li>
-</ul>
-
-<p>תוכלו לדמיין את המבנה בכללותו של ההרחבה כך:</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/13671/Untitled-1.png" style="display: block; height: 1200px; margin-left: auto; margin-right: auto; width: 860px;"></p>
-
-<p>זוהי הרחבה פשוטה, אך מציגה רבים מהקונספטים הבסיסיים של ממשק פיתוח הרחבות הרשת:</p>
-
-<ul>
- <li>הוספת כפתור לסרגל הכלים</li>
- <li>הוספת פאנל של חלון קו]ץ באמצעות HTML, CSS, ו-JavaScript</li>
- <li>החדרת תסריט תוכן לתוך דפי רשת</li>
- <li>תקשורת בין תסריטי תוכן לבין שאר ההרחבה</li>
- <li>אריזת משאבים היכולים להיות בשימוש על ידי הדפים ברשת עם ההרחבה</li>
-</ul>
-
-<p>תוכלו למצוא <a href="https://github.com/mdn/webextensions-examples/tree/master/beastify">complete source code for the extension on GitHub</a>.</p>
-
-<p>כדי לכתוב את ההרחבה, יש צורך בפיירפוקס מגרסא 45 או חדשה יותר.</p>
-
-<h2 id="כתיבת_ההרחבה">כתיבת ההרחבה</h2>
-
-<p>צרו תיקייה חדשה ונווטו לתוכה:</p>
-
-<pre class="brush: bash">mkdir beastify
-cd beastify</pre>
-
-<h3 id="manifest.json">manifest.json</h3>
-
-<p>כעת צרו קובץ בשם "manifest.json", והכניסו בו את התוכן:</p>
-
-<pre class="brush: json">{
-
- "manifest_version": 2,
- "name": "Beastify",
- "version": "1.0",
-
- "description": "Adds a browser action icon to the toolbar. Click the button to choose a beast. The active tab's body content is then replaced with a picture of the chosen beast. See https://developer.mozilla.org/en-US/Add-ons/WebExtensions/Examples#beastify",
- "homepage_url": "https://github.com/mdn/webextensions-examples/tree/master/beastify",
- "icons": {
- "48": "icons/beasts-48.png"
- },
-
- "permissions": [
- "activeTab"
- ],
-
- "browser_action": {
- "default_icon": "icons/beasts-32.png",
- "default_title": "Beastify",
- "default_popup": "popup/choose_beast.html"
- },
-
- "web_accessible_resources": [
- "beasts/frog.jpg",
- "beasts/turtle.jpg",
- "beasts/snake.jpg"
- ]
-
-}
-</pre>
-
-<ul>
- <li>שלושת המפתחות הראשונים: <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/manifest_version">manifest_version</a></code>, <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/name">name</a></code>, ו- <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/version">version</a></code>, הם חובה ומכילים מטאדאדה בסיסית עבור ההרחבה .</li>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/description">description</a></code> ו- <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/homepage_url">homepage_url</a></code> הם אופציונאליים, אך מומלצים: הם מספקים מידע שימושי אודות ההרחבה.</li>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/icons">icons</a></code> הוא אופציונאלי, אך מומלץ: הוא מאפשר לציין צלמית עבור ההרחבה , שתהיה מוצגת ב"ניהול ההרחבות שלך".</li>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/permissions">permissions</a></code> מהווה את רשימת ההרשאות שההרחבה זקוקה להן . אנו רק מבקשים  <a href="/en-US/Add-ons/WebExtensions/manifest.json/permissions#activeTab_permission"><code>הרשאותactiveTab</code></a> כאן.</li>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/browser_action">browser_action</a></code> מציין את הכפתור בסרגל הכלים. We'רנו מספקים 3 פיסות מידע כאן:
- <ul>
- <li><code>default_icon</code> הוא חובה, ומצביע לצלמית שבכפתור</li>
- <li><code>default_title</code> הוא אופציונאלי, ויוצג כעצת הכלי</li>
- <li><code>default_popup</code> יהיה בשימוש אם תרצו שחלון קופץ יוצג כאשר המשתמש/ת מקליק/ה על הכפתור . אנו רוצים זאת, אז כללנו את המפתח וגרמנו לו להצביע לקובץ  HTML הכלול בהרחבה.</li>
- </ul>
- </li>
- <li><code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json/web_accessible_resources">web_accessible_resources</a></code> מהווה רשימת קבצים שברמטננו להפוך לנגישים לדפי רשת . מאחר וההרחבה מחליפה את תוכן הדף בתמונות  שארזנו בתוך ההרחבה, נצטרך להפוך תמונות אלה לנגישות לדף.</li>
-</ul>
-
-<p>לתשומת לבך כל המסלולים הם יחסיים ל-manifest.json עצמו.</p>
-
-<h3 id="הצלמית">הצלמית</h3>
-
-<p>להרחבה צריכה להיות צלמית. היא תהיה מוצגת על יד רישום ההרחבה ב"ניהול ההרחבות שלך" (תוכלו לפתוח אותה על ידי ביקור בכתובת "about:addons"). ה- manifest.json הבטיח שתהיה לנו צלמית לסרגל הכלים ב-  "icons/beasts-48.png".</p>
-
-<p>צרו את התיקייה "icons" ושמרו שם את הצלמית בשם  "beasts-48.png".  ניתן להשתמש ב- <a href="https://github.com/mdn/webextensions-examples/raw/master/beastify/icons/beasts-48.png">the one from our example</a>, הלקוחה מתוך ה-<a href="https://www.iconfinder.com/iconsets/free-retina-icon-set">Aha-Soft’s Free Retina iconset</a>, ונמצאת בשימוש תחת תנאי ה<a href="http://www.aha-soft.com/free-icons/free-retina-icon-set/">רשיון</a> שלה</p>
-
-<p>אם תבחרו לספק צלמית משלכם, היא צריכה להיות בגודל 48x48 פיקסלים. תוכלו לספק גם צלמית בגודל 96x96 פיקסלים  , לתצוגות ברזולוציה יותר גבוהה, ואם תעשו זאת it היא תהיה מצויינת כתכונה <code>96</code> של אובייקט ה-<code>icons</code> ב-manifest.json:</p>
-
-<pre class="brush: json line-numbers language-json"><code class="language-json">"icons": {
- "48": "icons/beasts-48.png",
- "96": "icons/beasts-96.png"
-}</code></pre>
-
-<h3 id="הכפתור_בסרגל_הכלים">הכפתור בסרגל הכלים</h3>
-
-<p>הכפתור בסרגל הכלים צריך גם צלמית, וה- manifest.json מבטיח שתהיה לנו צלמית לכפתור בסרגל הכלים ב"icons/beasts-32.png".</p>
-
-<p>שמרו צלמית בשם "beasts-32.png" בתיקייה "icons" . תוכלו להשתמש ב<a href="https://github.com/mdn/webextensions-examples/raw/master/beastify/icons/beasts-32.png">זו מהדוגמה שלנו</a>, הלקוחה מתוך <a href="http://www.iconbeast.com/free">IconBeast Lite icon set</a> ובשימוש תחת תנאי <a href="http://www.iconbeast.com/faq/">הרשיון</a>. שלה.</p>
-
-<p>אם לא יסופק חלון קופץ, יישלח אירוע הקלקה להרחבה כאשר המשתמש/ת מקיש/ה על הכפתור. אם כן יסופק חלון קופץ, אירוע ההקלקה לא יישלח , אך במקום זאת, החלון הקופץ ייפתח . אנו רוצים חלון קופץ, אז הבה ניצור אותו כצעד הבא.</p>
-
-<h3 id="החלון_הקופץ">החלון הקופץ</h3>
-
-<p>תפקיד החלון הקופץ הוא לאפשר למשתמש/ת לבחור אחת מתוך שלוש חיות.</p>
-
-<p>צרו תיקייה חדשה בשם "popup" תחת שורש ההרחבה. זה המקום שבו נשמור את הקוד עבור החלון הקופץ. החלון הקופץ יהיה מורכב משלושה קבצים:</p>
-
-<ul>
- <li><strong><code>choose_beast.html</code></strong> מגדיר את תוכן הלוח</li>
- <li><strong><code>choose_beast.css</code></strong> מסגנן את התוכן</li>
- <li><strong><code>choose_beast.js</code></strong> מטפל בבחירת המשתמש/ת על ידי הרצת תסריט תוכן בלשונית הפעילה.</li>
-</ul>
-
-<pre class="brush: bash">mkdir popup
-cd popup
-touch choose_beast.html choose_beast.css choose_beast.js
-</pre>
-
-<h4 id="choose_beast.html">choose_beast.html</h4>
-
-<p>קובץ ה-HTML נראה כך:</p>
-
-<pre class="brush: html">&lt;!DOCTYPE html&gt;
-
-&lt;html&gt;
- &lt;head&gt;
- &lt;meta charset="utf-8"&gt;
- &lt;link rel="stylesheet" href="choose_beast.css"/&gt;
- &lt;/head&gt;
-
-&lt;body&gt;
- &lt;div id="popup-content"&gt;
- &lt;div class="button beast"&gt;Frog&lt;/div&gt;
- &lt;div class="button beast"&gt;Turtle&lt;/div&gt;
- &lt;div class="button beast"&gt;Snake&lt;/div&gt;
- &lt;div class="button reset"&gt;Reset&lt;/div&gt;
- &lt;/div&gt;
- &lt;div id="error-content" class="hidden"&gt;
- &lt;p&gt;Can't beastify this web page.&lt;/p&gt;&lt;p&gt;Try a different page.&lt;/p&gt;
- &lt;/div&gt;
- &lt;script src="choose_beast.js"&gt;&lt;/script&gt;
-&lt;/body&gt;
-
-&lt;/html&gt;
-</pre>
-
-<p>יש לנו אלמנט <code><a href="/en-US/docs/Web/HTML/Element/div">&lt;div&gt;</a></code> עם ID  שערכו <code>"popup-content"</code> המכיל אלמנט עבור כל חיה שנבחרה. יש לנו עוד אלמנט <code>&lt;div&gt;</code> עם ID שערכו <code>"error-content"</code> וסיווגו <code>"hidden"</code>. נשתמש בו במקרה שיש בעיה לאתחל את החלון הקופץ .</p>
-
-<p>יש לשים לב לכך שאני כוללים את קובצי  ה-  CSS וה- JS מקובץ זה, בדיוק כמו דף ברשת.</p>
-
-<h4 id="choose_beast.css">choose_beast.css</h4>
-
-<p>ה- CSS מקבע את מידות החלון הקופץ, מבטיח ששלוש הבחירות ימלאו את החלל, ונותן להם סגנון בסיסי. הוא גם מסתיר אלמנטים עם <code>class="hidden"</code>: כלומר שכברירת מחדל <code>"error-content"</code> <code>&lt;div&gt;</code> יוסתרו.</p>
-
-<pre class="brush: css">html, body {
- width: 100px;
-}
-
-.hidden {
- display: none;
-}
-
-.button {
- margin: 3% auto;
- padding: 4px;
- text-align: center;
- font-size: 1.5em;
- cursor: pointer;
-}
-
-.beast:hover {
- background-color: #CFF2F2;
-}
-
-.beast {
- background-color: #E5F2F2;
-}
-
-.reset {
- background-color: #FBFBC9;
-}
-
-.reset:hover {
- background-color: #EAEA9D;
-}
-
-</pre>
-
-<h4 id="choose_beast.js">choose_beast.js</h4>
-
-<p>הנה הג'אווהסקריפט עבור החלון הקופץ:</p>
-
-<pre class="brush: js">/**
- * CSS to hide everything on the page,
- * except for elements that have the "beastify-image" class.
- */
-const hidePage = `body &gt; :not(.beastify-image) {
- display: none;
- }`;
-
-/**
- * Listen for clicks on the buttons, and send the appropriate message to
- * the content script in the page.
- */
-function listenForClicks() {
- document.addEventListener("click", (e) =&gt; {
-
- /**
- * Given the name of a beast, get the URL to the corresponding image.
- */
- function beastNameToURL(beastName) {
- switch (beastName) {
- case "Frog":
- return browser.extension.getURL("beasts/frog.jpg");
- case "Snake":
- return browser.extension.getURL("beasts/snake.jpg");
- case "Turtle":
- return browser.extension.getURL("beasts/turtle.jpg");
- }
- }
-
- /**
- * Insert the page-hiding CSS into the active tab,
- * then get the beast URL and
- * send a "beastify" message to the content script in the active tab.
- */
- function beastify(tabs) {
- browser.tabs.insertCSS({code: hidePage}).then(() =&gt; {
- let url = beastNameToURL(e.target.textContent);
- browser.tabs.sendMessage(tabs[0].id, {
- command: "beastify",
- beastURL: url
- });
- });
- }
-
- /**
- * Remove the page-hiding CSS from the active tab,
- * send a "reset" message to the content script in the active tab.
- */
- function reset(tabs) {
- browser.tabs.removeCSS({code: hidePage}).then(() =&gt; {
- browser.tabs.sendMessage(tabs[0].id, {
- command: "reset",
- });
- });
- }
-
- /**
- * Just log the error to the console.
- */
- function reportError(error) {
- console.error(`Could not beastify: ${error}`);
- }
-
- /**
- * Get the active tab,
- * then call "beastify()" or "reset()" as appropriate.
- */
- if (e.target.classList.contains("beast")) {
- browser.tabs.query({active: true, currentWindow: true})
- .then(beastify)
- .catch(reportError);
- }
- else if (e.target.classList.contains("reset")) {
- browser.tabs.query({active: true, currentWindow: true})
- .then(reset)
- .catch(reportError);
- }
- });
-}
-
-/**
- * There was an error executing the script.
- * Display the popup's error message, and hide the normal UI.
- */
-function reportExecuteScriptError(error) {
- document.querySelector("#popup-content").classList.add("hidden");
- document.querySelector("#error-content").classList.remove("hidden");
- console.error(`Failed to execute beastify content script: ${error.message}`);
-}
-
-/**
- * When the popup loads, inject a content script into the active tab,
- * and add a click handler.
- * If we couldn't inject the script, handle the error.
- */
-browser.tabs.executeScript({file: "/content_scripts/beastify.js"})
-.then(listenForClicks)
-.catch(reportExecuteScriptError);
-
-</pre>
-
-<p>המקום להתחיל פה הוא שורה 96. תסריט החלון הקופץ מבצע תסריט תוכן בלשונית הפעילה מייד כשהחלון הקופץ נטען , באמצעות ממשק הפיתוח <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/tabs/executeScript">browser.tabs.executeScript()</a></code>. אם ביצוע תסריט התוכן הצליח , תסריט התוכן יישאר טעון בעמוד עד שהלשונית נסגרת או שהמשתמש/ת מנווט/ת לדף שונה.</p>
-
-<p>סיבה נפוצה שהקריאה ל- <code>browser.tabs.executeScript()</code> עלולה להיכשל היא שלא ניתן לבתע תסריטי תוכן בכל הדפים. לדוגמא, לא ניתן לבצע אותם בדפים פריגילגיים של הדפדפן כגון "about:debugging" , ולא ניתן לבצע אותם בדפים בתוך המתחם  <a href="https://addons.mozilla.org/">addons.mozilla.org</a>. אם זה נכשל,, <code>reportExecuteScriptError()</code> יסתיר את ה- <code>"popup-content"</code> <code>&lt;div&gt;</code>, יציג את ה- <code>"error-content"</code> <code>&lt;div&gt;</code>, וירשום שגיאה ל-<a href="/en-US/Add-ons/WebExtensions/Debugging">console</a>.</p>
-
-<p>אם ביצוע תסריט התוכן יצליח, נקרא ל- <code>listenForClicks()</code>. הוא יאזין לקליקים בחלון הקופץ..</p>
-
-<ul>
- <li>אם נלחץ כםתור עם <code>class="beast"</code>, אזי נקרא ל-<code>beastify()</code>.</li>
- <li>אם נלחץ כפתור עם <code>class="reset"</code>, אזי נקרא ל-<code>reset()</code>.</li>
-</ul>
-
-<p>הפונקציה <code>beastify()</code> מבצעת שלושה דברים:</p>
-
-<ul>
- <li>ממפה את הכפתור הנלחץ לכתובת URL המצביע לתמונה של חיה מסויימת</li>
- <li>מסתירה את כל התוכן של הדף על ידי החדרת CSS, באמצעות ממשק הפיתוח <code><a href="/en-US/Add-ons/WebExtensions/API/tabs/insertCSS">browser.tabs.insertCSS()</a></code></li>
- <li>שולחת הודעת "beastify" לתסריט התוכן באמצעות ממשק הפיתוח <code><a href="/en-US/docs/Mozilla/Add-ons/WebExtensions/API/tabs/sendMessage">browser.tabs.sendMessage()</a></code>, תוך בקשה לשנות את העמוד לתמונת חיה, ושליחת כתובת ה- URL לתמונת החיה.</li>
-</ul>
-
-<p>הפונקציה <code>reset()</code> בהכרח מבטלת את פעולת  beastify:</p>
-
-<ul>
- <li>מסירה את ה- CSS שהוספנו, באמצעות ממשק הפיתוח  <code><a href="/en-US/Add-ons/WebExtensions/API/tabs/removeCSS">browser.tabs.removeCSS()</a></code></li>
- <li>שולחת הודעת  "reset" לתסריט התוכן בבקשה להשיב את הדף לקדמותו.</li>
-</ul>
-
-<h3 id="תסריט_התוכן">תסריט התוכן</h3>
-
-<p>צרו תיקייה חדשה, תחת שורש ההרחבה, ששמה "content_scripts" וצרו קובץ חדש ששמו "beastify.js", עם התוכן הבא:</p>
-
-<pre class="brush: js">(function() {
- /**
- * Check and set a global guard variable.
- * If this content script is injected into the same page again,
- * it will do nothing next time.
- */
- if (window.hasRun) {
- return;
- }
- window.hasRun = true;
-
- /**
- * Given a URL to a beast image, remove all existing beasts, then
- * create and style an IMG node pointing to
- * that image, then insert the node into the document.
- */
- function insertBeast(beastURL) {
- removeExistingBeasts();
- let beastImage = document.createElement("img");
- beastImage.setAttribute("src", beastURL);
- beastImage.style.height = "100vh";
- beastImage.className = "beastify-image";
- document.body.appendChild(beastImage);
- }
-
- /**
- * Remove every beast from the page.
- */
- function removeExistingBeasts() {
- let existingBeasts = document.querySelectorAll(".beastify-image");
- for (let beast of existingBeasts) {
- beast.remove();
- }
- }
-
- /**
- * Listen for messages from the background script.
- * Call "beastify()" or "reset()".
- */
- browser.runtime.onMessage.addListener((message) =&gt; {
- if (message.command === "beastify") {
- insertBeast(message.beastURL);
- } else if (message.command === "reset") {
- removeExistingBeasts();
- }
- });
-
-})();
-</pre>
-
-<p>הדבר הראשון שתסריט התוכן עושה  הוא לבדוק שקיים משתנה גלובלי בשם <code>window.hasRun</code>: אם הוא מוגדר כאמת התסריט ירוץ מוקדם, אחרת הוא מציב ערך אמת ל0 <code>window.hasRun</code> וממשיך. הסיבה שאנו עושים זאת היא שכל פעם שהמשתמש/ת פותח/ת את החלון הקופץ , החלון הקופץ מבצע תסריט תוכן בלשונית הפעילה , כך שיכולים להיות לנו מופעים מרובים של התסריט רצים בלשונית יחידה. אם זה קורה, נצטרך לדאוג שרק המופע הראשון יעשה משהו באמת.</p>
-
-<p>אחר כך, המקום להתחיל הוא שורה 40, בה תסריט התוכן מאזין להודעות מהחלון הקופץ, באמצעות ממשק הפיתוח  <code><a href="/en-US/Add-ons/WebExtensions/API/runtime/onMessage">browser.runtime.onMessage</a></code>. ראינו לעיל כי תסריט החלון הקופץ יכול לשלוח שני סוגי הודעות שונים : "beastify" ו-"reset".</p>
-
-<ul>
- <li>אם ההודעה היא "beastify", נצפה ממנה לכלול כתובת URL המצביעה לתמונת חיה. נסיר כל חיה שייתכן ונוספה על ידי קריאות קודמות ל-  "beastify" אז נבנות קריאות ומספחות אלמנט   <code><a href="/en-US/docs/Web/HTML/Element/img">&lt;img&gt;</a></code> שהמאפיין <code>src</code> שלו מוגדר להיות כתובת   URL של חיה.</li>
- <li>אם ההודעה היא "reset", פשוט נסיר כל חיה  שייתכן שנוספה.</li>
-</ul>
-
-<h3 id="החיות">החיות</h3>
-
-<p>לסיום, עלינו לכלול את התמונות של החיות.</p>
-
-<p>צרו תיקייה חדשה ששמה "beasts", והוסיפו שלוש תמונות לתיקייה זו, אם השמות הנכונים. תוכלו להשיג את התמונות מ<a href="https://github.com/mdn/webextensions-examples/tree/master/beastify/beasts">מאגר ה-GitHub </a>, או מפה:</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/11459/frog.jpg" style="display: inline-block; height: 200px; margin: 20px; width: 200px;"><img alt="" src="https://mdn.mozillademos.org/files/11461/snake.jpg" style="display: inline-block; height: 200px; margin: 20px; width: 200px;"><img alt="" src="https://mdn.mozillademos.org/files/11463/turtle.jpg" style="display: inline-block; height: 200px; margin: 20px; width: 200px;"></p>
-
-<h2 id="לנסות_את_זה">לנסות את זה</h2>
-
-<p>תחילה, בדקו היטב שהקבצים הנכונים נמצאים במקומות הנכונים:</p>
-
-<pre>beastify/
-
- beasts/
- frog.jpg
- snake.jpg
- turtle.jpg
-
- content_scripts/
- beastify.js
-
- icons/
- beasts-32.png
- beasts-48.png
-
- popup/
- choose_beast.css
- choose_beast.html
- choose_beast.js
-
- manifest.json</pre>
-
-<p>החל מפיירפוקס 45, ניתן להתקין הרחבות זמנית מהדיסק.</p>
-
-<p>פתחו את "about:debugging" בפיירפוקס, הקליקו  "טעינת תוספות זמניות...", ובחרו את ה- manifest.json שלכם. תצטרכו לראות כעת את צלמית ההרחבה מופיעה בסרגל הכלים של פיירפוקס</p>
-
-<p>{{EmbedYouTube("sAM78GU4P34")}}</p>
-
-<p>פתחו דף ברשת, ואז הקליקו על הצלמית, בחרו חיה , ורארו את הדף משתנה:</p>
-
-<p>{{EmbedYouTube("YMQXyAQSiE8")}}</p>
-
-<h2 id="פיתוח_משורת_הפקודה">פיתוח משורת הפקודה</h2>
-
-<p>תוכלו לבצע אוטומציה של צעד ההתקנה הזמנית על ידי שימוש בכלי  <a href="/en-US/Add-ons/WebExtensions/Getting_started_with_web-ext">web-ext</a>. נסו את זה:</p>
-
-<pre class="brush: bash">cd beastify
-web-ext run</pre>
-</div>
diff --git a/files/he/mozilla/index.html b/files/he/mozilla/index.html
deleted file mode 100644
index edba954db8..0000000000
--- a/files/he/mozilla/index.html
+++ /dev/null
@@ -1,10 +0,0 @@
----
-title: Mozilla
-slug: Mozilla
-tags:
- - NeedsTranslation
- - TopicStub
-translation_of: Mozilla
----
-<p>The articles below include content about downloading and building Mozilla code. In addition, you'll find helpful articles about how the code works, how to build add-ons for Mozilla applications, and the like.</p>
-<p>{{LandingPageListSubpages}}</p>
diff --git a/files/he/orphaned/he/index.html b/files/he/orphaned/he/index.html
deleted file mode 100644
index 1fd6247132..0000000000
--- a/files/he/orphaned/he/index.html
+++ /dev/null
@@ -1,15 +0,0 @@
----
-title: MDN
-slug: orphaned/he
-original_slug: he
----
-<div dir="rtl">
-<h2 id="ברוכים_הבאים_לרשת_המפתחים_של_מוזילה">ברוכים הבאים לרשת המפתחים של מוזילה</h2>
-<p><img align="left" alt="MDN_1a_150x172.png" class="internal lwrap" src="/@api/deki/files/4317/=MDN_1a_150x172.png?size=thumb"> זהו פרוייקט התרגום העברי למאמרי רשת המפתחים של מוזילה (לשעבר MDC).</p>
-<table class="mainpage-table"> <tbody> <tr> <td> <h2 id="מדריכים">מדריכים</h2> <dl> <dt><a href="/he/פיתוח_לאינטרנט" title="פיתוח לאינטרנט">פיתוח לאינטרנט</a></dt> <dd>משאבים למפתחי אינטרנט.</dd> <dt><a href="/he/נגישות" title="נגישות">נגישות</a></dt> <dd>איך לפתח עבור משתמשים עם מוגבלויות.</dd> <dt><a href="/he/תקינה_באינטרנט" title="תקינה באינטרנט">תקינה באינטרנט</a></dt> <dd>איך ומדוע להשתמש בתקני אינטרנט בפיתוח.</dd> <dt><a href="/he/אבטחה" title="אבטחה">אבטחה</a></dt> <dd>אודות אבטחה באינטרנט.</dd> </dl> <p><a href="/he/מסמכים_נוספים" title="he/מסמכים נוספים">מסמכים נוספים</a></p> <h2 id="כלים">כלים</h2> <dl> <dt><a href="/he/Firebug" title="he/Firebug">Firebug</a></dt> <dd>דיבאגר לאתרי אינטרנט.</dd> <dt><a href="/he/Dom_Inspector" title="he/Dom Inspector">Dom Inspector</a></dt> <dd>כלי לחקירה וסקירה של ה DOM.</dd> </dl> <a href="/he/כלים_נוספים" title="he/כלים נוספים">כלים נוספים</a></td> <td> <h2 id="תיעוד_וסימוכין_(reference)">תיעוד וסימוכין (reference)</h2> <dl> <dt><a href="/he/HTML" title="he/HTML">HTML</a></dt> <dd>שפת סימון, הטכנולוגיה שבליבה של האינטרנט.</dd> <dt><a href="/he/CSS" title="he/CSS">CSS</a></dt> <dd>גליונות עיצוב.</dd> <dt><a href="/he/JavaScript" title="he/JavaScript">JavaScript</a></dt> <dd>שפת תסריט המניעה אפליקציות אינטרנט מודרניות.</dd> <dt><a href="/he/DOM" title="he/DOM">DOM</a></dt> <dd>תבנית המסמך המתארת את מבנה דפי האינטרנט.</dd> <dt><a href="/he/AJAX" title="he/AJAX">AJAX</a></dt> <dd>תקשורת א-סינכרונית.</dd> </dl> <p><a href="/he/סימוכין_נוספים" title="he/סימוכין נוספים">סימוכין נוספים</a></p> </td> </tr> </tbody>
-</table>
-<p> </p>
-<h3 id="עברית_ב-MDN">עברית ב-MDN</h3>
-<ul> <li><a href="/he/מושגים" title="he/מושגים">מושגים</a> - רשימת המושגים שתורגמו לעברית והשיקולים בתרגום.</li> <li><a href="/he/Hebrew_Localization" title="he/Hebrew Localization">תרגום מסמכים לעברית</a></li>
-</ul>
-</div>
diff --git a/files/he/orphaned/hebrew_localization/index.html b/files/he/orphaned/hebrew_localization/index.html
deleted file mode 100644
index 958841b982..0000000000
--- a/files/he/orphaned/hebrew_localization/index.html
+++ /dev/null
@@ -1,8 +0,0 @@
----
-title: Hebrew Localization
-slug: orphaned/Hebrew_Localization
-original_slug: Hebrew_Localization
----
-<h3 id="Special_Hebrew_Templates">Special Hebrew Templates</h3>
-<p>Instead of jsOverrides, use HEjsOverrides</p>
-<h3 id="Multilingual_templates_with_Hebrew_localization">Multilingual templates with Hebrew localization</h3>
diff --git a/files/he/orphaned/mdn/community/index.html b/files/he/orphaned/mdn/community/index.html
deleted file mode 100644
index 944e09e5ff..0000000000
--- a/files/he/orphaned/mdn/community/index.html
+++ /dev/null
@@ -1,54 +0,0 @@
----
-title: הצטרפות לקהילת מסמכי הרשת של MDN
-slug: orphaned/MDN/Community
-tags:
- - מדריך
- - נחיתה
- - קהילה
-translation_of: MDN/Community
-original_slug: MDN/Community
----
-<div>{{MDNSidebar}}</div>
-
-<div>{{IncludeSubnav("/he/docs/MDN")}}</div>
-
-<div class="summary" dir="rtl">
-<p>אתר מסמכי הרשת של MDN הוא יותר מסתם ויקי: זוהי קהילה של מפתחים שעובדים יחד לעשות את MDN משאב מדהים למפתחי ווב.</p>
-</div>
-
-<p dir="rtl">נשמח אם תתרום ל- MDN, אבל נשמח יותר אם תשתתף בקהילת MDN. הנה שלושה צעדים פשוטים להתחבר:</p>
-
-<ol dir="rtl">
- <li><a href="/he/docs/MDN/Contribute/Howto/Create_an_MDN_account">ליצור חשבון MDN</a>.</li>
- <li><a href="/he/docs/MDN/Community/Conversations">להשתתף בדיונים</a>.</li>
- <li><a href="/he/docs/MDN/Community/Whats_happening">לעקוב אחרי מה שקורה</a>.</li>
-</ol>
-
-<h2 dir="rtl" id="איך_עובדת_הקהילה">איך עובדת הקהילה</h2>
-
-<p dir="rtl">להלן מאמרים נוספים שמתארים את קהילת MDN.</p>
-
-<div class="row topicpage-table" dir="rtl">
-<div class="section">
-<dl>
- <dt class="landingPageList"><a href="/he/docs/MDN/Community/Roles">תפקידים בקהילה</a></dt>
- <dd class="landingPageList">קיימים מספר תפקידים בקהילת MDN, שהם בעלי אחריות מסוימת.</dd>
- <dt class="landingPageList"><a href="/he/docs/MDN/Community/Doc_sprints">ספרינטים לתיעוד (Doc Sprint)</a></dt>
- <dd class="landingPageList">זהו מדריך לארגון ספרינט תיעוד. הוא כולל עצות וטיפים מאנשים שארגנו ספרינטים של תיעוד, כדי לעזור לך לארגן אחד כזה.</dd>
- <dt class="landingPageList"><a href="/he/docs/MDN/Community/Whats_happening">עקוב אחרי מה שקורה</a></dt>
- <dd class="landingPageList">MDN מובא לך על-ידי <a class="external" href="https://wiki.mozilla.org/MDN">קהילת רשת המפתחים של מוזילה</a>. הנה כמה דרכים בהן אנחנו משתפים מידע לגבי העבודה שלנו.</dd>
-</dl>
-
-<dl>
-</dl>
-</div>
-
-<div class="section" dir="rtl">
-<dl>
- <dt class="landingPageList"><a href="/he/docs/MDN/Community/Conversations">שיחות קהילה ב- MDN</a></dt>
- <dd class="landingPageList">ה"עבודה" של MDN קורה באתר של MDN, אך ה"קהילה" גם קורה בדיונים (אסכינכרוניים) וצ'אטים ופגישות מקוונים (סיכנרוניים).</dd>
- <dt class="landingPageList"><a href="/he/docs/MDN/Community/Working_in_community">עבודה בקהילה</a></dt>
- <dd class="landingPageList">חלק גדול בתרומה לתיעוד ב- MDN בכל היקף הוא לדעת כיצד לעבוד כחלק מקהילת MDN. מאמר זה מציע טיפים שיעזרו לך להפיק את המירב מהאינטראקציות שלך עם הן עם כותבים והם עם צוותי פיתוח אחרים.</dd>
-</dl>
-</div>
-</div>
diff --git a/files/he/orphaned/mdn/contribute/howto/create_an_mdn_account/index.html b/files/he/orphaned/mdn/contribute/howto/create_an_mdn_account/index.html
deleted file mode 100644
index d07381e39e..0000000000
--- a/files/he/orphaned/mdn/contribute/howto/create_an_mdn_account/index.html
+++ /dev/null
@@ -1,43 +0,0 @@
----
-title: איך ליצור חשבון MDN
-slug: orphaned/MDN/Contribute/Howto/Create_an_MDN_account
-tags:
- - למתחילים
- - מדריך
- - תיעוד
-translation_of: MDN/Contribute/Howto/Create_an_MDN_account
-original_slug: MDN/Contribute/Howto/Create_an_MDN_account
----
-<div>{{MDNSidebar}}</div>
-
-<p><span class="seoSummary">כדי לערוך תוכן ב- MDN, עליך ליצור פרופיל MDN. אין צורך ליצור פרופיל אם ברצונך רק לקרוא ולעיין במסמכי MDN. מדריך זה יעזור לך להגדיר את פרופיל ה- MDN.</span></p>
-
-<div class="pull-aside">
-<div class="moreinfo"><strong>למה MDN זקוקים לכתובת הדוא"ל שלי?</strong><br>
-<br>
-כתובת הדוא"ל שלך משמשת לשחזור החשבון, ובמידת הצורך ליצירת קשר על-ידי מנהלי MDN לגבי החשבון שלך או פעילותך באתר.<br>
-<br>
-בנוסף, תוכל להירשם להתראות (כמו <a href="/he/docs/MDN/Contribute/Howto/Watch_a_page">כשעמודים מסוימים משתנים</a>) והודעות (למשל, אם תבחר להצטרף לצוות בדיקות הבטא שלנו, תוכל לקבל הודעות לגבי שינויים המצריכים בדיקה).<br>
-<br>
-כתובת הדוא"ל שלך לעולם לא תוצג ב- MDN ותשמש רק בהתאם ל<a href="https://www.mozilla.org/privacy/websites/">מדיניות הפרטיות</a> שלנו.<br>
-
-<div class="note">אם נכנסת ל- MDN באמצעות GitHub, והשתמשת בכתובת דוא"ל אוטומטית (ללא מענה) ב- GitHub, <em>לא תקבל</em> הודעות מ- MDN (כולל התראות כשתירשם לעמודים).</div>
-</div>
-</div>
-
-<ol>
- <li>בראש כל עמוד ב- MDN ניתן למצוא את לחצן <strong>Sign in</strong>. מקם עליו את סמן העכבר (או הקש עליו, אם אתה משתמש במכשיר נייד) כדי להציג רשימה של שירותי האימות הנתמכים בכניסה ל- MDN.</li>
- <li>בחר בשירות הרצוי לצורך כניסה. כרגע, רק GitHub זמין. שים לב שאם בחרת ב- GitHub, יופיע קישור לפרופיל ה- GitHub שלך בעמוד הפרופיל הציבורי שלך ב- MDN.</li>
- <li>מלא את בקשות GitHub כדי לקשר את חשבון ה- MDN שלך.</li>
- <li>לאחר ששירות האימות יחזיר אותך ל- MDN, תתבקש להזין שם משתמש וכתובת דוא"ל. <em>שם המשתמש שלך יוצג באופן ציבורי כדי לתת קרדיט לעבודה שעשית. אל תשתמש בכתובת הדוא"ל שלך כשם המשתמש שלך</em><strong>.</strong></li>
- <li>הקלק על <strong>Create my MDN profile</strong>.</li>
- <li>אם כתובת הדוא"ל שציינת בצעד 4 אינו זהה לזה של שירות האימות, אנא בדוק את תיבת הדוא"ל שלך והקלק על הקישור בהודעת האישור ששלחנו אליך.</li>
-</ol>
-
-<p>זה הכל! יש לך חשבון MDN, ואתה יכול לערוך עמודים כבר עכשיו!</p>
-
-<p>אתה יכול להקליק על השם שלך בראש כל עמוד MDN ולראות את הפרופיל הציבורי שלך. משם תוכל להקליק על <strong>Edit</strong> כדי לערוך שינויים או תוספות לפרופיל שלך.</p>
-
-<div class="note">
-<p>שמות משתמש חדשים לא יכולים להכיל רווחים או "@". יש לזכור ששם המשתמש שלך יוצג באופן ציבורי כדי לזהות את העבודה שעשית.</p>
-</div>
diff --git a/files/he/orphaned/web/hypertext_markup_language/index.html b/files/he/orphaned/web/hypertext_markup_language/index.html
deleted file mode 100644
index f9a9393a9e..0000000000
--- a/files/he/orphaned/web/hypertext_markup_language/index.html
+++ /dev/null
@@ -1,91 +0,0 @@
----
-title: Hypertext Markup Language
-slug: orphaned/Web/Hypertext_Markup_Language
-original_slug: Web/Hypertext_Markup_Language
----
-<div>
-<p><a href="/he/docs/HTML/HTML5" title="html5"><img alt="HTML5_Logo_128.png" src="/@api/deki/files/6020/=HTML5_Logo_128.png"></a></p>
-
-<p dir="rtl"><strong>HyperText Markup Language‏ (HTML)</strong> הינה שפה המשמשת ליצירת דפי אינטרנט ומסמכים אחרים הניתנים לצפייה בדפדפן אינטרנט.<br>
- HTML הוא תקן בינלאומי המוגדר על ידי ה־<a href="http://www.w3.org/" title="http://www.w3.org/">World Wide Web Consortium</a>. הגרסה הנוכחית של התקן היא <a href="http://www.whatwg.org/specs/web-apps/current-work/" title="http://www.whatwg.org/specs/web-apps/current-work/">גרסה 5</a> שהושקה בחודש אוקטובר 2014.</p>
-
-<p dir="rtl">ניתן להעשיר את דפי ה-HTML באמצעות <strong>גיליונות סגנון מדורגים</strong> <strong>(CSS)</strong> איתם ניתן לעצב את דפי האינטרנט והמסמכים שנבנו.<br>
- בנוסף, ניתן להטמיע תסריטים בדף באמצעות שפת <strong>ג'אווה</strong> <strong>סקריפט (JavasScript)</strong> הנחשבת לשפת תכנות דינמית מונחית־עצמים.</p>
-
-<table dir="rtl">
- <tbody>
- <tr>
- <td>
- <p dir="rtl"> </p>
-
- <h3 dir="rtl" id="היכרות_ראשונית">היכרות ראשונית</h3>
-
- <dl>
- <dt dir="rtl"><a href="https://developer.mozilla.org/he/docs/Learn/HTML/%D7%9E%D7%91%D7%95%D7%90_%D7%9C%D7%A9%D7%A4%D7%AA_HTML">מבוא לשפת HTML</a></dt>
- <dd dir="rtl">היכרות ראשונה עם שפת HTML למשתמשים מתחילים.</dd>
- <dt dir="rtl"><a href="https://developer.mozilla.org/he/docs/Web/HTML/Element">רשימת תגיות של שפת HTML</a></dt>
- <dd dir="rtl">מאגר תגיות בהן ניתן לבצע שימוש.</dd>
- </dl>
-
- <dl>
- <dt dir="rtl"><a href="https://developer.mozilla.org/he/docs/Learn/HTML/%D7%94%D7%98%D7%9E%D7%A2%D7%AA_%D7%9E%D7%95%D7%9C%D7%98%D7%99%D7%9E%D7%93%D7%99%D7%94">הטמעת מולטימדיה </a></dt>
- <dd dir="rtl">כיצד לשלב תמונות, סירטונים וקובצי קול בדף האינטרנט.</dd>
- <dt dir="rtl"><a href="https://developer.mozilla.org/he/docs/Learn/HTML/%D7%98%D7%91%D7%9C%D7%90%D7%95%D7%AA">טבלאות</a></dt>
- <dd dir="rtl">בניה והצגת נתונים באמצעות טבלאות בדף אינטרנט.</dd>
- <dt dir="rtl"><a href="https://developer.mozilla.org/he/docs/Learn/HTML/%D7%98%D7%A4%D7%A1%D7%99%D7%9D">טפסים</a></dt>
- <dd dir="rtl">טפסים הם נדבך חשוב בדף האינטרנט ומשמשים ליצירת קשר ראשוני עם הלקוחות באמצעות טפסים ליצירת קשר, קניה ומכירה של מוצרים וליצירת משתמשים חדשים.</dd>
- <dt dir="rtl"><a href="https://developer.mozilla.org/he/docs/Learn/HTML/%D7%A4%D7%AA%D7%A8%D7%95%D7%9F_%D7%91%D7%A2%D7%99%D7%95%D7%AA">פתרון בעיות נפוצות </a></dt>
- <dd dir="rtl">מאגר שאלות ותשובות המספקות מענה לבעיות נפוצות בכתיבת מסמכים בשפת HTML.</dd>
- <dt dir="rtl"> </dt>
- </dl>
-
- <h3 dir="rtl" id="מידע_למתקדמים">מידע למתקדמים</h3>
-
- <dl>
- <dt dir="rtl"><a href="https://developer.mozilla.org/he/docs/Web/HTML/Cross-Origin_Resource_Sharing">Cross-Origin Resource Sharing</a></dt>
- <dd dir="rtl">היכרות ראשונה עם שפת CROS.</dd>
- <dt dir="rtl"><a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%9B%D7%95%D7%A0%D7%95%D7%AA_%D7%95%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%A9%D7%9C_CORS">תכונות ותארים של CORS </a></dt>
- <dd dir="rtl">באילו אלמנטים ותגיות ניתן להשתמש.</dd>
- <dt dir="rtl"><a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%98%D7%A2%D7%99%D7%A0%D7%AA_%D7%AA%D7%9B%D7%A0%D7%99%D7%9D_%D7%9E%D7%95%D7%A7%D7%93%D7%9E%D7%AA">טעינת תכנים מוקדמת </a></dt>
- <dd dir="rtl">טעינת תכנים מראש באמצעות rel="preload".</dd>
- </dl>
- </td>
- <td dir="rtl">
- <h3 dir="rtl" id="עזרים">עזרים</h3>
-
- <dl>
- <dt dir="rtl"><a href="https://addons.mozilla.org/en-US/firefox/addon/firebug/">FireBug</a></dt>
- <dd dir="rtl">תוסף לדפדפן האינטרנט המסייע באיתור באגים באתרי אינטרנט.</dd>
- <dt dir="rtl"><a href="https://prettydiff.com/?html">Prettydiff</a></dt>
- <dd dir="rtl">כלי להשוואת קוד ואיתור שגיאות.</dd>
- <dt dir="rtl"><a href="https://validator.w3.org/">Markup Validation</a></dt>
- <dd dir="rtl">כלי להשוואת קוד ואיתור שגיאות.</dd>
- <dt dir="rtl"> </dt>
- </dl>
-
- <dl>
- </dl>
-
- <h3 dir="rtl" id="קהילה">קהילה</h3>
-
- <dl>
- <dt dir="rtl"><a href="https://www.w3schools.com/">W3schools</a></dt>
- <dd dir="rtl">אתר המכיל מדריכים ותרגולים בנושאים שונים.</dd>
- <dt dir="rtl"><a href="https://stackoverflow.com/questions/tagged/html"> Stackoverflow - HTML</a></dt>
- <dd dir="rtl">שאלות ותשובות בנושאי חומרה ותוכנה.</dd>
- <dt dir="rtl"> </dt>
- </dl>
-
- <h3 dir="rtl" id="נושאים_קשורים">נושאים קשורים</h3>
-
- <dl>
- <dt dir="rtl"><a href="https://developer.mozilla.org/he/docs/Learn/HTML/%D7%9E%D7%91%D7%95%D7%90_%D7%9C%D7%A9%D7%A4%D7%AA_HTML">CSS - גיליונות סגנון מדורגים</a></dt>
- <dd dir="rtl">שפה השמשת להפרדה בין תוכן ומבנה הדף לבין עיצובו.</dd>
- <dt dir="rtl"><a href="https://developer.mozilla.org/he/docs/Web/JavaScript">JS - ג'אווה סקריפט</a></dt>
- <dd dir="rtl">שפת תכנות מונחית עצמים המיועדת לשימוש באתרים ואפליקציות אינטרנט.</dd>
- </dl>
- </td>
- </tr>
- </tbody>
-</table>
-</div>
diff --git a/files/he/orphaned/מושגים/index.html b/files/he/orphaned/מושגים/index.html
deleted file mode 100644
index 665c8b31bc..0000000000
--- a/files/he/orphaned/מושגים/index.html
+++ /dev/null
@@ -1,11 +0,0 @@
----
-title: מושגים
-slug: orphaned/מושגים
-original_slug: מושגים
----
-<div dir="rtl">
-<p>רשימת מושגים והתרגומים שנבחרו עבורם. דיון בנוגע לתרגומים מתנהל באזור ה"שיחה".</p>
-<table class="standard-table"> <thead> <tr> <th>מושג</th> <th>תרגום</th> <th>הערות</th> </tr> </thead> <tbody> <tr> <td>reference</td> <td>תיעוד</td> <td>המילון מספק עבור reference את התרגום "סימוכין" או "התייחסות".</td> </tr> <tr> <td>object oriented</td> <td>מוכוון עצמים</td> <td>ניתן להתייחס גם כמונחה עצמים.</td> </tr> </tbody>
-</table>
-<p> </p>
-</div>
diff --git a/files/he/web/api/console/index.html b/files/he/web/api/console/index.html
deleted file mode 100644
index 61521af0f3..0000000000
--- a/files/he/web/api/console/index.html
+++ /dev/null
@@ -1,294 +0,0 @@
----
-title: Console
-slug: Web/API/Console
-tags:
- - API
- - Debugging
- - Interface
- - NeedsTranslation
- - Reference
- - TopicStub
- - console
- - web console
-translation_of: Web/API/Console
----
-<div>{{APIRef("Console API")}}</div>
-
-<p>The <strong><code>Console</code></strong> object provides access to the browser's debugging console (e.g. the <a href="/en-US/docs/Tools/Web_Console">Web Console</a> in Firefox). The specifics of how it works varies from browser to browser, but there is a <em>de facto</em> set of features that are typically provided.</p>
-
-<p>The <code>Console</code> object can be accessed from any global object. {{domxref("Window")}} on browsing scopes and {{domxref("WorkerGlobalScope")}} as specific variants in workers via the property console. It's exposed as {{domxref("Window.console")}}, and can be referenced as simply <code>console</code>. For example:</p>
-
-<pre class="brush: js">console.log("Failed to open the specified link")</pre>
-
-<p>This page documents the {{anch("Methods")}} available on the <code>Console</code> object and gives a few {{anch("Usage")}} examples.</p>
-
-<p>{{AvailableInWorkers}}</p>
-
-<h2 id="Methods">Methods</h2>
-
-<dl>
- <dt>{{domxref("Console.assert()")}}</dt>
- <dd>Log a message and stack trace to console if the first argument is <code>false</code>.</dd>
- <dt>{{domxref("Console.clear()")}}</dt>
- <dd>Clear the console.</dd>
- <dt>{{domxref("Console.count()")}}</dt>
- <dd>Log the number of times this line has been called with the given label.</dd>
- <dt>{{domxref("Console.countReset()")}}</dt>
- <dd>Resets the value of the counter with the given label.</dd>
- <dt>{{domxref("Console.debug()")}}</dt>
- <dd>Outputs a message to the console with the log level <code>"debug"</code>.
- <div class="note"><strong>Note</strong>: Starting with Chromium 58 this method only appears in Chromium browser consoles when level "Verbose" is selected.</div>
- </dd>
- <dt>{{domxref("Console.dir()")}}</dt>
- <dd>Displays an interactive listing of the properties of a specified JavaScript object. This listing lets you use disclosure triangles to examine the contents of child objects.</dd>
- <dt>{{domxref("Console.dirxml()")}}</dt>
- <dd>
- <p>Displays an XML/HTML Element representation of the specified object if possible or the JavaScript Object view if it is not possible.</p>
- </dd>
- <dt>{{domxref("Console.error()")}}</dt>
- <dd>Outputs an error message. You may use <a href="/en-US/docs/Web/API/console#Using_string_substitutions">string substitution</a> and additional arguments with this method.</dd>
- <dt>{{domxref("Console.exception()")}} {{Non-standard_inline}} {{deprecated_inline}}</dt>
- <dd>An alias for <code>error()</code>.</dd>
- <dt>{{domxref("Console.group()")}}</dt>
- <dd>Creates a new inline <a href="/en-US/docs/Web/API/console#Using_groups_in_the_console">group</a>, indenting all following output by another level. To move back out a level, call <code>groupEnd()</code>.</dd>
- <dt>{{domxref("Console.groupCollapsed()")}}</dt>
- <dd>Creates a new inline <a href="/en-US/docs/Web/API/console#Using_groups_in_the_console">group</a>, indenting all following output by another level. However, unlike <code>group()</code> this starts with the inline group collapsed requiring the use of a disclosure button to expand it. To move back out a level, call <code>groupEnd()</code>.</dd>
- <dt>{{domxref("Console.groupEnd()")}}</dt>
- <dd>Exits the current inline <a href="/en-US/docs/Web/API/console#Using_groups_in_the_console">group</a>.</dd>
- <dt>{{domxref("Console.info()")}}</dt>
- <dd>Informative logging of information. You may use <a href="/en-US/docs/Web/API/console#Using_string_substitutions">string substitution</a> and additional arguments with this method.</dd>
- <dt>{{domxref("Console.log()")}}</dt>
- <dd>For general output of logging information. You may use <a href="/en-US/docs/Web/API/console#Using_string_substitutions">string substitution</a> and additional arguments with this method.</dd>
- <dt>{{domxref("Console.profile()")}} {{Non-standard_inline}}</dt>
- <dd>Starts the browser's built-in profiler (for example, the <a href="/en-US/docs/Tools/Performance">Firefox performance tool</a>). You can specify an optional name for the profile.</dd>
- <dt>{{domxref("Console.profileEnd()")}} {{Non-standard_inline}}</dt>
- <dd>Stops the profiler. You can see the resulting profile in the browser's performance tool (for example, the <a href="/en-US/docs/Tools/Performance">Firefox performance tool</a>).</dd>
- <dt>{{domxref("Console.table()")}}</dt>
- <dd>Displays tabular data as a table.</dd>
- <dt>{{domxref("Console.time()")}}</dt>
- <dd>Starts a <a href="/en-US/docs/Web/API/console#Timers">timer</a> with a name specified as an input parameter. Up to 10,000 simultaneous timers can run on a given page.</dd>
- <dt>{{domxref("Console.timeEnd()")}}</dt>
- <dd>Stops the specified <a href="/en-US/docs/Web/API/console#Timers">timer</a> and logs the elapsed time in seconds since it started.</dd>
- <dt>{{domxref("Console.timeLog()")}}</dt>
- <dd>Logs the value of the specified <a href="/en-US/docs/Web/API/console#Timers">timer</a> to the console.</dd>
- <dt>{{domxref("Console.timeStamp()")}} {{Non-standard_inline}}</dt>
- <dd>Adds a marker to the browser's <a href="https://developer.chrome.com/devtools/docs/timeline">Timeline</a> or <a href="/en-US/docs/Tools/Performance/Waterfall">Waterfall</a> tool.</dd>
- <dt>{{domxref("Console.trace()")}}</dt>
- <dd>Outputs a <a href="/en-US/docs/Web/API/console#Stack_traces">stack trace</a>.</dd>
- <dt>{{domxref("Console.warn()")}}</dt>
- <dd>Outputs a warning message. You may use <a href="/en-US/docs/Web/API/console#Using_string_substitutions">string substitution</a> and additional arguments with this method.</dd>
-</dl>
-
-<h2 id="Usage" name="Usage">Usage</h2>
-
-<h3 id="Outputting_text_to_the_console" name="Outputting_text_to_the_console">Outputting text to the console</h3>
-
-<p>The most frequently-used feature of the console is logging of text and other data. There are four categories of output you can generate, using the {{domxref("console.log()")}}, {{domxref("console.info()")}}, {{domxref("console.warn()")}}, and {{domxref("console.error()")}} methods respectively. Each of these results in output styled differently in the log, and you can use the filtering controls provided by your browser to only view the kinds of output that interest you.</p>
-
-<p>There are two ways to use each of the output methods; you can simply pass in a list of objects whose string representations get concatenated into one string, then output to the console, or you can pass in a string containing zero or more substitution strings followed by a list of objects to replace them.</p>
-
-<h4 id="Outputting_a_single_object">Outputting a single object</h4>
-
-<p>The simplest way to use the logging methods is to output a single object:</p>
-
-<pre class="brush: js">var someObject = { str: "Some text", id: 5 };
-console.log(someObject);
-</pre>
-
-<p>The output looks something like this:</p>
-
-<pre>[09:27:13.475] ({str:"Some text", id:5})</pre>
-
-<h4 id="Outputting_multiple_objects">Outputting multiple objects</h4>
-
-<p>You can also output multiple objects by simply listing them when calling the logging method, like this:</p>
-
-<pre class="brush: js">var car = "Dodge Charger";
-var someObject = { str: "Some text", id: 5 };
-console.info("My first car was a", car, ". The object is:", someObject);</pre>
-
-<p>This output will look like this:</p>
-
-<pre>[09:28:22.711] My first car was a Dodge Charger . The object is: ({str:"Some text", id:5})
-</pre>
-
-<h4 id="Using_string_substitutions">Using string substitutions</h4>
-
-<p>Gecko 9.0 {{geckoRelease("9.0")}} introduced support for string substitutions. When passing a string to one of the console object's methods that accepts a string, you may use these substitution strings:</p>
-
-<table class="standard-table" style="width: auto;">
- <tbody>
- <tr>
- <td class="header">Substitution string</td>
- <td class="header">Description</td>
- </tr>
- <tr>
- <td>%o or %O</td>
- <td>Outputs a JavaScript object. Clicking the object name opens more information about it in the inspector.</td>
- </tr>
- <tr>
- <td>%d or %i</td>
- <td>Outputs an integer. Number formatting is supported, for example  <code>console.log("Foo %.2d", 1.1)</code> will output the number as two significant figures with a leading 0: <code>Foo 01</code></td>
- </tr>
- <tr>
- <td>%s</td>
- <td>Outputs a string.</td>
- </tr>
- <tr>
- <td>%f</td>
- <td>Outputs a floating-point value. Formatting is supported, for example  <code>console.log("Foo %.2f", 1.1)</code> will output the number to 2 decimal places: <code>Foo 1.10</code></td>
- </tr>
- </tbody>
-</table>
-
-<div class="note">
-<p><strong>Note</strong>: Precision formatting doesn't work in Chrome</p>
-</div>
-
-<p>Each of these pulls the next argument after the format string off the parameter list. For example:</p>
-
-<pre>for (var i=0; i&lt;5; i++) {
-  console.log("Hello, %s. You've called me %d times.", "Bob", i+1);
-}
-</pre>
-
-<p>The output looks like this:</p>
-
-<pre>[13:14:13.481] Hello, Bob. You've called me 1 times.
-[13:14:13.483] Hello, Bob. You've called me 2 times.
-[13:14:13.485] Hello, Bob. You've called me 3 times.
-[13:14:13.487] Hello, Bob. You've called me 4 times.
-[13:14:13.488] Hello, Bob. You've called me 5 times.
-</pre>
-
-<h4 id="Styling_console_output">Styling console output</h4>
-
-<p>You can use the <code>%c</code> directive to apply a CSS style to console output:</p>
-
-<pre class="brush: js">console.log("This is %cMy stylish message", "color: yellow; font-style: italic; background-color: blue;padding: 2px");</pre>
-
-<div>The text before the directive will not be affected, but the text after the directive will be styled using the CSS declarations in the parameter.</div>
-
-<div> </div>
-
-<div><img alt="" src="https://mdn.mozillademos.org/files/12527/CSS-styling.png" style="display: block; margin: 0 auto;"></div>
-
-<div> </div>
-
-<div class="note">
-<p><strong>Note</strong>: Quite a few CSS properties are supported by this styling; you should experiment and see which ones prove useful.</p>
-</div>
-
-<div> </div>
-
-<div>{{h3_gecko_minversion("Using groups in the console", "9.0")}}</div>
-
-<p>You can use nested groups to help organize your output by visually combining related material. To create a new nested block, call <code>console.group()</code>. The <code>console.groupCollapsed()</code> method is similar but creates the new block collapsed, requiring the use of a disclosure button to open it for reading.</p>
-
-<div class="note"><strong>Note:</strong> Collapsed groups are not supported yet in Gecko; the <code>groupCollapsed()</code> method is the same as <code>group()</code> at this time.</div>
-
-<p>To exit the current group, simply call <code>console.groupEnd()</code>. For example, given this code:</p>
-
-<pre class="brush: js">console.log("This is the outer level");
-console.group();
-console.log("Level 2");
-console.group();
-console.log("Level 3");
-console.warn("More of level 3");
-console.groupEnd();
-console.log("Back to level 2");
-console.groupEnd();
-console.debug("Back to the outer level");
-</pre>
-
-<p>The output looks like this:</p>
-
-<p><img alt="nesting.png" class="default internal" src="/@api/deki/files/6082/=nesting.png"></p>
-
-<div>{{h3_gecko_minversion("Timers", "10.0")}}</div>
-
-<p>In order to calculate the duration of a specific operation, Gecko 10 introduced the support of timers in the <code>console</code> object. To start a timer, call the <code>console.time</code><code>()</code> method, giving it a name as the only parameter. To stop the timer, and to get the elapsed time in milliseconds, just call the <code>console.timeEnd()</code> method, again passing the timer's name as the parameter. Up to 10,000 timers can run simultaneously on a given page.</p>
-
-<p>For example, given this code:</p>
-
-<pre class="brush: js">console.time("answer time");
-alert("Click to continue");
-console.timeLog("answer time");
-alert("Do a bunch of other stuff...");
-console.timeEnd("answer time");
-</pre>
-
-<p>Will log the time needed by the user to dismiss the alert box, log the time to the console, wait for the user to dismiss the second alert, and then log the ending time to the console:</p>
-
-<p><img alt="timerresult.png" class="default internal" src="https://mdn.mozillademos.org/files/16113/console-timeLog.png" style="border: 1px solid black; height: 102px; margin: 0 auto; width: 318px;"></p>
-
-<p>Notice that the timer's name is displayed both when the timer is started and when it's stopped.</p>
-
-<div class="note"><strong>Note:</strong> It's important to note that if you're using this to log the timing for network traffic, the timer will report the total time for the transaction, while the time listed in the network panel is just the amount of time required for the header. If you have response body logging enabled, the time listed for the response header and body combined should match what you see in the console output.</div>
-
-<h3 id="Stack_traces">Stack traces</h3>
-
-<p>The console object also supports outputting a stack trace; this will show you the call path taken to reach the point at which you call {{domxref("console.trace()")}}. Given code like this:</p>
-
-<pre class="brush: js">function foo() {
-  function bar() {
-    console.trace();
-  }
-  bar();
-}
-
-foo();
-</pre>
-
-<p>The output in the console looks something like this:</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/7167/api-trace2.png" style="display: block; margin-left: auto; margin-right: auto;"></p>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('Console API')}}</td>
- <td>{{Spec2('Console API')}}</td>
- <td>Initial definition.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-
-
-<p>{{Compat("api.Console")}}</p>
-
-<h2 id="Notes">Notes</h2>
-
-<ul>
- <li>At least in Firefox, if a page defines a <code>console</code> object, that object overrides the one built into Firefox.</li>
- <li>Prior to {{Gecko("12.0")}}, the console object's methods only work when the Web Console is open. Starting with {{Gecko("12.0")}}, output is cached until the Web Console is opened, then displayed at that time.</li>
- <li>It's worth noting that the Firefox's built-in <code>Console</code> object is compatible with the one provided by <a class="external" href="http://getfirebug.com/" title="http://getfirebug.com/">Firebug</a>.</li>
-</ul>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li><a href="/en-US/docs/Tools" title="Tools">Tools</a></li>
- <li><a href="/en-US/docs/Tools/Web_Console" title="Web Console">Web Console</a> — how the Web Console in Firefox handles console API calls</li>
- <li><a href="/en-US/docs/Tools/Remote_Debugging">Remote debugging</a> — how to see console output when the debugging target is a mobile device</li>
- <li><a href="/en-US/docs/Mozilla/Firefox_OS/Debugging/On-device_console_logging" title="/en-US/docs/Mozilla/Firefox_OS/Debugging/On-device_console_logging">On-device console logging</a> — how to do logging on Firefox OS devices</li>
-</ul>
-
-<h3 id="Other_implementations">Other implementations</h3>
-
-<ul>
- <li><a href="https://developers.google.com/chrome-developer-tools/docs/console-api">Google Chrome DevTools</a></li>
- <li><a href="http://getfirebug.com/wiki/index.php/Console_API">Firebug</a></li>
- <li><a href="http://msdn.microsoft.com/en-us/library/hh772173(v=vs.85).aspx">Internet Explorer</a></li>
- <li><a href="https://developer.apple.com/library/safari/documentation/AppleApplications/Conceptual/Safari_Developer_Guide/Console/Console.html">Safari</a></li>
-</ul>
diff --git a/files/he/web/api/console/log/index.html b/files/he/web/api/console/log/index.html
deleted file mode 100644
index 8ea8ab6218..0000000000
--- a/files/he/web/api/console/log/index.html
+++ /dev/null
@@ -1,39 +0,0 @@
----
-title: Console.log()
-slug: Web/API/Console/log
-translation_of: Web/API/Console/log
----
-<div>{{APIRef("Console API")}}</div>
-
-<p><strong><code>()Console.log</code></strong> - מציגה את פלט ההודעה באזור המסוף של דפדפן האינטרנט.</p>
-
-<h2 id="תחביר">תחביר</h2>
-
-<pre class="syntaxbox">console.log(<em>obj1</em> [, <em>obj2</em>, ..., <em>objN</em>]);
-console.log(<em>msg</em> [, <em>subst1</em>, ..., <em>substN</em>]);
-</pre>
-
-<h2 id="מפרט">מפרט</h2>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>{{SpecName("Console API", "#log", "console.log()")}}</td>
- <td>{{Spec2("Console API")}}</td>
- <td>Initial definition</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תאימות_דפדפן">תאימות דפדפן</h2>
-
-
-
-<p>{{Compat("api.Console.log")}}</p>
diff --git a/files/he/web/api/document/index.html b/files/he/web/api/document/index.html
deleted file mode 100644
index 6862ada7f2..0000000000
--- a/files/he/web/api/document/index.html
+++ /dev/null
@@ -1,488 +0,0 @@
----
-title: Document
-slug: Web/API/Document
-tags:
- - API
- - DOM
- - Document
- - Interface
- - NeedsTranslation
- - Reference
- - TopicStub
-translation_of: Web/API/Document
----
-<p><span class="seoSummary">The <strong><code>Document</code></strong> interface represents any web page loaded in the browser and serves as an entry point into the web page's content, which is the <a href="/en-US/docs/Using_the_W3C_DOM_Level_1_Core" title="Using_the_W3C_DOM_Level_1_Core">DOM tree</a>.</span> The DOM tree includes elements such as {{HTMLElement("body")}} and {{HTMLElement("table")}}, among <a href="/en-US/docs/Web/HTML/Element">many others</a>. It provides functionality globally to the document, like how to obtain the page's URL and create new elements in the document.</p>
-
-<p>{{inheritanceDiagram}}</p>
-
-<p>The <code>Document</code> interface describes the common properties and methods for any kind of document. Depending on the document's type (e.g. <a href="/en-US/docs/HTML" title="HTML">HTML</a>, <a href="/en-US/docs/XML" title="XML">XML</a>, SVG, …), a larger API is available: HTML documents, served with the <code>"text/html"</code> content type, also implement the {{domxref("HTMLDocument")}} interface, whereas XML and SVG documents implement the {{domxref("XMLDocument")}} interface.</p>
-
-<h2 id="Properties" name="Properties">Constructor</h2>
-
-<dl>
- <dt>{{domxref("Document.Document","Document()")}}{{non-standard_inline}}</dt>
- <dd>Creates a new <code>Document</code> object.</dd>
-</dl>
-
-<h2 id="Properties" name="Properties">Properties</h2>
-
-<p><em>This interface also inherits from the {{domxref("Node")}} and {{domxref("EventTarget")}} interfaces.</em></p>
-
-<dl>
- <dt>{{domxref("Document.anchors")}} {{readonlyinline}}</dt>
- <dd>Returns a list of all of the anchors in the document.</dd>
- <dt>{{domxref("Document.body")}}</dt>
- <dd>Returns the {{HTMLElement("body")}} or {{htmlelement("frameset")}} node of the current document.</dd>
- <dt>{{domxref("Document.characterSet")}} {{readonlyinline}}</dt>
- <dd>Returns the character set being used by the document.</dd>
- <dt>{{domxref("Document.compatMode")}} {{readonlyinline}} {{experimental_inline}}</dt>
- <dd>Indicates whether the document is rendered in <em>quirks</em> or <em>strict</em> mode.</dd>
- <dt>{{domxref("Document.contentType")}} {{readonlyinline}} {{experimental_inline}}</dt>
- <dd>Returns the Content-Type from the MIME Header of the current document.</dd>
- <dt>{{domxref("Document.doctype")}} {{readonlyinline}}</dt>
- <dd>Returns the Document Type Definition (DTD) of the current document.</dd>
- <dt>{{domxref("Document.documentElement")}} {{readonlyinline}}</dt>
- <dd>Returns the {{domxref("Element")}} that is a direct child of the document. For HTML documents, this is normally the <span class="seoSummary">{{domxref("HTMLElement")}}</span> element.</dd>
- <dt>{{domxref("Document.documentURI")}} {{readonlyinline}}</dt>
- <dd>Returns the document location as a string.</dd>
- <dt>{{domxref("Document.embeds")}} {{readonlyinline}}</dt>
- <dd>Returns a list of the embedded {{HTMLElement('embed')}} elements within the current document.</dd>
- <dt>{{domxref("Document.fonts")}}</dt>
- <dd>Returns the {{domxref("FontFaceSet")}} interface of the current document.</dd>
- <dt>{{domxref("Document.forms")}} {{readonlyinline}}</dt>
- <dd>Returns a list of the {{HTMLElement("form")}} elements within the current document.</dd>
- <dt>{{domxref("Document.head")}} {{readonlyinline}}</dt>
- <dd>Returns the {{HTMLElement("head")}} element of the current document.</dd>
- <dt>{{domxref("Document.hidden")}} {{readonlyinline}}</dt>
- <dd>…</dd>
- <dt>{{domxref("Document.images")}} {{readonlyinline}}</dt>
- <dd>Returns a list of the images in the current document.</dd>
- <dt>{{domxref("Document.implementation")}} {{readonlyinline}}</dt>
- <dd>Returns the DOM implementation associated with the current document.</dd>
- <dt>{{domxref("Document.lastStyleSheetSet")}} {{readonlyinline}}</dt>
- <dd>Returns the name of the style sheet set that was last enabled. Has the value <code>null</code> until the style sheet is changed by setting the value of {{domxref("document.selectedStyleSheetSet","selectedStyleSheetSet")}}.</dd>
- <dt>{{domxref("Document.links")}} {{readonlyinline}}</dt>
- <dd>Returns a list of all the hyperlinks in the document.</dd>
- <dt>{{domxref("Document.mozSyntheticDocument")}} {{non-standard_inline}} {{gecko_minversion_inline("8.0")}}</dt>
- <dd>Returns a {{jsxref("Boolean")}} that is <code>true</code> only if this document is synthetic, such as a standalone image, video, audio file, or the like.</dd>
- <dt>{{domxref("Document.mozFullScreenElement")}} {{readonlyinline}} {{non-standard_inline}} {{gecko_minversion_inline("9.0")}}</dt>
- <dd>The element that's currently in full screen mode for this document.</dd>
- <dt>{{domxref("Document.mozFullScreenEnabled")}} {{readonlyinline}} {{non-standard_inline}} {{gecko_minversion_inline("9.0")}}</dt>
- <dd><code>true</code> if calling {{domxref("Element.mozRequestFullscreen()")}} would succeed in the current document.</dd>
- <dt>{{domxref("Document.plugins")}} {{readonlyinline}}</dt>
- <dd>Returns a list of the available plugins.</dd>
- <dt>{{domxref("Document.policy")}} {{readonlyinline}}{{experimental_inline}}</dt>
- <dd>Returns the {{domxref("Policy")}} interface which provides a simple API for introspecting the feature policies applied to a specific document.</dd>
- <dt>{{domxref("Document.preferredStyleSheetSet")}} {{readonlyinline}}</dt>
- <dd>Returns the preferred style sheet set as specified by the page author.</dd>
- <dt>{{domxref("Document.scripts")}} {{readonlyinline}}</dt>
- <dd>Returns all the {{HTMLElement("script")}} elements on the document.</dd>
- <dt>{{domxref("Document.scrollingElement")}} {{readonlyinline}}</dt>
- <dd>Returns a reference to the {{domxref("Element")}} that scrolls the document.</dd>
- <dt>{{domxref("Document.selectedStyleSheetSet")}}</dt>
- <dd>Returns which style sheet set is currently in use.</dd>
- <dt>{{domxref("Document.styleSheetSets")}} {{readonlyinline}}</dt>
- <dd>Returns a list of the style sheet sets available on the document.</dd>
- <dt>{{domxref("Document.timeline")}} {{readonlyinline}}</dt>
- <dd>…</dd>
- <dt>{{domxref("Document.undoManager")}} {{readonlyinline}} {{experimental_inline}}</dt>
- <dd>…</dd>
- <dt>{{domxref("Document.visibilityState")}} {{readonlyinline}}</dt>
- <dd>Returns a <code>string</code> denoting the visibility state of the document. Possible values are <code>visible</code>,  <code>hidden</code>,  <code>prerender</code>, and <code>unloaded</code>.</dd>
-</dl>
-
-<p>The <code>Document</code> interface is extended with the {{domxref("ParentNode")}} interface:</p>
-
-<p>{{page("/en-US/docs/Web/API/ParentNode","Properties")}}</p>
-
-<h3 id="Extensions_for_HTMLDocument">Extensions for HTMLDocument</h3>
-
-<p><em>The <code>Document</code> interface for HTML documents inherits from the {{domxref("HTMLDocument")}} interface or, since HTML5,  is extended for such documents.</em></p>
-
-<dl>
- <dt>{{domxref("Document.cookie")}}</dt>
- <dd>Returns a semicolon-separated list of the cookies for that document or sets a single cookie.</dd>
- <dt>{{domxref("Document.defaultView")}} {{readonlyinline}}</dt>
- <dd>Returns a reference to the window object.</dd>
- <dt>{{domxref("Document.designMode")}}</dt>
- <dd>Gets/sets the ability to edit the whole document.</dd>
- <dt>{{domxref("Document.dir")}} {{readonlyinline}}</dt>
- <dd>Gets/sets directionality (rtl/ltr) of the document.</dd>
- <dt>{{domxref("Document.domain")}}</dt>
- <dd>Gets/sets the domain of the current document.</dd>
- <dt>{{domxref("Document.lastModified")}} {{readonlyinline}}</dt>
- <dd>Returns the date on which the document was last modified.</dd>
- <dt>{{domxref("Document.location")}} {{readonlyinline}}</dt>
- <dd>Returns the URI of the current document.</dd>
- <dt>{{domxref("Document.readyState")}} {{readonlyinline}} {{gecko_minversion_inline("1.9.2")}}</dt>
- <dd>Returns loading status of the document.</dd>
- <dt>{{domxref("Document.referrer")}} {{readonlyinline}}</dt>
- <dd>Returns the URI of the page that linked to this page.</dd>
- <dt>{{domxref("Document.title")}}</dt>
- <dd>Sets or gets the title of the current document.</dd>
- <dt>{{domxref("Document.URL")}} {{readonlyInline}}</dt>
- <dd>Returns the document location as a string.</dd>
-</dl>
-
-<h3 id="Properties_included_from_DocumentOrShadowRoot">Properties included from DocumentOrShadowRoot</h3>
-
-<p><em>The <code>Document</code> interface includes the following properties defined on the {{domxref("DocumentOrShadowRoot")}} mixin. Note that this is currently only implemented by Chrome; other browsers still implement them directly on the {{domxref("Document")}} interface.</em></p>
-
-<dl>
- <dt>{{domxref("DocumentOrShadowRoot.activeElement")}} {{readonlyInline}}</dt>
- <dd>Returns the {{domxref('Element')}} within the shadow tree that has focus.</dd>
- <dt>{{domxref("Document.fullscreenElement")}} {{readonlyinline}}</dt>
- <dd>The element that's currently in full screen mode for this document.</dd>
- <dt>{{domxref("DocumentOrShadowRoot.pointerLockElement")}} {{readonlyinline}} {{experimental_inline}}</dt>
- <dd>Returns the element set as the target for mouse events while the pointer is locked. <code>null</code> if lock is pending, pointer is unlocked, or if the target is in another document.</dd>
- <dt>{{domxref("DocumentOrShadowRoot.styleSheets")}} {{readonlyInline}}</dt>
- <dd>Returns a {{domxref('StyleSheetList')}} of {{domxref('CSSStyleSheet')}} objects for stylesheets explicitly linked into, or embedded in a document.</dd>
-</dl>
-
-<h3 id="Event_handlers" name="Event_handlers">Event handlers</h3>
-
-<dl>
- <dt>{{domxref("Document.onafterscriptexecute")}} {{non-standard_inline}}</dt>
- <dd>Represents the event handling code for the {{event("afterscriptexecute")}} event.</dd>
- <dt>{{domxref("Document.onbeforescriptexecute")}} {{non-standard_inline}}</dt>
- <dd>Represents the event handling code for the {{event("beforescriptexecute")}} event.</dd>
- <dt>{{domxref("Document.oncopy")}} {{non-standard_inline}}</dt>
- <dd>Represents the event handling code for the {{event("copy")}} event.</dd>
- <dt>{{domxref("Document.oncut")}} {{non-standard_inline}}</dt>
- <dd>Represents the event handling code for the {{event("cut")}} event.</dd>
- <dt>{{domxref("Document.onfullscreenchange")}}</dt>
- <dd>Is an {{domxref("EventHandler")}} representing the code to be called when the {{event("fullscreenchange")}} event is raised.</dd>
- <dt>{{domxref("Document.onfullscreenerror")}}</dt>
- <dd>Is an {{domxref("EventHandler")}} representing the code to be called when the {{event("fullscreenerror")}} event is raised.</dd>
- <dt>{{domxref("Document.onpaste")}} {{non-standard_inline}}</dt>
- <dd>Represents the event handling code for the {{event("paste")}} event.</dd>
- <dt>{{domxref("Document.onpointerlockchange")}} {{experimental_inline}}</dt>
- <dd>Represents the event handling code for the {{event("pointerlockchange")}} event.</dd>
- <dt>{{domxref("Document.onpointerlockerror")}} {{experimental_inline}}</dt>
- <dd>Represents the event handling code for the {{event("pointerlockerror")}} event.</dd>
- <dt>{{domxref("Document.onreadystatechange")}} {{gecko_minversion_inline("1.9.2")}}</dt>
- <dd>Represents the event handling code for the {{event("readystatechange")}} event.</dd>
- <dt>{{domxref("Document.onselectionchange")}} {{experimental_inline}}</dt>
- <dd>Is an {{domxref("EventHandler")}} representing the code to be called when the {{event("selectionchange")}} event is raised.</dd>
- <dt>{{domxref("Document.onvisibilitychange")}}</dt>
- <dd>Is an {{domxref("EventHandler")}} representing the code to be called when the {{event("visibilitychange")}} event is raised.</dd>
- <dt>{{domxref("Document.onwheel")}} {{non-standard_inline}}</dt>
- <dd>Represents the event handling code for the {{event("wheel")}} event.</dd>
-</dl>
-
-<p>The <code>Document</code> interface is extended with the {{domxref("GlobalEventHandlers")}} interface:</p>
-
-<p>{{Page("/en-US/docs/Web/API/GlobalEventHandlers", "Properties")}}</p>
-
-<h3 id="Deprecated_properties">Deprecated properties</h3>
-
-<dl>
- <dt>{{domxref("Document.alinkColor")}} {{Deprecated_inline}}</dt>
- <dd>Returns or sets the color of active links in the document body.</dd>
- <dt>{{domxref("Document.all")}} {{Deprecated_inline}} {{non-standard_inline}}</dt>
- <dd>Provides access to all elements in the document. This is a legacy, non-standard property and should not be used.</dd>
- <dt>{{domxref("Document.applets")}} {{Deprecated_inline}} {{readonlyinline}}</dt>
- <dd>Returns an ordered list of the applets within a document.</dd>
- <dt>{{domxref("Document.async")}} {{Deprecated_inline}}</dt>
- <dd>Used with {{domxref("Document.load")}} to indicate an asynchronous request.</dd>
- <dt>{{domxref("Document.bgColor")}} {{Deprecated_inline}}</dt>
- <dd>Gets/sets the background color of the current document.</dd>
- <dt>{{domxref("Document.charset")}} {{readonlyinline}} {{Deprecated_inline}}</dt>
- <dd>Alias of {{domxref("Document.characterSet")}}. Use this property instead.</dd>
- <dt>{{domxref("Document.domConfig")}} {{Deprecated_inline}}</dt>
- <dd>Should return a {{domxref("DOMConfiguration")}} object.</dd>
- <dt>{{domxref("document.fgColor")}} {{Deprecated_inline}}</dt>
- <dd>Gets/sets the foreground color, or text color, of the current document.</dd>
- <dt>{{domxref("Document.fullscreen")}} {{obsolete_inline}}</dt>
- <dd><code>true</code> when the document is in {{domxref("Using_full-screen_mode","full-screen mode")}}.</dd>
- <dt>{{domxref("Document.height")}} {{non-standard_inline}} {{obsolete_inline}}</dt>
- <dd>Gets/sets the height of the current document.</dd>
- <dt>{{domxref("Document.inputEncoding")}} {{readonlyinline}} {{Deprecated_inline}}</dt>
- <dd>Alias of {{domxref("Document.characterSet")}}. Use this property instead.</dd>
- <dt>{{domxref("Document.linkColor")}} {{Deprecated_inline}}</dt>
- <dd>Gets/sets the color of hyperlinks in the document.</dd>
- <dt>{{domxref("Document.vlinkColor")}} {{Deprecated_inline}}</dt>
- <dd>Gets/sets the color of visited hyperlinks.</dd>
- <dt>{{domxref("Document.width")}} {{non-standard_inline}} {{obsolete_inline}}</dt>
- <dd>Returns the width of the current document.</dd>
- <dt>{{domxref("Document.xmlEncoding")}} {{Deprecated_inline}}</dt>
- <dd>Returns the encoding as determined by the XML declaration.</dd>
- <dt>{{domxref("Document.xmlStandalone")}} {{obsolete_inline("10.0")}}</dt>
- <dd>Returns <code>true</code> if the XML declaration specifies the document to be standalone (<em>e.g.,</em> An external part of the DTD affects the document's content), else <code>false</code>.</dd>
- <dt>{{domxref("Document.xmlVersion")}} {{obsolete_inline("10.0")}}</dt>
- <dd>Returns the version number as specified in the XML declaration or <code>"1.0"</code> if the declaration is absent.</dd>
-</dl>
-
-<h2 id="Methods" name="Methods">Methods</h2>
-
-<p><em>This interface also inherits from the {{domxref("Node")}} and {{domxref("EventTarget")}} interfaces.</em></p>
-
-<dl>
- <dt>{{domxref("Document.adoptNode()")}}</dt>
- <dd>Adopt node from an external document.</dd>
- <dt>{{domxref("Document.captureEvents()")}} {{Deprecated_inline}}</dt>
- <dd>See {{domxref("Window.captureEvents")}}.</dd>
- <dt>{{domxref("Document.caretRangeFromPoint()")}}{{non-standard_inline}}</dt>
- <dd>Gets a {{Domxref("Range")}} object for the document fragment under the specified coordinates.</dd>
- <dt>{{domxref("Document.createAttribute()")}}</dt>
- <dd>Creates a new {{domxref("Attr")}} object and returns it.</dd>
- <dt>{{domxref("Document.createAttributeNS()")}}</dt>
- <dd>Creates a new attribute node in a given namespace and returns it.</dd>
- <dt>{{domxref("Document.createCDATASection()")}}</dt>
- <dd>Creates a new CDATA node and returns it.</dd>
- <dt>{{domxref("Document.createComment()")}}</dt>
- <dd>Creates a new comment node and returns it.</dd>
- <dt>{{domxref("Document.createDocumentFragment()")}}</dt>
- <dd>Creates a new document fragment.</dd>
- <dt>{{domxref("Document.createElement()")}}</dt>
- <dd>Creates a new element with the given tag name.</dd>
- <dt>{{domxref("Document.createElementNS()")}}</dt>
- <dd>Creates a new element with the given tag name and namespace URI.</dd>
- <dt>{{domxref("Document.createEntityReference()")}} {{obsolete_inline}}</dt>
- <dd>Creates a new entity reference object and returns it.</dd>
- <dt>{{domxref("Document.createEvent()")}}</dt>
- <dd>Creates an event object.</dd>
- <dt>{{domxref("Document.createNodeIterator()")}}</dt>
- <dd>Creates a {{domxref("NodeIterator")}} object.</dd>
- <dt>{{domxref("Document.createProcessingInstruction()")}}</dt>
- <dd>Creates a new {{domxref("ProcessingInstruction")}} object.</dd>
- <dt>{{domxref("Document.createRange()")}}</dt>
- <dd>Creates a {{domxref("Range")}} object.</dd>
- <dt>{{domxref("Document.createTextNode()")}}</dt>
- <dd>Creates a text node.</dd>
- <dt>{{domxref("Document.createTouch()")}} {{Deprecated_inline}}</dt>
- <dd>Creates a {{domxref("Touch")}} object.</dd>
- <dt>{{domxref("Document.createTouchList()")}}</dt>
- <dd>Creates a {{domxref("TouchList")}} object.</dd>
- <dt>{{domxref("Document.createTreeWalker()")}}</dt>
- <dd>Creates a {{domxref("TreeWalker")}} object.</dd>
- <dt>{{domxref("Document.enableStyleSheetsForSet()")}}</dt>
- <dd>Enables the style sheets for the specified style sheet set.</dd>
- <dt>{{domxref("Document.exitPointerLock()")}} {{experimental_inline}}</dt>
- <dd>Release the pointer lock.</dd>
- <dt>{{domxref("Document.getAnimations()")}} {{experimental_inline}}</dt>
- <dd>Returns an array of all {{domxref("Animation")}} objects currently in effect, whose target elements are descendants of the <code>document</code>.</dd>
- <dt>{{domxref("Document.getElementsByClassName()")}}</dt>
- <dd>Returns a list of elements with the given class name.</dd>
- <dt>{{domxref("Document.getElementsByTagName()")}}</dt>
- <dd>Returns a list of elements with the given tag name.</dd>
- <dt>{{domxref("Document.getElementsByTagNameNS()")}}</dt>
- <dd>Returns a list of elements with the given tag name and namespace.</dd>
- <dt>{{domxref("Document.importNode()")}}</dt>
- <dd>Returns a clone of a node from an external document.</dd>
- <dt>{{domxref("Document.normalizeDocument()")}} {{obsolete_inline}}</dt>
- <dd>Replaces entities, normalizes text nodes, etc.</dd>
- <dt>{{domxref("Document.releaseCapture()")}} {{non-standard_inline}} {{gecko_minversion_inline("2.0")}}</dt>
- <dd>Releases the current mouse capture if it's on an element in this document.</dd>
- <dt>{{domxref("Document.releaseEvents()")}} {{non-standard_inline}} {{Deprecated_inline}}</dt>
- <dd>See {{domxref("Window.releaseEvents()")}}.</dd>
- <dt>{{domxref("Document.routeEvent()")}} {{non-standard_inline}} {{obsolete_inline(24)}}</dt>
- <dd>See {{domxref("Window.routeEvent()")}}.</dd>
- <dt>{{domxref("Document.mozSetImageElement()")}} {{non-standard_inline}} {{gecko_minversion_inline("2.0")}}</dt>
- <dd>Allows you to change the element being used as the background image for a specified element ID.</dd>
-</dl>
-
-<p>The <code>Document</code> interface is extended with the {{domxref("ParentNode")}} interface:</p>
-
-<dl>
- <dt>{{domxref("document.getElementById","document.getElementById(String id)")}}</dt>
- <dd>Returns an object reference to the identified element.</dd>
- <dt>{{domxref("document.querySelector","document.querySelector(String selector)")}} {{gecko_minversion_inline("1.9.1")}}</dt>
- <dd>Returns the first Element node within the document, in document order, that matches the specified selectors.</dd>
- <dt>{{domxref("document.querySelectorAll","document.querySelectorAll(String selector)")}} {{gecko_minversion_inline("1.9.1")}}</dt>
- <dd>Returns a list of all the Element nodes within the document that match the specified selectors.</dd>
-</dl>
-
-<p>The <code>Document</code> interface is extended with the {{domxref("XPathEvaluator")}} interface:</p>
-
-<dl>
- <dt>{{domxref("document.createExpression","document.createExpression(String expression, XPathNSResolver resolver)")}}</dt>
- <dd>Compiles an <code><a href="/en-US/docs/XPathExpression" title="XPathExpression">XPathExpression</a></code> which can then be used for (repeated) evaluations.</dd>
- <dt>{{domxref("document.createNSResolver","document.createNSResolver(Node resolver)")}}</dt>
- <dd>Creates an {{domxref("XPathNSResolver")}} object.</dd>
- <dt>{{domxref("document.evaluate","document.evaluate(String expression, Node contextNode, XPathNSResolver resolver, Number type, Object result)")}}</dt>
- <dd>Evaluates an XPath expression.</dd>
-</dl>
-
-<h3 id="Extension_for_HTML_documents">Extension for HTML documents</h3>
-
-<p>The <code>Document</code> interface for HTML documents inherit from the {{domxref("HTMLDocument")}} interface or, since HTML5,  is extended for such documents:</p>
-
-<dl>
- <dt>{{domxref("document.clear()")}} {{non-standard_inline}} {{Deprecated_inline}}</dt>
- <dd>In majority of modern browsers, including recent versions of Firefox and Internet Explorer, this method does nothing.</dd>
- <dt>{{domxref("document.close()")}}</dt>
- <dd>Closes a document stream for writing.</dd>
- <dt>{{domxref("document.execCommand","document.execCommand(String command[, Boolean showUI[, String value]])")}}</dt>
- <dd>On an editable document, executes a formating command.</dd>
- <dt>{{domxref("document.getElementsByName","document.getElementsByName(String name)")}}</dt>
- <dd>Returns a list of elements with the given name.</dd>
- <dt>{{domxref("document.hasFocus()")}}</dt>
- <dd>Returns <code>true</code> if the focus is currently located anywhere inside the specified document.</dd>
- <dt>{{domxref("document.open()")}}</dt>
- <dd>Opens a document stream for writing.</dd>
- <dt>{{domxref("document.queryCommandEnabled","document.queryCommandEnabled(String command)")}}</dt>
- <dd>Returns true if the formating command can be executed on the current range.</dd>
- <dt>{{domxref("document.queryCommandIndeterm","document.queryCommandIndeterm(String command)")}}</dt>
- <dd>Returns true if the formating command is in an indeterminate state on the current range.</dd>
- <dt>{{domxref("document.queryCommandState","document.queryCommandState(String command)")}}</dt>
- <dd>Returns true if the formating command has been executed on the current range.</dd>
- <dt>{{domxref("document.queryCommandSupported","document.queryCommandSupported(String command)")}}</dt>
- <dd>Returns true if the formating command is supported on the current range.</dd>
- <dt>{{domxref("document.queryCommandValue","document.queryCommandValue(String command)")}}</dt>
- <dd>Returns the current value of the current range for a formating command.</dd>
- <dt>{{domxref("document.write","document.write(String text)")}}</dt>
- <dd>Writes text in a document.</dd>
- <dt>{{domxref("document.writeln","document.writeln(String text)")}}</dt>
- <dd>Writes a line of text in a document.</dd>
-</dl>
-
-<h3 id="Methods_included_from_DocumentOrShadowRoot">Methods included from DocumentOrShadowRoot</h3>
-
-<p><em>The <code>Document</code> interface includes the following methods defined on the {{domxref("DocumentOrShadowRoot")}} mixin. Note that this is currently only implemented by Chrome; other browsers still implement them on the {{domxref("Document")}} interface.</em></p>
-
-<dl>
- <dt>{{domxref("DocumentOrShadowRoot.getSelection()")}}</dt>
- <dd>Returns a {{domxref('Selection')}} object representing the range of text selected by the user, or the current position of the caret.</dd>
- <dt>{{domxref("DocumentOrShadowRoot.elementFromPoint()")}}</dt>
- <dd>Returns the topmost element at the specified coordinates.</dd>
- <dt>{{domxref("DocumentOrShadowRoot.elementsFromPoint()")}}</dt>
- <dd>Returns an array of all elements at the specified coordinates.</dd>
- <dt>{{domxref("DocumentOrShadowRoot.caretPositionFromPoint()")}}</dt>
- <dd>Returns a {{domxref('CaretPosition')}} object containing the DOM node containing the caret, and caret's character offset within that node.</dd>
-</dl>
-
-<h2 id="Non-standard_extensions_non-standard_inline">Non-standard extensions {{non-standard_inline}}</h2>
-
-<div>{{non-standard_header}}</div>
-
-<h3 id="Firefox_notes">Firefox notes</h3>
-
-<p>Mozilla defines a set of non-standard properties made only for XUL content:</p>
-
-<dl>
- <dt>{{domxref("document.currentScript")}} {{non-standard_inline}} {{gecko_minversion_inline("2.0")}}</dt>
- <dd>Returns the {{HTMLElement("script")}} element that is currently executing.</dd>
- <dt>{{domxref("document.documentURIObject")}} {{gecko_minversion_inline("1.9")}}</dt>
- <dd>(<strong>Mozilla add-ons only!</strong>) Returns the {{Interface("nsIURI")}} object representing the URI of the document. This property only has special meaning in privileged JavaScript code (with UniversalXPConnect privileges).</dd>
- <dt>{{domxref("document.popupNode")}}</dt>
- <dd>Returns the node upon which a popup was invoked.</dd>
- <dt>{{domxref("document.tooltipNode")}}</dt>
- <dd>Returns the node which is the target of the current tooltip.</dd>
-</dl>
-
-<p>Mozilla also define some non-standard methods:</p>
-
-<dl>
- <dt>{{domxref("document.execCommandShowHelp")}} {{obsolete_inline("14.0")}}</dt>
- <dd>This method never did anything and always threw an exception, so it was removed in Gecko 14.0 {{geckoRelease("14.0")}}.</dd>
- <dt>{{domxref("document.getBoxObjectFor")}} {{obsolete_inline}}</dt>
- <dd>Use the {{domxref("Element.getBoundingClientRect()")}} method instead.</dd>
- <dt>{{domxref("document.loadOverlay")}}</dt>
- <dd>Loads a <a href="/en-US/docs/XUL_Overlays" title="XUL_Overlays">XUL overlay</a> dynamically. This only works in XUL documents.</dd>
- <dt>{{domxref("document.queryCommandText")}} {{obsolete_inline("14.0")}}</dt>
- <dd>This method never did anything but throw an exception, and was removed in Gecko 14.0 {{geckoRelease("14.0")}}.</dd>
-</dl>
-
-<h3 id="Internet_Explorer_notes">Internet Explorer notes</h3>
-
-<p>Microsoft defines some non-standard properties:</p>
-
-<dl>
- <dt>{{domxref("document.fileSize")}}* {{non-standard_inline}} {{obsolete_inline}}</dt>
- <dd>Returns size in bytes of the document. Starting with Internet Explorer 11, that property is no longer supported. See <a href="http://msdn.microsoft.com/en-us/library/ms533752%28v=VS.85%29.aspx" title="http://msdn.microsoft.com/en-us/library/ms533752%28v=VS.85%29.aspx">MSDN</a>.</dd>
-</dl>
-
-<p>Internet Explorer does not support all methods from the <code>Node</code> interface in the <code>Document</code> interface:</p>
-
-<dl>
- <dt>{{domxref("document.contains")}}</dt>
- <dd>As a work-around, <code>document.body.contains()</code> can be used.</dd>
-</dl>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>{{SpecName("DOM WHATWG", "#interface-document", "Document")}}</td>
- <td>{{Spec2("DOM WHATWG")}}</td>
- <td>Intend to supersede DOM 3</td>
- </tr>
- <tr>
- <td>{{SpecName("HTML WHATWG", "dom.html#the-document-object", "Document")}}</td>
- <td>{{Spec2("HTML WHATWG")}}</td>
- <td>Turn the {{domxref("HTMLDocument")}} interface into a <code>Document</code> extension.</td>
- </tr>
- <tr>
- <td>{{SpecName("HTML Editing", "#dom-document-getselection", "Document")}}</td>
- <td>{{Spec2("HTML Editing")}}</td>
- <td>Extend the <code>Document</code> interface</td>
- </tr>
- <tr>
- <td>{{SpecName("CSSOM View", "#extensions-to-the-document-interface", "Document")}}</td>
- <td>{{Spec2("CSSOM View")}}</td>
- <td>Extend the <code>Document</code> interface</td>
- </tr>
- <tr>
- <td>{{SpecName("CSSOM", "#extensions-to-the-document-interface", "Document")}}</td>
- <td>{{Spec2("CSSOM")}}</td>
- <td>Extend the <code>Document</code> interface</td>
- </tr>
- <tr>
- <td>{{SpecName("Pointer Lock", "#extensions-to-the-document-interface", "Document")}}</td>
- <td>{{Spec2("Pointer Lock")}}</td>
- <td>Extend the <code>Document</code> interface</td>
- </tr>
- <tr>
- <td>{{SpecName("Page Visibility API", "#extensions-to-the-document-interface", "Document")}}</td>
- <td>{{Spec2("Page Visibility API")}}</td>
- <td>Extend the <code>Document</code> interface with the <code>visibilityState</code> and <code>hidden</code> attributes and the <code>onvisibilitychange</code> event listener.</td>
- </tr>
- <tr>
- <td>{{SpecName("Selection API", "#extensions-to-document-interface", "Document")}}</td>
- <td>{{Spec2("Selection API")}}</td>
- <td>Adds <code>getSelection()</code>, <code>onselectstart</code> and <code>onselectionchange</code>.</td>
- </tr>
- <tr>
- <td>{{SpecName("DOM4", "#interface-document", "Document")}}</td>
- <td>{{Spec2("DOM4")}}</td>
- <td>Supersede DOM 3</td>
- </tr>
- <tr>
- <td>{{SpecName("DOM3 Core", "#i-Document", "Document")}}</td>
- <td>{{Spec2("DOM3 Core")}}</td>
- <td>Supersede DOM 2</td>
- </tr>
- <tr>
- <td>{{SpecName("DOM3 XPath", "xpath.html#XPathEvaluator", "XPathEvaluator")}}</td>
- <td>{{Spec2("DOM3 XPath")}}</td>
- <td>Define the {{domxref("XPathEvaluator")}} interface which extend document.</td>
- </tr>
- <tr>
- <td>{{SpecName("DOM2 Core", "#i-Document", "Document")}}</td>
- <td>{{Spec2("DOM2 Core")}}</td>
- <td>Supersede DOM 1</td>
- </tr>
- <tr>
- <td>{{SpecName("DOM1", "#i-Document", "Document")}}</td>
- <td>{{Spec2("DOM1")}}</td>
- <td>Initial definition for the interface</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-
-
-<p>{{Compat("api.Document")}}</p>
-
-<div>{{APIRef}}</div>
diff --git a/files/he/web/api/document/write/index.html b/files/he/web/api/document/write/index.html
deleted file mode 100644
index 8c497d548c..0000000000
--- a/files/he/web/api/document/write/index.html
+++ /dev/null
@@ -1,82 +0,0 @@
----
-title: 'Document.write():'
-slug: Web/API/Document/write
-translation_of: Web/API/Document/write
----
-<div>{{ ApiRef("DOM") }}</div>
-
-<p><strong><code>()Document.write</code></strong> - כותב מחרוזת טקסט אל גוף מסמך HTML.</p>
-
-<h2 id="תחביר">תחביר</h2>
-
-<pre class="brush: js">document.write(<em>markup</em>);
-</pre>
-
-<h3 id="פרמטרים">פרמטרים</h3>
-
-<dl>
- <dt><code>markup</code></dt>
- <dd>מחרוזת המכילה את הטקסט שיופיע במסמך.</dd>
-</dl>
-
-<h3 id="דוגמה">דוגמה</h3>
-
-<pre class="brush: html">&lt;html&gt;
-
-&lt;head&gt;
- &lt;title&gt;write example&lt;/title&gt;
-
- &lt;script&gt;
- function newContent() {
- alert("load new content");
- document.open();
- document.write("&lt;h1&gt;Out with the old - in with the new!&lt;/h1&gt;");
- document.close();
- }
- &lt;/script&gt;
-&lt;/head&gt;
-
-&lt;body onload="newContent();"&gt;
- &lt;p&gt;Some original document content.&lt;/p&gt;
-&lt;/body&gt;
-
-&lt;/html&gt;
-
-</pre>
-
-<h2 id="מפרט">מפרט</h2>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>{{SpecName("HTML WHATWG", "#dom-document-write", "document.write(...)")}}</td>
- <td>{{Spec2("HTML WHATWG")}}</td>
- <td> </td>
- </tr>
- <tr>
- <td>{{SpecName("DOM2 HTML", "html.html#ID-75233634", "document.write(...)")}}</td>
- <td>{{Spec2("DOM2 HTML")}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תאימות_דפדפן">תאימות דפדפן</h2>
-
-
-
-<p>{{Compat("api.Document.write")}}</p>
-
-<h2 id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{ domxref("element.innerHTML") }}</li>
- <li>{{ domxref("document.createElement()") }}</li>
-</ul>
diff --git a/files/he/web/api/document_object_model/index.html b/files/he/web/api/document_object_model/index.html
deleted file mode 100644
index 80e3102138..0000000000
--- a/files/he/web/api/document_object_model/index.html
+++ /dev/null
@@ -1,14 +0,0 @@
----
-title: DOM
-slug: Web/API/Document_Object_Model
-original_slug: DOM
----
-<div>
-<p> </p>
-<div>
-<p><strong>Document Object Model</strong> הינו API עבור מסמכי <a href="/he/HTML" title="HTML">HTML</a> ו-<a href="/he/XML" title="XML">XML</a>. הוא מספק ייצוג מבני של המסמך המאפשר הן את שינוי תוכן המסמך ואת מראהו. עיקר תפקידו של ממשק זה, לאפשר לנו לחבר בין דפי אינטרנט לבין שפות תכנות.</p>
-<h3 id="תיעוד">תיעוד</h3>
-<dl> <dt><a href="/he/Gecko_DOM_Reference" title="he/Gecko_DOM_Reference">Gecko DOM</a></dt> <dd><small>The Gecko Document Object Model Reference.</small></dd>
-</dl>
-</div>
-</div>
diff --git a/files/he/web/api/domstring/index.html b/files/he/web/api/domstring/index.html
deleted file mode 100644
index 210e3c86c0..0000000000
--- a/files/he/web/api/domstring/index.html
+++ /dev/null
@@ -1,50 +0,0 @@
----
-title: DOMString
-slug: Web/API/DOMString
-translation_of: Web/API/DOMString
----
-<p>{{APIRef("DOM")}}<br>
- מחרוזת <strong><code>DOMString</code></strong> הינה מחרוזות מסוג UTF-16.<br>
- כל מחרוזת בשפת JavaScript נחשבת למחרוזת UTF-16 ולכן, נחשבת ל-<code><strong>DOMString</strong></code> באופן אוטומטי.</p>
-
-<h2 id="Specification" name="Specification">מפרט</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('WebIDL', '#idl-DOMString', 'DOMString')}}</td>
- <td>{{Spec2('WebIDL')}}</td>
- <td>Rephrasing of the definition to remove weird edge cases.</td>
- </tr>
- <tr>
- <td>{{SpecName('DOM3 Core', 'core.html#DOMString', 'DOMString')}}</td>
- <td>{{Spec2('DOM3 Core')}}</td>
- <td>No change from {{SpecName('DOM2 Core')}}</td>
- </tr>
- <tr>
- <td>{{SpecName('DOM2 Core', 'core.html#ID-C74D1578', 'DOMString')}}</td>
- <td>{{Spec2('DOM2 Core')}}</td>
- <td>No change from {{SpecName('DOM1')}}</td>
- </tr>
- <tr>
- <td>{{SpecName('DOM1', 'level-one-core.html#ID-C74D1578', 'DOMString')}}</td>
- <td>{{Spec2('DOM1')}}</td>
- <td>Initial definition.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="ראו_גם">ראו גם </h2>
-
-<ul>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/String" title="/en-US/docs/Web/API/DOMString">String</a></li>
- <li>{{domxref("USVString")}}</li>
- <li>{{domxref("CSSOMString")}}</li>
- <li><a href="/en-US/docs/Web/JavaScript/Typed_arrays/String_view" title="/en-US/docs/Web/JavaScript/Typed_arrays/String_view"><code>StringView</code> – a C-like representation of strings based on typed arrays</a></li>
- <li><a href="https://developer.mozilla.org/en-US/docs/Web/API/DOMString/Binary">Binary strings</a></li>
-</ul>
diff --git a/files/he/web/api/element/index.html b/files/he/web/api/element/index.html
deleted file mode 100644
index a0d4f8ee21..0000000000
--- a/files/he/web/api/element/index.html
+++ /dev/null
@@ -1,331 +0,0 @@
----
-title: Element
-slug: Web/API/Element
-tags:
- - API
- - DOM
- - DOM Reference
- - Element
- - Interface
- - NeedsTranslation
- - Reference
- - TopicStub
- - Web API
-translation_of: Web/API/Element
----
-<div>{{APIRef("DOM")}}</div>
-
-<p><span class="seoSummary"><strong><code>Element</code></strong> is the most general base class from which all objects in a {{DOMxRef("Document")}} inherit. It only has methods and properties common to all kinds of elements. More specific classes inherit from <code>Element</code>.</span> For example, the {{DOMxRef("HTMLElement")}} interface is the base interface for HTML elements, while the {{DOMxRef("SVGElement")}} interface is the basis for all SVG elements. Most functionality is specified further down the class hierarchy.</p>
-
-<p>Languages outside the realm of the Web platform, like XUL through the <code>XULElement</code> interface, also implement <code>Element</code>.</p>
-
-<p>{{InheritanceDiagram}}</p>
-
-<h2 id="Properties" name="Properties">Properties</h2>
-
-<p><em>Inherits properties from its parent interface, {{DOMxRef("Node")}}, and by extension that interface's parent, {{DOMxRef("EventTarget")}}. It implements the properties of {{DOMxRef("ParentNode")}}, {{DOMxRef("ChildNode")}}, {{DOMxRef("NonDocumentTypeChildNode")}}, </em>and {{DOMxRef("Animatable")}}.</p>
-
-<dl>
- <dt>{{DOMxRef("Element.attributes")}} {{readOnlyInline}}</dt>
- <dd>Returns a {{DOMxRef("NamedNodeMap")}} object containing the assigned attributes of the corresponding HTML element.</dd>
- <dt>{{DOMxRef("Element.classList")}} {{readOnlyInline}}</dt>
- <dd>Returns a {{DOMxRef("DOMTokenList")}} containing the list of class attributes.</dd>
- <dt>{{DOMxRef("Element.className")}}</dt>
- <dd>Is a {{DOMxRef("DOMString")}} representing the class of the element.</dd>
- <dt>{{DOMxRef("Element.clientHeight")}} {{readOnlyInline}}</dt>
- <dd>Returns a {{jsxref("Number")}} representing the inner height of the element.</dd>
- <dt>{{DOMxRef("Element.clientLeft")}} {{readOnlyInline}}</dt>
- <dd>Returns a {{jsxref("Number")}} representing the width of the left border of the element.</dd>
- <dt>{{DOMxRef("Element.clientTop")}}  {{readOnlyInline}}</dt>
- <dd>Returns a {{jsxref("Number")}} representing the width of the top border of the element.</dd>
- <dt>{{DOMxRef("Element.clientWidth")}} {{readOnlyInline}}</dt>
- <dd>Returns a {{jsxref("Number")}} representing the inner width of the element.</dd>
- <dt>{{DOMxRef("Element.computedName")}} {{readOnlyInline}}</dt>
- <dd>Returns a {{DOMxRef("DOMString")}} containing the label exposed to accessibility.</dd>
- <dt>{{DOMxRef("Element.computedRole")}} {{readOnlyInline}}</dt>
- <dd>Returns a {{DOMxRef("DOMString")}} containing the ARIA role that has been applied to a particular element. </dd>
- <dt>{{DOMxRef("Element.id")}}</dt>
- <dd>Is a {{DOMxRef("DOMString")}} representing the id of the element.</dd>
- <dt>{{DOMxRef("Element.innerHTML")}}</dt>
- <dd>Is a {{DOMxRef("DOMString")}} representing the markup of the element's content.</dd>
- <dt>{{DOMxRef("Element.localName")}} {{readOnlyInline}}</dt>
- <dd>A {{DOMxRef("DOMString")}} representing the local part of the qualified name of the element.</dd>
- <dt>{{DOMxRef("Element.namespaceURI")}} {{readonlyInline}}</dt>
- <dd>The namespace URI of the element, or <code>null</code> if it is no namespace.
- <div class="note">
- <p><strong>Note:</strong> In Firefox 3.5 and earlier, HTML elements are in no namespace. In later versions, HTML elements are in the <code><a class="linkification-ext external" href="http://www.w3.org/1999/xhtml" title="Linkification: http://www.w3.org/1999/xhtml">http://www.w3.org/1999/xhtml</a></code> namespace in both HTML and XML trees. {{ gecko_minversion_inline("1.9.2")}}</p>
- </div>
- </dd>
- <dt>{{DOMxRef("NonDocumentTypeChildNode.nextElementSibling")}} {{readOnlyInline}}</dt>
- <dd>Is an {{DOMxRef("Element")}}, the element immediately following the given one in the tree, or <code>null</code> if there's no sibling node.</dd>
- <dt>{{DOMxRef("Element.outerHTML")}}</dt>
- <dd>Is a {{DOMxRef("DOMString")}} representing the markup of the element including its content. When used as a setter, replaces the element with nodes parsed from the given string.</dd>
- <dt>{{DOMxRef("Element.prefix")}} {{readOnlyInline}}</dt>
- <dd>A {{DOMxRef("DOMString")}} representing the namespace prefix of the element, or <code>null</code> if no prefix is specified.</dd>
- <dt>{{DOMxRef("NonDocumentTypeChildNode.previousElementSibling")}} {{readOnlyInline}}</dt>
- <dd>Is a {{DOMxRef("Element")}}, the element immediately preceding the given one in the tree, or <code>null</code> if there is no sibling element.</dd>
- <dt>{{DOMxRef("Element.scrollHeight")}}  {{readOnlyInline}}</dt>
- <dd>Returns a {{jsxref("Number")}} representing the scroll view height of an element.</dd>
- <dt>{{DOMxRef("Element.scrollLeft")}}</dt>
- <dd>Is a {{jsxref("Number")}} representing the left scroll offset of the element.</dd>
- <dt>{{DOMxRef("Element.scrollLeftMax")}} {{Non-standard_Inline}} {{readOnlyInline}}</dt>
- <dd>Returns a {{jsxref("Number")}} representing the maximum left scroll offset possible for the element.</dd>
- <dt>{{DOMxRef("Element.scrollTop")}}</dt>
- <dd>A {{jsxref("Number")}} representing number of pixels the top of the document is scrolled vertically.</dd>
- <dt>{{DOMxRef("Element.scrollTopMax")}} {{Non-standard_Inline}} {{readOnlyInline}}</dt>
- <dd>Returns a {{jsxref("Number")}} representing the maximum top scroll offset possible for the element.</dd>
- <dt>{{DOMxRef("Element.scrollWidth")}} {{readOnlyInline}}</dt>
- <dd>Returns a {{jsxref("Number")}} representing the scroll view width of the element.</dd>
- <dt>{{DOMxRef("Element.shadowRoot")}}{{readOnlyInline}}</dt>
- <dd>Returns the open shadow root that is hosted by the element, or null if no open shadow root is present.</dd>
- <dt>{{DOMxRef("Element.openOrClosedShadowRoot")}} {{Non-standard_Inline}}{{readOnlyInline}}</dt>
- <dd>Returns the shadow root that is hosted by the element, regardless if its open or closed. <strong>Available only to <a href="/en-US/docs/Mozilla/Add-ons/WebExtensions">WebExtensions</a>.</strong></dd>
- <dt>{{DOMxRef("Element.slot")}} {{Experimental_Inline}}</dt>
- <dd>Returns the name of the shadow DOM slot the element is inserted in.</dd>
- <dt>{{DOMxRef("Element.tabStop")}} {{Non-standard_Inline}}</dt>
- <dd>Is a {{jsxref("Boolean")}} indicating if the element can receive input focus via the tab key.</dd>
- <dt>{{DOMxRef("Element.tagName")}} {{readOnlyInline}}</dt>
- <dd>Returns a {{jsxref("String")}} with the name of the tag for the given element.</dd>
- <dt>{{DOMxRef("Element.undoManager")}} {{Experimental_Inline}} {{readOnlyInline}}</dt>
- <dd>Returns the {{DOMxRef("UndoManager")}} associated with the element.</dd>
- <dt>{{DOMxRef("Element.undoScope")}} {{Experimental_Inline}}</dt>
- <dd>Is a {{jsxref("Boolean")}} indicating if the element is an undo scope host, or not.</dd>
-</dl>
-
-<div class="note">
-<p><strong>Note:</strong> DOM Level 3 defined <code>namespaceURI</code>, <code>localName</code> and <code>prefix</code> on the {{DOMxRef("Node")}} interface. In DOM4 they were moved to <code>Element</code>.</p>
-
-<p>This change is implemented in Chrome since version 46.0 and Firefox since version 48.0.</p>
-</div>
-
-<h3 id="Properties_included_from_Slotable">Properties included from Slotable</h3>
-
-<p><em>The <code>Element</code> interface includes the following property, defined on the {{DOMxRef("Slotable")}} mixin.</em></p>
-
-<dl>
- <dt>{{DOMxRef("Slotable.assignedSlot")}}{{readonlyInline}}</dt>
- <dd>Returns a {{DOMxRef("HTMLSlotElement")}} representing the {{htmlelement("slot")}} the node is inserted in.</dd>
-</dl>
-
-<h3 id="Handlers" name="Handlers">Event handlers</h3>
-
-<dl>
- <dt>{{domxref("Element.onfullscreenchange")}}</dt>
- <dd>An event handler for the {{event("fullscreenchange")}} event, which is sent when the element enters or exits full-screen mode. This can be used to watch both for successful expected transitions, but also to watch for unexpected changes, such as when your app is backgrounded.</dd>
- <dt>{{domxref("Element.onfullscreenerror")}}</dt>
- <dd>An event handler for the {{event("fullscreenerror")}} event, which is sent when an error occurs while attempting to change into full-screen mode.</dd>
-</dl>
-
-<h4 id="Obsolete_event_handlers">Obsolete event handlers</h4>
-
-<dl>
- <dt>{{DOMxRef("Element.onwheel")}}</dt>
- <dd>Returns the event handling code for the {{Event("wheel")}} event. <strong>This is now implemented on {{DOMxRef("GlobalEventHandlers.onwheel", "GlobalEventHandlers")}}.</strong></dd>
-</dl>
-
-<h2 id="Methods" name="Methods">Methods</h2>
-
-<p><em>Inherits methods from its parents {{DOMxRef("Node")}}, and its own parent, {{DOMxRef("EventTarget")}}<em>, and implements those of {{DOMxRef("ParentNode")}}, {{DOMxRef("ChildNode")}}<em>, {{DOMxRef("NonDocumentTypeChildNode")}}, </em></em>and {{DOMxRef("Animatable")}}.</em></p>
-
-<dl>
- <dt>{{DOMxRef("EventTarget.addEventListener()")}}</dt>
- <dd>Registers an event handler to a specific event type on the element.</dd>
- <dt>{{DOMxRef("Element.attachShadow()")}}</dt>
- <dd>Attatches a shadow DOM tree to the specified element and returns a reference to its {{DOMxRef("ShadowRoot")}}.</dd>
- <dt>{{DOMxRef("Element.animate()")}} {{Experimental_Inline}}</dt>
- <dd>A shortcut method to create and run an animation on an element. Returns the created Animation object instance.</dd>
- <dt>{{DOMxRef("Element.closest()")}} {{Experimental_Inline}}</dt>
- <dd>Returns the {{DOMxRef("Element")}} which is the closest ancestor of the current element (or the current element itself) which matches the selectors given in parameter.</dd>
- <dt>{{DOMxRef("Element.createShadowRoot()")}} {{Non-standard_Inline}} {{Deprecated_Inline}}</dt>
- <dd>Creates a <a href="/en-US/docs/Web/Web_Components/Shadow_DOM">shadow DOM</a> on on the element, turning it into a shadow host. Returns a {{DOMxRef("ShadowRoot")}}.</dd>
- <dt>{{DOMxRef("Element.computedStyleMap()")}} {{Experimental_Inline}}</dt>
- <dd>Returns a {{DOMxRef("StylePropertyMapReadOnly")}} interface which provides a read-only representation of a CSS declaration block that is an alternative to {{DOMxRef("CSSStyleDeclaration")}}.</dd>
- <dt>{{DOMxRef("EventTarget.dispatchEvent()")}}</dt>
- <dd>Dispatches an event to this node in the DOM and returns a {{jsxref("Boolean")}} that indicates whether no handler canceled the event.</dd>
- <dt>{{DOMxRef("Element.getAnimations()")}} {{Experimental_Inline}}</dt>
- <dd>Returns an array of Animation objects currently active on the element.</dd>
- <dt>{{DOMxRef("Element.getAttribute()")}}</dt>
- <dd>Retrieves the value of the named attribute from the current node and returns it as an {{jsxref("Object")}}.</dd>
- <dt>{{DOMxRef("Element.getAttributeNames()")}}</dt>
- <dd>Returns an array of attribute names from the current element.</dd>
- <dt>{{DOMxRef("Element.getAttributeNS()")}}</dt>
- <dd>Retrieves the value of the attribute with the specified name and namespace, from the current node and returns it as an {{jsxref("Object")}}.</dd>
- <dt>{{DOMxRef("Element.getAttributeNode()")}} {{Obsolete_Inline}}</dt>
- <dd>Retrieves the node representation of the named attribute from the current node and returns it as an {{DOMxRef("Attr")}}.</dd>
- <dt>{{DOMxRef("Element.getAttributeNodeNS()")}} {{Obsolete_Inline}}</dt>
- <dd>Retrieves the node representation of the attribute with the specified name and namespace, from the current node and returns it as an {{DOMxRef("Attr")}}.</dd>
- <dt>{{DOMxRef("Element.getBoundingClientRect()")}}</dt>
- <dd>Returns the size of an element and its position relative to the viewport.</dd>
- <dt>{{DOMxRef("Element.getClientRects()")}}</dt>
- <dd>Returns a collection of rectangles that indicate the bounding rectangles for each line of text in a client.</dd>
- <dt>{{DOMxRef("Element.getElementsByClassName()")}}</dt>
- <dd>Returns a live {{DOMxRef("HTMLCollection")}} that contains all descendants of the current element that possess the list of classes given in the parameter.</dd>
- <dt>{{DOMxRef("Element.getElementsByTagName()")}}</dt>
- <dd>Returns a live {{DOMxRef("HTMLCollection")}} containing all descendant elements, of a particular tag name, from the current element.</dd>
- <dt>{{DOMxRef("Element.getElementsByTagNameNS()")}}</dt>
- <dd>Returns a live {{DOMxRef("HTMLCollection")}} containing all descendant elements, of a particular tag name and namespace, from the current element.</dd>
- <dt>{{DOMxRef("Element.hasAttribute()")}}</dt>
- <dd>Returns a {{jsxref("Boolean")}} indicating if the element has the specified attribute or not.</dd>
- <dt>{{DOMxRef("Element.hasAttributeNS()")}}</dt>
- <dd>Returns a {{jsxref("Boolean")}} indicating if the element has the specified attribute, in the specified namespace, or not.</dd>
- <dt>{{DOMxRef("Element.hasAttributes()")}}</dt>
- <dd>Returns a {{jsxref("Boolean")}} indicating if the element has one or more HTML attributes present.</dd>
- <dt>{{DOMxRef("Element.hasPointerCapture()")}}</dt>
- <dd>Indicates whether the element on which it is invoked has pointer capture for the pointer identified by the given pointer ID.</dd>
- <dt>{{DOMxRef("Element.insertAdjacentElement()")}}</dt>
- <dd>Inserts a given element node at a given position relative to the element it is invoked upon.</dd>
- <dt>{{DOMxRef("Element.insertAdjacentHTML()")}}</dt>
- <dd>Parses the text as HTML or XML and inserts the resulting nodes into the tree in the position given.</dd>
- <dt>{{DOMxRef("Element.insertAdjacentText()")}}</dt>
- <dd>Inserts a given text node at a given position relative to the element it is invoked upon.</dd>
- <dt>{{DOMxRef("Element.matches()")}} {{Experimental_Inline}}</dt>
- <dd>Returns a {{jsxref("Boolean")}} indicating whether or not the element would be selected by the specified selector string.</dd>
- <dt>{{DOMxRef("Element.querySelector()")}}</dt>
- <dd>Returns the first {{DOMxRef("Node")}} which matches the specified selector string relative to the element.</dd>
- <dt>{{DOMxRef("Element.querySelectorAll()")}}</dt>
- <dd>Returns a {{DOMxRef("NodeList")}} of nodes which match the specified selector string relative to the element.</dd>
- <dt>{{DOMxRef("Element.releasePointerCapture()")}}</dt>
- <dd>Releases (stops) pointer capture that was previously set for a specific {{DOMxRef("PointerEvent","pointer event")}}.</dd>
- <dt>{{DOMxRef("ChildNode.remove()")}} {{Experimental_Inline}}</dt>
- <dd>Removes the element from the children list of its parent.</dd>
- <dt>{{DOMxRef("Element.removeAttribute()")}}</dt>
- <dd>Removes the named attribute from the current node.</dd>
- <dt>{{DOMxRef("Element.removeAttributeNS()")}}</dt>
- <dd>Removes the attribute with the specified name and namespace, from the current node.</dd>
- <dt>{{DOMxRef("Element.removeAttributeNode()")}} {{Obsolete_Inline}}</dt>
- <dd>Removes the node representation of the named attribute from the current node.</dd>
- <dt>{{DOMxRef("EventTarget.removeEventListener()")}}</dt>
- <dd>Removes an event listener from the element.</dd>
- <dt>{{DOMxRef("Element.requestFullscreen()")}} {{Experimental_Inline}}</dt>
- <dd>Asynchronously asks the browser to make the element full-screen.</dd>
- <dt>{{DOMxRef("Element.requestPointerLock()")}} {{Experimental_Inline}}</dt>
- <dd>Allows to asynchronously ask for the pointer to be locked on the given element.</dd>
-</dl>
-
-<dl>
- <dt>{{domxref("Element.scroll()")}}</dt>
- <dd>Scrolls to a particular set of coordinates inside a given element.</dd>
- <dt>{{domxref("Element.scrollBy()")}}</dt>
- <dd>Scrolls an element by the given amount.</dd>
- <dt>{{DOMxRef("Element.scrollIntoView()")}} {{Experimental_Inline}}</dt>
- <dd>Scrolls the page until the element gets into the view.</dd>
- <dt>{{domxref("Element.scrollTo()")}}</dt>
- <dd>Scrolls to a particular set of coordinates inside a given element.</dd>
- <dt>{{DOMxRef("Element.setAttribute()")}}</dt>
- <dd>Sets the value of a named attribute of the current node.</dd>
- <dt>{{DOMxRef("Element.setAttributeNS()")}}</dt>
- <dd>Sets the value of the attribute with the specified name and namespace, from the current node.</dd>
- <dt>{{DOMxRef("Element.setAttributeNode()")}} {{Obsolete_Inline}}</dt>
- <dd>Sets the node representation of the named attribute from the current node.</dd>
- <dt>{{DOMxRef("Element.setAttributeNodeNS()")}} {{Obsolete_Inline}}</dt>
- <dd>Sets the node representation of the attribute with the specified name and namespace, from the current node.</dd>
- <dt>{{DOMxRef("Element.setCapture()")}} {{Non-standard_Inline}}</dt>
- <dd>Sets up mouse event capture, redirecting all mouse events to this element.</dd>
- <dt>{{DOMxRef("Element.setPointerCapture()")}}</dt>
- <dd>Designates a specific element as the capture target of future <a href="/en-US/docs/Web/API/Pointer_events">pointer events</a>.</dd>
- <dt>{{DOMxRef("Element.toggleAttribute()")}}</dt>
- <dd>Toggles a boolean attribute, removing it if it is present and adding it if it is not present, on the specified element.</dd>
-</dl>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>{{SpecName("Web Animations", '', '')}}</td>
- <td>{{Spec2("Web Animations")}}</td>
- <td>Added the <code>getAnimations()</code> method.</td>
- </tr>
- <tr>
- <td>{{SpecName('Undo Manager', '', 'Element')}}</td>
- <td>{{Spec2('Undo Manager')}}</td>
- <td>Added the <code>undoScope</code> and <code>undoManager</code> properties.</td>
- </tr>
- <tr>
- <td>{{SpecName('Pointer Events 2', '#extensions-to-the-element-interface', 'Element')}}</td>
- <td>{{Spec2('Pointer Events 2')}}</td>
- <td>Added the following event handlers: <code>ongotpointercapture</code> and <code>onlostpointercapture</code>.<br>
- Added the following methods: <code>setPointerCapture()</code> and <code>releasePointerCapture()</code>.</td>
- </tr>
- <tr>
- <td>{{SpecName('Pointer Events', '#extensions-to-the-element-interface', 'Element')}}</td>
- <td>{{Spec2('Pointer Events')}}</td>
- <td>Added the following event handlers: <code>ongotpointercapture</code> and <code>onlostpointercapture</code>.<br>
- Added the following methods: <code>setPointerCapture()</code> and <code>releasePointerCapture()</code>.</td>
- </tr>
- <tr>
- <td>{{SpecName('Selectors API Level 1', '#interface-definitions', 'Element')}}</td>
- <td>{{Spec2('Selectors API Level 1')}}</td>
- <td>Added the following methods: <code>querySelector()</code> and <code>querySelectorAll()</code>.</td>
- </tr>
- <tr>
- <td>{{SpecName('Pointer Lock', 'index.html#element-interface', 'Element')}}</td>
- <td>{{Spec2('Pointer Lock')}}</td>
- <td>Added the <code>requestPointerLock()</code> method.</td>
- </tr>
- <tr>
- <td>{{SpecName('Fullscreen', '#api', 'Element')}}</td>
- <td>{{Spec2('Fullscreen')}}</td>
- <td>Added the <code>requestFullscreen()</code> method.</td>
- </tr>
- <tr>
- <td>{{SpecName('DOM Parsing', '#extensions-to-the-element-interface', 'Element')}}</td>
- <td>{{Spec2('DOM Parsing')}}</td>
- <td>Added the following properties: <code>innerHTML</code>, and <code>outerHTML</code>.<br>
- Added the following method: <code>insertAdjacentHTML()</code>.</td>
- </tr>
- <tr>
- <td>{{SpecName('CSSOM View', '#extensions-to-the-element-interface', 'Element')}}</td>
- <td>{{Spec2('CSSOM View')}}</td>
- <td>Added the following properties: <code>scrollTop</code>, <code>scrollLeft</code>, <code>scrollWidth</code>, <code>scrollHeight</code>, <code>clientTop</code>, <code>clientLeft</code>, <code>clientWidth</code>, and <code>clientHeight</code>.<br>
- Added the following methods: <code>getClientRects()</code>, <code>getBoundingClientRect()</code>, <code>scroll()</code>, <code>scrollBy()</code>, <code>scrollTo()</code> and <code>scrollIntoView()</code>.</td>
- </tr>
- <tr>
- <td>{{SpecName('Element Traversal', '#ecmascript-bindings', 'Element')}}</td>
- <td>{{Spec2('Element Traversal')}}</td>
- <td>Added inheritance of the {{DOMxRef("ElementTraversal")}} interface.</td>
- </tr>
- <tr>
- <td>{{SpecName('DOM WHATWG', '#interface-element', 'Element')}}</td>
- <td>{{Spec2('DOM WHATWG')}}</td>
- <td>Added the following methods: <code>closest()</code>, <code>insertAdjacentElement()</code> and <code>insertAdjacentText()</code>.<br>
- Moved <code>hasAttributes()</code> from the <code>Node</code> interface to this one.</td>
- </tr>
- <tr>
- <td>{{SpecName("DOM4", "#interface-element", "Element")}}</td>
- <td>{{Spec2("DOM4")}}</td>
- <td>Removed the following methods: <code>setIdAttribute()</code>, <code>setIdAttributeNS()</code>, and <code>setIdAttributeNode()</code>.<br>
- Modified the return value of <code>getElementsByTagName()</code> and <code>getElementsByTagNameNS()</code>.<br>
- Removed the <code>schemaTypeInfo</code> property.</td>
- </tr>
- <tr>
- <td>{{SpecName('DOM3 Core', 'core.html#ID-745549614', 'Element')}}</td>
- <td>{{Spec2('DOM3 Core')}}</td>
- <td>Added the following methods: <code>setIdAttribute()</code>, <code>setIdAttributeNS()</code>, and <code>setIdAttributeNode()</code>. These methods were never implemented and have been removed in later specifications.<br>
- Added the <code>schemaTypeInfo</code> property. This property was never implemented and has been removed in later specifications.</td>
- </tr>
- <tr>
- <td>{{SpecName('DOM2 Core', 'core.html#ID-745549614', 'Element')}}</td>
- <td>{{Spec2('DOM2 Core')}}</td>
- <td>The <code>normalize()</code> method has been moved to {{DOMxRef("Node")}}.</td>
- </tr>
- <tr>
- <td>{{SpecName('DOM1', 'level-one-core.html#ID-745549614', 'Element')}}</td>
- <td>{{Spec2('DOM1')}}</td>
- <td>Initial definition.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-
-
-<p>{{Compat("api.Element")}}</p>
diff --git a/files/he/web/api/geolocation/index.html b/files/he/web/api/geolocation/index.html
deleted file mode 100644
index e69c21503d..0000000000
--- a/files/he/web/api/geolocation/index.html
+++ /dev/null
@@ -1,109 +0,0 @@
----
-title: Geolocation
-slug: Web/API/Geolocation
-tags:
- - API
- - Advanced
- - Geolocation API
- - Interface
- - NeedsTranslation
- - Reference
- - TopicStub
-translation_of: Web/API/Geolocation
----
-<div>
- {{APIRef}}</div>
-<p>The <code><strong>Geolocation</strong></code> interface represents an object able to programmatically obtain the position of the device. It gives Web content access to the location of the device. This allows a Web site or app offer customized results based on the user's location.</p>
-<p>An object with this interface is obtained using the {{domxref("NavigatorGeolocation.geolocation")}} property implemented by the {{domxref("Navigator")}} object.</p>
-<div class="note">
- <p><strong>Note:</strong> For security reasons, when a web page tries to access location information, the user is notified and asked to grant permission. Be aware that each browser has its own policies and methods for requesting this permission.</p>
-</div>
-<h2 id="Properties">Properties</h2>
-<p><em>The <code>Geolocation</code> interface neither implements, nor inherit any property.</em></p>
-<h2 id="Methods">Methods</h2>
-<p><em><em>The <code>Geolocation</code> interface doesn't inherit any </em>method</em>.</p>
-<dl>
- <dt>
- {{domxref("Geolocation.getCurrentPosition()")}}</dt>
- <dd>
- Determines the device's current location and gives back a {{domxref("Position")}} object with the data.</dd>
- <dt>
- {{domxref("Geolocation.watchPosition()")}}</dt>
- <dd>
- Returns a <code>long</code> value representing the newly established callback function to be invoked whenever the device location changes.</dd>
- <dt>
- {{domxref("Geolocation.clearWatch()")}}</dt>
- <dd>
- Removes the particular handler previously installed using <code>watchPosition()</code>.</dd>
-</dl>
-<h2 id="Specifications">Specifications</h2>
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>{{SpecName('Geolocation')}}</td>
- <td>{{Spec2('Geolocation')}}</td>
- <td>Initial specification.</td>
- </tr>
- </tbody>
-</table>
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-<p>{{ CompatibilityTable() }}</p>
-<div id="compat-desktop">
- <table class="compat-table">
- <tbody>
- <tr>
- <th>Feature</th>
- <th>Chrome</th>
- <th>Firefox (Gecko)</th>
- <th>Internet Explorer</th>
- <th>Opera</th>
- <th>Safari</th>
- </tr>
- <tr>
- <td>Basic support</td>
- <td>5</td>
- <td>{{CompatGeckoDesktop("1.9.1")}}</td>
- <td>9</td>
- <td>10.60<br>
- Removed in 15.0<br>
- Reintroduced in 16.0</td>
- <td>5</td>
- </tr>
- </tbody>
- </table>
-</div>
-<div id="compat-mobile">
- <table class="compat-table">
- <tbody>
- <tr>
- <th>Feature</th>
- <th>Android</th>
- <th>Chrome for Android</th>
- <th>Firefox Mobile (Gecko)</th>
- <th>IE Mobile</th>
- <th>Opera Mobile</th>
- <th>Safari Mobile</th>
- </tr>
- <tr>
- <td>Basic support</td>
- <td>{{CompatUnknown()}}</td>
- <td>{{CompatUnknown()}}</td>
- <td>{{CompatGeckoMobile("4")}}</td>
- <td>{{CompatUnknown()}}</td>
- <td>10.60</td>
- <td>{{CompatUnknown()}}</td>
- </tr>
- </tbody>
- </table>
-</div>
-<h2 id="See_also">See also</h2>
-<ul>
- <li><a href="/en-US/docs/WebAPI/Using_geolocation" title="/en-US/docs/WebAPI/Using_geolocation">Using geolocation</a></li>
-</ul>
diff --git a/files/he/web/api/geolocation_api/index.html b/files/he/web/api/geolocation_api/index.html
deleted file mode 100644
index 68994fa141..0000000000
--- a/files/he/web/api/geolocation_api/index.html
+++ /dev/null
@@ -1,251 +0,0 @@
----
-title: ממשק שירותי מיקום
-slug: Web/API/Geolocation_API
-translation_of: Web/API/Geolocation_API
-original_slug: Web/API/Geolocation/ממשק_שירותי_מיקום
----
-<p style="direction: rtl;">ממשק שירותי המיקום, geolocation API, מאפשר למשתמש לשתף את המיקום שלו עם אפליקציות ברשת. כדי להגן על הפרטיות, המשתמש נדרש להסכים לשתף את שירותי המיקום שלו.</p>
-<p style="direction: rtl;"><span style="font-size: 2.142857142857143rem; font-weight: 700; letter-spacing: -1px; line-height: 30px;">אובייקט ה- geolocation </span></p>
-<p style="direction: rtl;">ממשק שירותי המיקום נגיש באמצעות אובייקט:<span style="line-height: 1.5;">{{domxref("window.navigator.geolocation","navigator.geolocation")}} .</span></p>
-<p style="direction: rtl;">אם האובייקט קיים, ממשק שירותי המיקום נתמך: ניתן לבדוק אם ממשק שירותי המיקום נתמך באמצעות: </p>
-<pre class="brush: js">if ("geolocation" in navigator) {
- /* הממשק נתמך*/
-} else {
- /* הממשק אינו נתמך */
-}הערה
-</pre>
-<div class="note">
- <p style="direction: rtl;"><strong>הערה:</strong> מגרסה מס' 24 של FireFox ומטה, הפקודה geolocation" in navigator" מחזירה true אפילו אם הממשק אינו נתמך. באג זה תוקן ב<a href="/en-US/docs/Mozilla/Firefox/Releases/25/Site_Compatibility">גרסה 25 של FireFox</a> על מנת לעמוד בתקן. ({{bug(884921)}}).</p>
-</div>
-<h3 id="קבלת_המיקום_הנוכחי" style="direction: rtl;">קבלת המיקום הנוכחי</h3>
-<p dir="rtl">כדי לקבל את נתוני המיקום הנוכחי של המשתמש, ניתן לקרוא לפונקציה: <span style="line-height: 1.5;"> {{domxref("window.navigator.geolocation.getCurrentPosition()","getCurrentPosition()")}}. הפונקציה יוצרת קריאה אסינכרונית על מנת לאחזר את המיקום של המשתמש ובודקת את החומרה על מנת לקבל את המיקום העדכני ביותר. כאשר נתוני המיקום חוזרים כתוצאה מהקריאה, פונקציית המטרה (באנגלית: callback) נקראת. אפשר להעביר לקריאה פרמטר נוסף, פרמטר שני: פונקציית מטרה לטיפול במיקרה של שגיאה. אפשר להעביר פרמטר שלישי לקריאה: אובייקט options שבו אפשר להגדיר מהו הוותק המכסימלי לערכי המיקום המוחזרים, משך הזמן המכסימלי להמתנה עד שנתוני המיקום יתקבלו ורמת הדיוק של נתוני המיקום. </span></p>
-<div class="note">
- <p style="direction: rtl;"><strong>הערה</strong>: כברירת מחדל, הפונקציה<span style="line-height: 1.5;">, {{domxref("window.navigator.geolocation.getCurrentPosition()","getCurrentPosition()")}} מנסה להחזיר את נתוני המיקום במהירות האפשרית, אך ברמת דיוק מינימלית. צורה זו שימושית אם רוצים לקבל את הנתונים במהירות הגבוהה האפשרית תוך התפשרות על רמת הדיוק. במכשירים עם מנגנון GPS משך הזמן לקבלת נתונים יכול לקחת דקה ויותר, לכן הפונקציה </span><span style="line-height: 1.5;"> {{domxref("window.navigator.geolocation.getCurrentPosition()","getCurrentPosition()")}} יכולה לקבל בחזרה נתונים שיש בהם מידה מסוימת של שגיאה (אם המיקום חושב על בסיס כתובת IP על בסיס מיקום נקודת wifi).</span></p>
-</div>
-<pre class="brush: js">navigator.geolocation.getCurrentPosition(function(position) {
- do_something(position.coords.latitude, position.coords.longitude);
-});</pre>
-<p style="direction: rtl;">הקוד בדוגמא שלעיל יגרום לפונקצייה, ()do_something, להתבצע כאשר נתוני המיקום חזרו.</p>
-<p> </p>
-<p style="direction: rtl;"><span style="font-size: 1.714285714285714rem; letter-spacing: -0.5px; line-height: 24px;">מעקב אחר המיקום הנוכחי</span></p>
-<p style="direction: rtl;"><span style="line-height: 1.5;">אם נתוני המיקום משתנים (בגלל שהדפדפן נמצא בתנועה, או אם הגיעו נתוני מיקום מדוייקים יותר), אפשר להגדיר פונקציית מטרה (באנגלית: callback), המקבלת נתוני מיקום מעודכנים יותר. עושים זאת באמצעות הפונקציה: </span><span style="line-height: 1.5;">{{domxref("window.navigator.geolocation.watchPosition()","watchPosition()")}} שיש לה את אותם פרמטרים כמו הפונקציה: </span><span style="line-height: 1.5;"> {{domxref("window.navigator.geolocation.getCurrentPosition()","getCurrentPosition()")}}. פונקציית המטרה מתבצעת מס' כלשהו של פעמים ומאפשרת לדפדפן לעדכן את המיקום של המשתמש תוך כדי תנועה, או לעדכן את מיקומו בנתונים מעודכנים יותר שהגיעו על ידי טכניקות זיהוי מיקום מדוייקות יותר. ניתן להגדיר פונקציית מטרה נוספת למקרה של שגיאה שתיקרא בכל פעם שתתרחש שגיאה כפי שקורה במיקרה של: </span><span style="line-height: 1.5;"> {{domxref("window.navigator.geolocation.getCurrentPosition()","getCurrentPosition()")}}.</span></p>
-<div class="note">
- <p style="direction: rtl;"><strong>הערה</strong>: ניתן להשתמש בפונקציה: <span style="line-height: 1.5;">{{domxref("window.navigator.geolocation.watchPosition()","watchPosition()")}} מבלי צורך לקרוא לפני כן לפונקציה: {{domxref("window.navigator.geolocation.getCurrentPosition()","getCurrentPosition()")}} .</span></p>
-</div>
-<pre class="brush: js">var watchID = navigator.geolocation.watchPosition(function(position) {
- do_something(position.coords.latitude, position.coords.longitude);
-});</pre>
-<p style="direction: rtl;">הפונקציה <span style="line-height: 1.5;">{{domxref("window.navigator.geolocation.watchPosition()","watchPosition()")}} מחזירה id שמזהה את הפונקציה שעוקבת אחר המיקום. ניתן לאחר מכן להשתמש בו כדי לקרוא לפונקציה </span><span style="line-height: 1.5;"> {{domxref("window.navigator.geolocation.clearWatch()","clearWatch()")}} על מנת להפסיק את פעולת המעקב אחרי תנועת המשתמש.</span></p>
-<pre class="brush: js">navigator.geolocation.clearWatch(watchID);
-</pre>
-<h3 id="כיול_התוצאות" style="direction: rtl;">כיול התוצאות</h3>
-<p style="direction: rtl;">הן הפונקציה {{domxref("window.navigator.geolocation.getCurrentPosition()","getCurrentPosition()")}} והן הפונקציה {{domxref("window.navigator.geolocation.watchPosition()","watchPosition()")}} מקבלות פרמטר פונקציית מטרה למקרה הצלחה בקבלת נתונים, מקבלות פרמטר אופציונאלי למקרה של שגיאה בקבלת נתוני מיקום ופרמטר אופציונאלי שלישי: אובייקט <span style="line-height: 1.5;"> </span><code style="font-style: normal; line-height: 1.5;">PositionOptions</code><span style="line-height: 1.5;">.</span></p>
-<p>{{page("/en-US/docs/DOM/window.navigator.geolocation.getCurrentPosition","PositionOptions")}}</p>
-<p style="direction: rtl;">קריאה ל: {{domxref("window.navigator.geolocation.watchPosition()","watchPosition")}} יכולה להיראות כך:</p>
-<pre class="brush: js">function geo_success(position) {
- do_something(position.coords.latitude, position.coords.longitude);
-}
-
-function geo_error() {
- alert("Sorry, no position available.");
-}
-
-var geo_options = {
- enableHighAccuracy: true,
- maximumAge : 30000,
- timeout : 27000
-};
-
-var wpid = navigator.geolocation.watchPosition(geo_success, geo_error, geo_options);</pre>
-<p><a id="fck_paste_padding">A demo of watchPosition in use: </a><a class="external" href="http://www.thedotproduct.org/experiments/geo/">http://www.thedotproduct.org/experiments/geo/</a><br>
- <a id="fck_paste_padding"></a></p>
-<h2 id="נתוני_המיקום" style="direction: rtl;">נתוני המיקום</h2>
-<p style="direction: rtl;">המיקום של המשתמש הוא אובייקט <code>Position</code> שמכיל בתוכו אובייקט <code>Coordinates</code>.</p>
-<p><span style="line-height: 1.5;">{{page("/en-US/docs/DOM/window.navigator.geolocation.getCurrentPosition","Position")}}</span></p>
-<p>{{page("/en-US/docs/DOM/window.navigator.geolocation.getCurrentPosition","Coordinates")}}</p>
-<h2 id="טיפול_בשגיאות" style="direction: rtl;">טיפול בשגיאות</h2>
-<p style="direction: rtl;"><span style="font-size: 14px; font-weight: normal; line-height: 1.5;">פונקציית המטרה לטיפול בשגיאות נגישה גם בקריאה לפונקציה ()</span><code><span style="font-size: 14px; line-height: 1.5;"><font face="Courier New, Andale Mono, monospace">getCurrentPosition</font></span></code><span style="line-height: 1.5;"><code> </code>וגם בקריאה ל ()<code>watchPosition</code><strong><code>, </code></strong></span>ומקבלת כפרמטר ראשון אובייקט <code>PositionError</code>. </p>
-<pre class="brush: js">function errorCallback(error) {
- alert('ERROR(' + error.code + '): ' + error.message);
-};
-</pre>
-<p>{{page("/en-US/docs/DOM/window.navigator.geolocation.getCurrentPosition","PositionError")}}</p>
-<h2 id="דוגמא_שלמה_לממשק_שירותי_מיקום" style="direction: rtl;">דוגמא שלמה לממשק שירותי מיקום</h2>
-<div class="hidden">
- <pre class="brush: css">body {
- padding: 20px;
- background-color:#ffffc9
-}
-
-p { margin : 0; }
-</pre>
-</div>
-<h3 id="HTML" style="direction: rtl;">HTML: </h3>
-<pre class="brush: html;">&lt;p&gt;&lt;button onclick="geoFindMe()"&gt;Show my location&lt;/button&gt;&lt;/p&gt;
-&lt;div id="out"&gt;&lt;/div&gt;
-</pre>
-<h3 id="JavaScript" style="direction: rtl;">JavaScript:</h3>
-<pre class="brush: js;">function geoFindMe() {
- var output = document.getElementById("out");
-
- if (!navigator.geolocation){
- output.innerHTML = "&lt;p&gt;Geolocation is not supported by your browser&lt;/p&gt;";
- return;
- }
-
- function success(position) {
- var latitude = position.coords.latitude;
- var longitude = position.coords.longitude;
-
- output.innerHTML = '&lt;p&gt;Latitude is ' + latitude + '° &lt;br&gt;Longitude is ' + longitude + '°&lt;/p&gt;';
-
- var img = new Image();
- img.src = "http://maps.googleapis.com/maps/api/staticmap?center=" + latitude + "," + longitude + "&amp;zoom=13&amp;size=300x300&amp;sensor=false";
-
- output.appendChild(img);
- };
-
- function error() {
- output.innerHTML = "Unable to retrieve your location";
- };
-
- output.innerHTML = "&lt;p&gt;Locating…&lt;/p&gt;";
-
- navigator.geolocation.getCurrentPosition(success, error);
-}
-</pre>
-<h3 id="תוצאות_של_הדוגמא_לעיל" style="direction: rtl;">תוצאות של הדוגמא לעיל:</h3>
-<p>{{ EmbedLiveSample('Geolocation_Live_Example',350,410) }}</p>
-<h2 id="הצגת_הודעה_לבקשת_רשות" style="direction: rtl;">הצגת הודעה לבקשת רשות</h2>
-<p style="direction: rtl;">כל תוסף המשתייך ל addons.mozilla.org המשתמש בממשק שירותי המיקום חייב לקבל אישור מהמשתמש לגשת לממשק על ידי בקשת רשות מפורשת. הפונקציה הבאה תבקש אישור באופן שזהה לבקשת האישור המוצגת לדפים ברשת. הבחירה של המשתמש תישמר בהעדפות באמצעות פרמטר <code>pref </code>או הוא מאופשר. הפונקציה המוצבעת על ידי פרמטר <code>callback </code>תיקרא עם פרמטר בוליאני המציין את בחירת המשתמש. אם הערך <code>true </code>יש לתוסף הרשאה לגשת לנתוני המיקום. </p>
-<pre class="brush: js">function prompt(window, pref, message, callback) {
- let branch = Components.classes["@mozilla.org/preferences-service;1"]
- .getService(Components.interfaces.nsIPrefBranch);
-
- if (branch.getPrefType(pref) === branch.PREF_STRING) {
- switch (branch.getCharPref(pref)) {
- case "always":
- return callback(true);
- case "never":
- return callback(false);
- }
- }
-
- let done = false;
-
- function remember(value, result) {
- return function() {
- done = true;
- branch.setCharPref(pref, value);
- callback(result);
- }
- }
-
- let self = window.PopupNotifications.show(
- window.gBrowser.selectedBrowser,
- "geolocation",
- message,
- "geo-notification-icon",
- {
- label: "Share Location",
- accessKey: "S",
- callback: function(notification) {
- done = true;
- callback(true);
- }
- }, [
- {
- label: "Always Share",
- accessKey: "A",
- callback: remember("always", true)
- },
- {
- label: "Never Share",
- accessKey: "N",
- callback: remember("never", false)
- }
- ], {
- eventCallback: function(event) {
- if (event === "dismissed") {
- if (!done) callback(false);
- done = true;
- window.PopupNotifications.remove(self);
- }
- },
- persistWhileVisible: true
- });
-}
-
-prompt(window,
- "extensions.foo-addon.allowGeolocation",
- "Foo Add-on wants to know your location.",
- function callback(allowed) { alert(allowed); });
-</pre>
-<h2 id="תאימות_דפדפנים">תאימות דפדפנים</h2>
-<div>
- {{ CompatibilityTable() }}</div>
-<div>
-  </div>
-<div id="compat-desktop">
- <table class="compat-table">
- <tbody>
- <tr>
- <th>Feature</th>
- <th>Chrome</th>
- <th>Firefox (Gecko)</th>
- <th>Internet Explorer</th>
- <th>Opera</th>
- <th>Safari</th>
- </tr>
- <tr>
- <td>Basic support</td>
- <td>5</td>
- <td>{{CompatGeckoDesktop("1.9.1")}}</td>
- <td>9</td>
- <td>10.60<br>
- Removed in 15.0<br>
- Reintroduced in 16.0</td>
- <td>5</td>
- </tr>
- </tbody>
- </table>
-</div>
-<div id="compat-mobile">
- <table class="compat-table">
- <tbody>
- <tr>
- <th>Feature</th>
- <th>Android</th>
- <th>Chrome for Android</th>
- <th>Firefox Mobile (Gecko)</th>
- <th>Firefox OS</th>
- <th>IE Mobile</th>
- <th>Opera Mobile</th>
- <th>Safari Mobile</th>
- </tr>
- <tr>
- <td>Basic support</td>
- <td>{{CompatUnknown()}}</td>
- <td>{{CompatUnknown()}}</td>
- <td>{{CompatGeckoMobile("4")}}</td>
- <td>1.0.1</td>
- <td>{{CompatUnknown()}}</td>
- <td>10.60<br>
- Removed in 15.0<br>
- Reintroduced in 16.0</td>
- <td>{{CompatUnknown()}}</td>
- </tr>
- </tbody>
- </table>
-</div>
-<h3 id="הערות_לגבי_Gecko" style="direction: rtl;">הערות לגבי Gecko</h3>
-<p style="direction: rtl;">דפדפן FireFox תומך בקבלת נתוני המיקום בהתבסס על מידע WiFi באמצעות שירותי המיקום של גוגל. בטרנזאקציה שבין FireFox ל Google, המידע שמועבר כולל מידע על נקודת הגישה ל WiFi, כולל access token (שדומה לcookie בעלת תוקף למשך שבועיים) וכולל את כתובת ה IP של המשתמש. למידע נוסף יש התעדכן ב<a href="http://www.mozilla.com/en-US/legal/privacy/">תנאי הפרטיות</a> של Mozilla וב<a href="http://www.google.com/privacy-lsf.html">תנאי הפרטיות</a> של גוגל המפרטים באיזה אופן נתונים אלה ניתנים לשימוש. </p>
-<p style="direction: rtl;">FireFox גרסת 3.6 (Gecko 1.9.2) הוסיף תמיכה לשימוש בשירות GPSD (GPS daemon) בשביל שירותי מיקום עבור Linux. </p>
-<p style="direction: rtl;"><span style="font-size: 2.142857142857143rem; font-weight: 700; letter-spacing: -1px; line-height: 30px;">לעיון נוסף</span></p>
-<ul>
- <li>{{domxref("window.navigator.geolocation","navigator.geolocation")}}</li>
- <li><a href="/en-US/Apps/Build/gather_and_modify_data/Plotting_yourself_on_the_map">צייר את עצמך על המפה</a></li>
- <li><a href="http://www.w3.org/TR/geolocation-API/">ממשק שירותי המיקום ב:w3.org</a></li>
- <li><a href="/en-US/demos/tag/tech:geolocation">דוגמאות לשימוש במשק נתוני המיקום</a></li>
- <li><a href="https://hacks.mozilla.org/2013/10/who-moved-my-geolocation/">Who moved my geolocation?</a> (Hacks blog)</li>
-</ul>
diff --git a/files/he/web/api/index.html b/files/he/web/api/index.html
deleted file mode 100644
index 83cde65af8..0000000000
--- a/files/he/web/api/index.html
+++ /dev/null
@@ -1,38 +0,0 @@
----
-title: Web API Interfaces
-slug: Web/API
-tags:
- - API
- - Apps
- - JavaScript
- - Landing
- - Reference
- - Web
- - WebAPI
-translation_of: Web/API
----
-<p dir="rtl">כשאתה כותב קוד עבור ה-Web, יש הרבה Web APIs זמינים. להלן רשימה של כל ה-APIs והממשקים (טיפוסי עצמים) בהם תוכל להשתמש בעת פיתוח אפליקציית ה-Web או האתר שלך.</p>
-
-<div dir="rtl">בדרך כלל משתמשים ב-Web APIs עם JavaScript, אם כי זה לא תמיד חייב להיות כך.</div>
-
-<div dir="rtl"></div>
-
-<h2 dir="rtl" id="מפרטים">מפרטים</h2>
-
-<p dir="rtl">זו רשימת כל ה-APIs הזמינים.</p>
-
-<p dir="rtl">{{ListGroups}}</p>
-
-<h2 dir="rtl" id="ממשקים">ממשקים</h2>
-
-<p dir="rtl">זו רשימת כל הממשקים (זאת אומרת, טיפוסים של עצמים) הזמינים.</p>
-
-<p dir="rtl">{{APIListAlpha}}</p>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-
-
-<ul dir="rtl">
- <li><a href="/he/docs/Web/Events">התייחסות לאירועי Web API</a></li>
-</ul>
diff --git a/files/he/web/api/indexeddb_api/browser_storage_limits_and_eviction_criteria/index.html b/files/he/web/api/indexeddb_api/browser_storage_limits_and_eviction_criteria/index.html
deleted file mode 100644
index 094ee01378..0000000000
--- a/files/he/web/api/indexeddb_api/browser_storage_limits_and_eviction_criteria/index.html
+++ /dev/null
@@ -1,141 +0,0 @@
----
-title: מגבלות האחסנה של הדפדפן וקריטריונים לפינוי
-slug: Web/API/IndexedDB_API/Browser_storage_limits_and_eviction_criteria
-tags:
- - Database
- - IndexedDB
- - LRU
- - אחסנה
- - בדיס נתונים
- - מגבלה
- - פינוי
- - צד הלקוח
-translation_of: Web/API/IndexedDB_API/Browser_storage_limits_and_eviction_criteria
----
-<div>{{DefaultAPISidebar("IndexedDB")}}</div>
-
-<div>קיימות מספר טכנולוגיות רשת המאחסנות נתונים מסוג זה או אחר בצד הלקוח (כלומר, על הדיסק המקומי שלך). התהליך בו הדפדפן מחשב כמה מקום להקצות לאחסנת מידע רשת ומה למחוק כאשר מגיעים לגבול אינו פשוט, ונבדל בין דפדפנים.</div>
-
-<div>מאמר זה מתאר איך דפדפנים מכריעים איזה תוכן מקומי לטהר, ומתי בסדר לשחרר חלל אחסנה מקומי.</div>
-
-<p class="summary"></p>
-
-<div class="note">
-<p><strong>לתשומת לבך</strong>: המידע שלהלן אמור להיות מדוייק במידה מספקת עבור רוב הדפדפנים המודרניים, אך פרטי דפדפן נקראים כאשר ידועים. אופרה וכרום צריכים לפעול באותה דרך בכל המקרים, <a href="http://www.opera.com/mobile/mini">Opera Mini</a> (תצוגת צד שרת, שעדיין מבוסס על תגובה מהירה) אינו מאחסן כל נתונים שהם בצד הלדוח.</p>
-</div>
-
-<h2 id="אלו_טכנולוגיות_משתמשות_באחסנת_הנתונים_של_הדפדפן">אלו טכנולוגיות משתמשות באחסנת הנתונים של הדפדפן?</h2>
-
-<p>בפיירפוקס, הטכנולוגיות הבאות עושות שימוש באחסנת הנתונים של הדפדפן לאחסן נתונים כאשר יש צורך.  הגדרנו עבורם את המושג "לקוחות מכסה" בהקשר זה:</p>
-
-<ul>
- <li><a href="/en-US/docs/Web/API/IndexedDB_API">IndexedDB</a></li>
- <li>שמירת <a href="http://asmjs.org/">asm.js</a> במטמון</li>
- <li><a href="/en-US/docs/Web/API/Cache">Cache API</a></li>
- <li>עוגיות</li>
-</ul>
-
-<div class="note">
-<p><strong>לתשומת לבך</strong>: בפיירפוקס, <a href="/en-US/docs/Web/API/Web_Storage_API">אחסנת הרשת</a> בקרוב תתחיל להשתמש גם היא באותם כלי ניהול שטחי אחסון , כמתואר במסמך זה.</p>
-</div>
-
-<div class="note">
-<p><strong>לתשומת לבך</strong>: במצב גלישה פרטית, רוב אחסנת המידע אינה נתמכת. נתוני אחסון מקומיים ועוגיות עדיין מאוחסנים, אך הם ארעיים - הנתונים נמחקים כאשר סוגרים את חלון אך הם ארעיים — הנתונים נמחקים עם סגירת חלון הגלישה הפרטית האחרון.</p>
-</div>
-
-<p>"זמן הגישה האחרון" של מקורות מתעדכן כאשר כל אחד מאלה מופעל/מושבת  — פינוי מקורות ימח' נתונים עבור כל לקוחות המכסה.</p>
-
-<p>בכרום/אופרה, ממשק פיתוח היישומים של ניהול המכסות מטפל בניהול עבור  <a href="/en-US/docs/Web/HTML/Using_the_application_cache">AppCache</a>, <a href="/en-US/docs/Web/API/IndexedDB_API">IndexedDB</a>, WebSQL, ו-<a href="/en-US/docs/Web/API/File_System_API">File System API</a>.</p>
-
-<h2 id="טיפוסים_שונים_של_אחסנת_נתונים">טיפוסים שונים של אחסנת נתונים</h2>
-
-<p>גם באותו הדפדפן, שימוש באותה שיטת אחסון, קיינות מחלקות שונות של אחסנת נתונים להבין. פרק זה ידון במפר מהם שייתכן ויימצאו בדפדפנים שונים.</p>
-
-<p>אחסנה מופיעה במספר טיפוסים:</p>
-
-<ul>
- <li>קבועה : אלה הנתונים שבכוונתנו לשמור בהישג יד לטווח רחוק. הם יפונו אך ורק על פי בחירת המשתמש/ת (לדוגמה, בפיירפוקס תוכלו לבחור למחוק את כל הנתונים המאוחסנים ממקורות נבחרים על ידי גישה ל"העדפות" ושימוש באפשרויות תחת <em>"פרטיות ואבטחה-&gt; עוגיות ונתוני אתרים"</em>).</li>
- <li>זמנית: אלו נתונים שאינם צריכים להישמר לזמן רב כל כך. הם יפונו תחת מדיניות השימוש המאוחר ביותר ({{anch("LRU policy")}}) כאשר כמות הנתונים תגיע ל- {{anch("מגבלות האחסנה")}}.</li>
-</ul>
-
-<p>בפיירפוקס, כשאשר נעשה שימוש באחסנה קבועה,, ניתן למשתמש/ת חלון ממשק משתמש קופץ להתריע לו/ה כי הנתונים יישמרו, ובחלון תישאל השאלה אם המשתמש/ת מסכים/ה לכך.  אחסנת נתונים זמנית אינה מעוררת כל פנייה למשתמש/ת.</p>
-
-<p>כברירת מחדל האחסנה היא זמנית; מפתחים יכולים לבחור להשתמש באחסנה קבועה לאתרים שלהם באמצעות השיטה  {{domxref("StorageManager.persist()")}} הזמינה ב-<a href="/en-US/docs/Web/API/Storage_API">Storage API</a>.</p>
-
-<h2 id="היכן_מאוחסנים_הנתונים">היכן מאוחסנים הנתונים?</h2>
-
-<p>כל טיפוס אחסנה מייצג מאגר נפרד. להלן המיפוי האקטואלי ל,תיקיות תחת פרופיל הפיירפוקס של  המשתמש/ת (דפדפנים אחרים עשויים להיות מעט שונים):</p>
-
-<ul>
- <li><code>&lt;profile&gt;/storage</code> — התיקייה הראשית של הרמה הגבוהה ביותר לאחסון מתוחזקת על ידי מנהל המכסות (ראו להלן)</li>
- <li><code>&lt;profile&gt;/storage/permanent</code> — תיקיית מאגר הנתונים הקבועים</li>
- <li><code>&lt;profile&gt;/storage/temporary</code> — תיקיית מאגר הנתונים הזמניים</li>
- <li><code>&lt;profile&gt;/storage/default</code> — מאגר ברירת המחדל של הנתונים</li>
-</ul>
-
-<div>
-<div class="note">
-<p><strong>לתשומת לבך</strong>: אחרי שהוצג ה <a href="/en-US/docs/Web/API/Storage_API">Storage API</a>, התיקייה "permanent" יכולה להיחשב  מיושנת; התיקייה  "permanent" מאחסנת רק את בסיסי הנתונים מהטיפוס הקבוע IndexedDB. לא משנה אם מצב התיבה הוא  "best-effort" או "persistent" — נתונים   נשמרים תחת &lt;profile&gt;/storage/default.</p>
-</div>
-</div>
-
-<div class="note">
-<p><strong>לתשומת לבך</strong>: בפיירפוקס , ניתן למצוא את תיקיית הפרופיל שלך על ידי הכנסת  <code>about:support</code> בשורת ה- URL , ולחיצה על הכפתור  פתיחת ספרייה  (למשל <em>Show ב- Finder</em> על Mac OS X) על יד הכותרת <em>Profile Folder</em> .</p>
-</div>
-
-<div class="note">
-<p><strong>לתשומת לבך</strong>: אם תחפשו במידע השמור בתיקיית הפרופיל , ייתכן שתמצאו תיקייה רביעית:: <code>persistent</code>. בעיקרות, שמה של התיקייה <code>persistent</code> שונה ל-<code>permanent</code> בשלב מסויים בעבר  כדי ששדרוגים/מעברים יהיו פשוטים לביצוע.</p>
-</div>
-
-<div class="note">
-<p><strong>לתשומת לבך</strong>: אל למשתמשים להוסיף תיקיות וקבצים משלהם תחת  <code>&lt;profile&gt;/storage</code>. זה יגרום לאתחולי אחסנה להיכשל; לדוגמא, {{domxref("IDBFactory.open()", "open()")}} יגרום לאירוע שגיאה.</p>
-</div>
-
-<h2 id="מגבלות_האחסנה">מגבלות האחסנה</h2>
-
-<p>שטח האחסנה המירבי של הדפדפן הוא דינמי — הוא מבוסס על גודל הדיסק הקשיח.  <strong>הגבול הגלובלי</strong> מחושב כ-50% מהשטח הפנוי על הדיסק. בפיירפוקס, כלי פנימי של הדפדפן הקרוי   Quota Manager כוקב אחרי גודל חלל הדיסק שכל מקור מנצל עד תום, ומוחק נתונים אם יש צורך בכך.</p>
-
-<p>כך שאם נפח הדיסק הקשיח שלך הוא 500 ג"ב, אזי שטח האחסון לדפדפן הינו 250 ג"ב. במקרה של חריגה, מופעל תהליך בשם <strong>origin eviction</strong>, המוחק את כל שווי הנתונים של המקור  עד שכמות הנתונים המאוחסנת חוזרת אל מתחת לגבול. אין כל אפקט של קיצוץ הבא למחוק חלקים של מקורות  — מחיקת בסיס נתונים של מקור עלולה ליצור בעיות של חוסר עקביות.</p>
-
-<p>קיים גם גבול הקרוי <strong>group limit</strong> — הוא מוגדר כ- 20% מהגבול הגלובלי, אך יש לו מינימום של 10 מ"ב ומקסימום של 2 ג"ב. כל מקור הוא חלק מקבוצה (קבוצת מקורות). קיימת קבוצה לכל דומיין eTLD+1. לדוגמה:</p>
-
-<ul>
- <li><code>mozilla.org</code> — group1, origin1</li>
- <li><code>www.mozilla.org</code> — group1, origin2</li>
- <li><code>joe.blogs.mozilla.org</code> — group1, origin3</li>
- <li><code>firefox.com</code> — group2, origin4</li>
-</ul>
-
-<p>בקבוצה זו, <code>mozilla.org</code>, <code>www.mozilla.org</code>, ו-<code>joe.blogs.mozilla.org</code> יכולים במצטבר להשתמש במקסימום  20% מהגבול הגלובלי. <code>ל- firefox.com</code> יש מקסימום בנפרד של 20%.</p>
-
-<p>שני הגבולות מגיבים בצורה שונה כשמגיעים לגבול:</p>
-
-<ul>
- <li>לגבול הקבוצתי קוראים גם  "גבול קשה": הוא אינו גורם לפינוי מקורות.</li>
- <li>הגבול הגלובלי הוא "גבול רך" מכיוון שאין סיכוי ששטח כלשהו ישוחרר והפעולה יכולה להימשך,</li>
-</ul>
-
-<div class="note">
-<p><strong>לתשומת לבך</strong>: הגבול הקבוצתי אינו יכול להיות יותר מהגבול הגלובלי, , למרות מינימום הגבול הקבוצתי הנזכר לעיל . אם הינך במצב של מעט זיכרון באמת כשנניח שהגבול הגלובלי הוא, 8 מ"ב, אז גם הגבול הקבוצתי יהיה  8 מ"ב.</p>
-</div>
-
-<div class="note">
-<p><strong>לתשומת לבך</strong>: כאשר חורגים מהגבול הקבוצתי, או אם פינוי המקור אינו יכול לשחרר מספיק שטח, הדפדפן יצא עם החריגה <code>QuotaExceededError</code>.</p>
-</div>
-
-<div class="note">
-<p><strong>לתשומת לבך</strong>: בכרום מכסת האחסנה הרכה והקשה השתנתה מאז  <strong>M66</strong>. מידע נוסף ניתן למצוא <a href="https://chromium.googlesource.com/chromium/src/+/refs/heads/master/storage/browser/quota/quota_settings.cc#68">כאן.</a></p>
-</div>
-
-<h2 id="מדיניותLRU">מדיניותLRU</h2>
-
-<p>כאשר שטח הדיסק מתמלא עד תום, מנהל המכסות מתחיל לנקות נתונים בהתבסס על מדיניות  LRU  — המקור בו נעשה שימוש רחוק ביותר מלאחרונה ימחק קודם, ואחר כך זה הבא אחריו, עד שהדפדפן כבר אינו חורג מהגבול.</p>
-
-<p>אנו עוקבים אחרי "זמן הגישה האחרון" עבור כל מקור באמצעות אחסנה זמנית. כאשר מושג הגבול הגלובלי עבור אחסנה זמנית (עוד אודות הגבול מאוחר יותר), אנו מנסים למצוא את כל המקורות שלא היו בשימוש (iכלומר אלה ללא לשוניות.ישומים פתוחים הממשיכים לשמור מאגרי מידע פתוחים). אלה ממויינים בשלב זה על פי "זמן הגישה האחרון".  המקור שהיה בשימוש הכי רחוק מלאחרונה נמחקים בשלב זה  עד שיש מספיק מקום להגשים את הבקשה שגרמה לפינוי המקור.</p>
-
-<h2 id="ראו_גם">ראו גם</h2>
-
-<ul>
- <li><a href="http://www.html5rocks.com/en/tutorials/offline/quota-research/">Working with quota on mobile browsers</a>, by<a href="http://blog.agektmr.com" title="Eiji Kitamura"> Eiji Kitamura.</a> A detailed analysis of client-side storage on mobile browsers.</li>
- <li><a href="https://developers.google.com/web/updates/2011/11/Quota-Management-API-Fast-Facts">Quota Management API: Fast Facts</a>, by<a href="http://blog.agektmr.com" title="Eiji Kitamura"> Eiji Kitamura.</a> A look at the Quota Management API in Chrome/Blink (which should include Opera, too).</li>
-</ul>
diff --git a/files/he/web/api/indexeddb_api/index.html b/files/he/web/api/indexeddb_api/index.html
deleted file mode 100644
index 957b6f96c5..0000000000
--- a/files/he/web/api/indexeddb_api/index.html
+++ /dev/null
@@ -1,165 +0,0 @@
----
-title: IndexedDB API
-slug: Web/API/IndexedDB_API
-tags:
- - API
- - Advanced
- - Database
- - IndexedDB
- - Landing
- - NeedsTranslation
- - Reference
- - Storage
- - TopicStub
-translation_of: Web/API/IndexedDB_API
----
-<div>{{DefaultAPISidebar("IndexedDB")}}</div>
-
-<p>IndexedDB is a low-level API for client-side storage of significant amounts of structured data, including files/blobs. This API uses indexes to enable high-performance searches of this data. While <a href="/en-US/docs/Web/API/Web_Storage_API">Web Storage</a> is useful for storing smaller amounts of data, it is less useful for storing larger amounts of structured data. IndexedDB provides a solution. This is the main landing page for MDN's IndexedDB coverage — here we provide links to the full API reference and usage guides, browser support details, and some explanation of key concepts.</p>
-
-<p>{{AvailableInWorkers}}</p>
-
-<div class="note">
-<p><strong>Note</strong>: IndexedDB API is powerful, but may seem too complicated for simple cases. If you'd prefer a simple API, try libraries such as <a href="https://localforage.github.io/localForage/">localForage</a>, <a href="https://dexie.org/">dexie.js</a>, <a href="https://github.com/erikolson186/zangodb">ZangoDB</a>, <a href="https://pouchdb.com/">PouchDB</a>, <a href="https://www.npmjs.com/package/idb">idb</a>, <a href="https://www.npmjs.com/package/idb-keyval">idb-keyval</a>, <a href="https://jsstore.net/">JsStore</a> and <a href="https://github.com/google/lovefield">lovefield</a> that make IndexedDB more programmer-friendly.</p>
-</div>
-
-<h2 id="Key_concepts_and_usage">Key concepts and usage</h2>
-
-<p>IndexedDB is a transactional database system, like an SQL-based RDBMS. However, unlike SQL-based RDBMSes, which use fixed-column tables, IndexedDB is a JavaScript-based object-oriented database. IndexedDB lets you store and retrieve objects that are indexed with a <strong>key</strong>; any objects supported by the <a href="/en-US/docs/Web/API/Web_Workers_API/Structured_clone_algorithm">structured clone algorithm</a> can be stored. You need to specify the database schema, open a connection to your database, and then retrieve and update data within a series of <strong>transactions</strong>.</p>
-
-<ul>
- <li>Read more about the <a href="/en-US/docs/Web/API/IndexedDB_API/Basic_Concepts_Behind_IndexedDB">Concepts behind IndexedDB</a>.</li>
- <li>Learn to use IndexedDB asynchronously from first principles with our <a href="/en-US/docs/Web/API/IndexedDB_API/Using_IndexedDB">Using IndexedDB</a> guide.</li>
- <li>Combine IndexedDB for storing data offline with Service Workers for storing assets offline, as outlined in <a href="/en-US/docs/Web/Progressive_web_apps/Offline_Service_workers">Making PWAs work offline with Service workers</a>.</li>
-</ul>
-
-<div class="note">
-<p><strong>Note</strong>: Like most web storage solutions, IndexedDB follows a <a class="external" href="https://www.w3.org/Security/wiki/Same_Origin_Policy">same-origin policy</a>. So while you can access stored data within a domain, you cannot access data across different domains.</p>
-</div>
-
-<h3 id="Synchronous_and_asynchronous">Synchronous and asynchronous</h3>
-
-<p>Operations performed using IndexedDB are done asynchronously, so as not to block applications. IndexedDB originally included both synchronous and asynchronous APIs. The synchronous API was intended for use only with <a href="/en-US/docs/Web/Guide/Performance/Using_web_workers">Web Workers</a> but was removed from the spec because it was unclear whether it was needed. However, the synchronous API may be reintroduced if there is enough demand from web developers.</p>
-
-<h3 id="Storage_limits_and_eviction_criteria">Storage limits and eviction criteria</h3>
-
-<p>There are a number of web technologies that store data of one kind or another on the client side (i.e. on your local disk). IndexedDB is most commonly talked about. The process by which the browser works out how much space to allocate to web data storage and what to delete when that limit is reached is not simple, and differs between browsers. <a href="/en-US/docs/Web/API/IndexedDB_API/Browser_storage_limits_and_eviction_criteria">Browser storage limits and eviction criteria</a> attempts to explain how this works, at least in the case of Firefox.</p>
-
-<h2 id="Interfaces">Interfaces</h2>
-
-<p>To get access to a database, call <a href="/en-US/docs/Web/API/IDBFactory.open"><code>open()</code></a> on the <a href="/en-US/docs/Web/API/IDBEnvironment.indexedDB"><code>indexedDB</code></a> attribute of a <a href="/en-US/docs/DOM/window">window</a> object. This method returns an {{domxref("IDBRequest")}} object; asynchronous operations communicate to the calling application by firing events on {{domxref("IDBRequest")}} objects.</p>
-
-<h3 id="Connecting_to_a_database">Connecting to a database</h3>
-
-<dl>
- <dt>{{domxref("IDBEnvironment")}}</dt>
- <dd>Provides access to IndexedDB functionality. It is implemented by the {{domxref("window")}} and {{domxref("worker")}} objects. This interface isn't part of the 2.0 specification.</dd>
- <dt>{{domxref("IDBFactory")}}</dt>
- <dd>Provides access to a database. This is the interface implemented by the global object {{domxref("WindowOrWorkerGlobalScope/indexedDB", "indexedDB")}} and is therefore the entry point for the API.</dd>
- <dt>{{domxref("IDBOpenDBRequest")}}</dt>
- <dd>Represents a request to open a database.</dd>
- <dt>{{domxref("IDBDatabase")}}</dt>
- <dd>Represents a connection to a database. It's the only way to get a transaction on the database.</dd>
-</dl>
-
-<h3 id="Retrieving_and_modifying_data">Retrieving and modifying data</h3>
-
-<dl>
- <dt>{{domxref("IDBTransaction")}}</dt>
- <dd>Represents a transaction. You create a transaction on a database, specify the scope (such as which object stores you want to access), and determine the kind of access (read only or readwrite) that you want.</dd>
- <dt>{{domxref("IDBRequest")}}</dt>
- <dd>Generic interface that handles database requests and provides access to results.</dd>
- <dt>{{domxref("IDBObjectStore")}}</dt>
- <dd>Represents an object store that allows access to a set of data in an IndexedDB database, looked up via primary key.</dd>
- <dt>{{domxref("IDBIndex")}}</dt>
- <dd>Also allows access to a subset of data in an IndexedDB database, but uses an index to retrieve the record(s) rather than the primary key. This is sometimes faster than using {{domxref("IDBObjectStore")}}.</dd>
- <dt>{{domxref("IDBCursor")}}</dt>
- <dd>Iterates over object stores and indexes.</dd>
- <dt>{{domxref("IDBCursorWithValue")}}</dt>
- <dd>Iterates over object stores and indexes and returns the cursor's current value.</dd>
- <dt>{{domxref("IDBKeyRange")}}</dt>
- <dd>Defines a key range that can be used to retrieve data from a database in a certain range.</dd>
- <dt>{{domxref("IDBLocaleAwareKeyRange")}} {{Non-standard_inline}}</dt>
- <dd>Defines a key range that can be used to retrieve data from a database in a certain range, sorted according to the rules of the locale specified for a certain index (see <a href="/en-US/docs/Web/API/IDBObjectStore/createIndex#Parameters"><code>createIndex()</code>'s optionalParameters</a>.). This interface isn't part of the 2.0 specification.</dd>
-</dl>
-
-<h3 id="Custom_event_interfaces">Custom event interfaces</h3>
-
-<p>This specification fires events with the following custom interface:</p>
-
-<dl>
- <dt>{{domxref("IDBVersionChangeEvent")}}</dt>
- <dd>The <code>IDBVersionChangeEvent</code> interface indicates that the version of the database has changed, as the result of an {{domxref("IDBOpenDBRequest.onupgradeneeded")}} event handler function.</dd>
-</dl>
-
-<h3 id="Obsolete_interfaces">Obsolete interfaces</h3>
-
-<p>An early version of the specification also defined the following, now removed, interfaces. They are still documented in case you need to update previously written code:</p>
-
-<dl>
- <dt>{{domxref("IDBVersionChangeRequest")}} {{obsolete_inline}}</dt>
- <dd>Represents a request to change the version of a database. The way to change the version of the database has since changed (by calling {{domxref("IDBFactory.open")}} without also calling {{domxref("IDBDatabase.setVersion")}}), and the interface {{domxref("IDBOpenDBRequest")}} now has the functionality of the removed {{domxref("IDBVersionChangeRequest")}}.</dd>
- <dt>{{domxref("IDBDatabaseException")}}  {{obsolete_inline}}</dt>
- <dd>Represents exception conditions that can be encountered while performing database operations.</dd>
- <dt>{{domxref("IDBTransactionSync")}} {{obsolete_inline}}</dt>
- <dd>Sync version of {{domxref("IDBTransaction")}}.</dd>
- <dt>{{domxref("IDBObjectStoreSync")}} {{obsolete_inline}}</dt>
- <dd>Sync version of {{domxref("IDBObjectStore")}}.</dd>
- <dt>{{domxref("IDBIndexSync")}} {{obsolete_inline}}</dt>
- <dd>Sync version of {{domxref("IDBIndex")}}.</dd>
- <dt>{{domxref("IDBFactorySync")}} {{obsolete_inline}}</dt>
- <dd>Sync version of {{domxref("IDBFactory")}}.</dd>
- <dt>{{domxref("IDBEnvironmentSync")}} {{obsolete_inline}}</dt>
- <dd>Sync version of {{domxref("IDBEnvironment")}}.</dd>
- <dt>{{domxref("IDBDatabaseSync")}} {{obsolete_inline}}</dt>
- <dd>Sync version of {{domxref("IDBDatabase")}}.</dd>
- <dt>{{domxref("IDBCursorSync")}} {{obsolete_inline}}</dt>
- <dd>Sync version of {{domxref("IDBCursor")}}.</dd>
-</dl>
-
-<h2 id="Examples">Examples</h2>
-
-<ul>
- <li><a class="external" href="https://marco-c.github.io/eLibri/">eLibri:</a> A powerful library and eBook reader application, written by Marco Castelluccio, winner of the IndexedDB Mozilla DevDerby.</li>
- <li><a class="external" href="https://github.com/chrisdavidmills/to-do-notifications/tree/gh-pages">To-do Notifications</a> (<a class="external" href="https://mdn.github.io/to-do-notifications/">view example live</a>): The reference application for the examples in the reference docs.</li>
- <li><a class="external" href="https://hacks.mozilla.org/2012/02/storing-images-and-files-in-indexeddb/">Storing images and files in IndexedDB</a></li>
-</ul>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>{{SpecName("IndexedDB 2")}}</td>
- <td>{{Spec2("IndexedDB 2")}}</td>
- <td></td>
- </tr>
- <tr>
- <td>{{SpecName('IndexedDB')}}</td>
- <td>{{Spec2('IndexedDB')}}</td>
- <td>Initial definition</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li><a class="external" href="https://localforage.github.io/localForage/">localForage</a>: A Polyfill providing a simple name:value syntax for client-side data storage, which uses IndexedDB in the background, but falls back to WebSQL and then localStorage in browsers that don't support IndexedDB.</li>
- <li><a class="external" href="https://www.dexie.org/">Dexie.js</a>: A wrapper for IndexedDB that allows much faster code development via nice, simple syntax.</li>
- <li><a href="https://github.com/erikolson186/zangodb">ZangoDB</a>: A MongoDB-like interface for IndexedDB that supports most of the familiar filtering, projection, sorting, updating and aggregation features of MongoDB.</li>
- <li><a href="https://jsstore.net/">JsStore</a>: An IndexedDB wrapper with SQL like syntax.</li>
- <li><a href="https://github.com/mWater/minimongo">MiniMongo</a>: A client-side in-memory mongodb backed by localstorage with server sync over http. MiniMongo is used by MeteorJS.</li>
- <li><a href="https://pouchdb.com">PouchDB</a>: A client-side implementation of CouchDB in the browser using IndexedDB</li>
- <li><a href="https://www.npmjs.com/package/idb">idb</a>: A tiny (~1.15k) library that mostly mirrors the IndexedDB API, but with small improvements that make a big difference to usability.</li>
- <li><a href="https://www.npmjs.com/package/idb-keyval">idb-keyval</a>: A super-simple-small (~600B) promise-based keyval store implemented with IndexedDB</li>
- <li><a href="https://www.npmjs.com/package/@sifrr/storage">sifrr-storage:</a> A small (~2kB) promise based library for client side key-value storage. Works with IndexedDB, localStorage, WebSQL, Cookies. Can automatically use supported storage available based on priority.</li>
- <li><a href="https://github.com/google/lovefield">lovefield</a>: <span class="mr-2 text-gray-dark">Lovefield is a relational database for web apps. Written in JavaScript, works cross-browser. Provides SQL-like APIs that are fast, safe, and easy to use.</span></li>
-</ul>
diff --git a/files/he/web/api/storage/clear/index.html b/files/he/web/api/storage/clear/index.html
deleted file mode 100644
index f93b7cf4a4..0000000000
--- a/files/he/web/api/storage/clear/index.html
+++ /dev/null
@@ -1,52 +0,0 @@
----
-title: Storage.clear()
-slug: Web/API/Storage/clear
-translation_of: Web/API/Storage/clear
----
-<p>{{APIRef("Web Storage API")}}</p>
-
-<p>פונקציית <strong><code>()clear</code></strong> מאפשרת לנקות את כל המפתחות מהאחסון המקומי.</p>
-
-<h2 id="תחביר">תחביר</h2>
-
-<pre class="brush: js"><em>storage</em>.clear();</pre>
-
-<h3 id="ערך_חוזר">ערך חוזר</h3>
-
-<p>undefined.</p>
-
-<h2 id="דוגמאות">דוגמאות</h2>
-
-<p><font><font>הפונקציה הבאה יוצרת שלושה פריטים באחסון המקומי, ולאחר מכן מוחקת אותם.</font></font></p>
-
-<pre class="brush: js">function populateStorage() {
- localStorage.setItem('bgcolor', 'red');
- localStorage.setItem('font', 'Helvetica');
- localStorage.setItem('image', 'miGato.png');
-
- localStorage.clear();
-}
-</pre>
-
-<h2 id="מפרט">מפרט</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('HTML WHATWG', 'webstorage.html#dom-storage-clear', 'Storage.clear')}}</td>
- <td>{{Spec2('HTML WHATWG')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תאימות_דפדפן">תאימות דפדפן</h2>
-
-
-
-<p>{{Compat("api.Storage.clear")}}</p>
diff --git a/files/he/web/api/storage/getitem/index.html b/files/he/web/api/storage/getitem/index.html
deleted file mode 100644
index d18fcf9d3d..0000000000
--- a/files/he/web/api/storage/getitem/index.html
+++ /dev/null
@@ -1,75 +0,0 @@
----
-title: localStorage.getItem()
-slug: Web/API/Storage/getItem
-translation_of: Web/API/Storage/getItem
----
-<p>{{APIRef("Web Storage API")}}</p>
-
-<p> </p>
-
-<p>פונקציית <strong><code>()getItem</code></strong> מאפשרת לאחזר נתונים מהאחסון המקומי באמצעות שם המפתח.<br>
- במידה והמפתח שרוצים לאחזר אינו קיים באחסון המקומי, יוחזר הערך null.</p>
-
-<h2 id="תחביר">תחביר</h2>
-
-<pre class="syntaxbox">var <em>aValue</em> = localStorage.getItem(<em>keyName</em>);
-</pre>
-
-<h3 id="פרמטרים">פרמטרים</h3>
-
-<dl>
- <dt><em><code>keyName</code></em></dt>
- <dd>שם המפתח אותו רוצים לאחזר.</dd>
-</dl>
-
-<h3 id="ערך_חוזר">ערך חוזר</h3>
-
-<p>במידה והמפתח קיים באחסון המקומי הוא יחזיר את ערכו. במידה והמפתח אינו קיים יוחזר הערך null.</p>
-
-<h2 id="דוגמאות">דוגמאות</h2>
-
-<p>הפונקציה הבאה מאחזרת שלושה פריטי נתונים מהאחסון המקומי ולאחר מכן משתמשת בהם כדי להגדיר גיליונות סגנון מדורגים.</p>
-
-<pre class="brush: js">function setStyles() {
- var currentColor = localStorage.getItem('bgcolor');
- var currentFont = localStorage.getItem('font');
- var currentImage = localStorage.getItem('image');
-
- currentColor = document.getElementById('bgcolor').value;
- currentFont = document.getElementById('font').value;
- currentImage = document.getElementById('image').value;
-
- htmlElem.style.backgroundColor = '#' + currentColor;
- pElem.style.fontFamily = currentFont;
- imgElem.setAttribute('src', currentImage);
-}</pre>
-
-<h2 id="מפרט">מפרט</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('HTML WHATWG', 'webstorage.html#dom-storage-getitem', 'Storage.getItem')}}</td>
- <td>{{Spec2('HTML WHATWG')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תאימות_דפדפן">תאימות דפדפן</h2>
-
-
-
-<p>{{Compat("api.Storage.getItem")}}</p>
-
-<h2 id="ראו_גם">ראו גם</h2>
-
-<ul>
- <li><a href="https://developer.mozilla.org/he/docs/Web/API/Storage/setItem">()Storage.setItem </a></li>
- <li><a href="/he/docs/Web/API/Storage/removeItem">()Storage.removeItem</a></li>
-</ul>
diff --git a/files/he/web/api/storage/index.html b/files/he/web/api/storage/index.html
deleted file mode 100644
index b89a1ef6a2..0000000000
--- a/files/he/web/api/storage/index.html
+++ /dev/null
@@ -1,107 +0,0 @@
----
-title: Storage
-slug: Web/API/Storage
-tags:
- - API
- - Interface
- - NeedsTranslation
- - Reference
- - Storage
- - TopicStub
- - Web Storage
- - data
-translation_of: Web/API/Storage
----
-<p>{{APIRef("Web Storage API")}}</p>
-
-<p>The <code>Storage</code> interface of the Web Storage API provides access to a particular domain's session or local storage. It allows, for example, the addition, modification, or deletion of stored data items.</p>
-
-<p>To manipulate, for instance, the session storage for a domain, a call to the {{domxref("Window.sessionStorage")}} is made; whereas for local storage the call is made to {{domxref("Window.localStorage")}}.</p>
-
-<h2 id="Properties">Properties</h2>
-
-<dl>
- <dt>{{domxref("Storage.length")}} {{readonlyInline}}</dt>
- <dd>Returns an integer representing the number of data items stored in the <code>Storage</code> object.</dd>
-</dl>
-
-<h2 id="Methods">Methods</h2>
-
-<dl>
- <dt>{{domxref("Storage.key()")}}</dt>
- <dd>When passed a number n, this method will return the name of the nth key in the storage.</dd>
-</dl>
-
-<dl>
- <dt>{{domxref("Storage.getItem()")}}</dt>
- <dd>When passed a key name, will return that key's value.</dd>
- <dt>{{domxref("Storage.setItem()")}}</dt>
- <dd>When passed a key name and value, will add that key to the storage, or update that key's value if it already exists.</dd>
- <dt>{{domxref("Storage.removeItem()")}}</dt>
- <dd>When passed a key name, will remove that key from the storage.</dd>
- <dt>{{domxref("Storage.clear()")}}</dt>
- <dd>When invoked, will empty all keys out of the storage.</dd>
-</dl>
-
-<h2 id="Examples">Examples</h2>
-
-<p>Here we access a <code>Storage</code> object by calling <code>localStorage</code>. We first test whether the local storage contains data items using <code>!localStorage.getItem('bgcolor')</code>. If it does, we run a function called <code>setStyles()</code> that grabs the data items using {{domxref("Storage.getItem()")}} and uses those values to update page styles. If it doesn't, we run another function, <code>populateStorage()</code>, which uses {{domxref("Storage.setItem()")}} to set the item values, then runs <code>setStyles()</code>.</p>
-
-<pre class="brush: js">if(!localStorage.getItem('bgcolor')) {
- populateStorage();
-}
-setStyles();
-
-function populateStorage() {
- localStorage.setItem('bgcolor', document.getElementById('bgcolor').value);
- localStorage.setItem('font', document.getElementById('font').value);
- localStorage.setItem('image', document.getElementById('image').value);
-}
-
-function setStyles() {
- var currentColor = localStorage.getItem('bgcolor');
- var currentFont = localStorage.getItem('font');
- var currentImage = localStorage.getItem('image');
-
- document.getElementById('bgcolor').value = currentColor;
- document.getElementById('font').value = currentFont;
- document.getElementById('image').value = currentImage;
-
- htmlElem.style.backgroundColor = '#' + currentColor;
- pElem.style.fontFamily = currentFont;
- imgElem.setAttribute('src', currentImage);
-}</pre>
-
-<div class="note">
-<p><strong>Note</strong>: To see this running as a complete working example, see our <a href="https://mdn.github.io/dom-examples/web-storage/">Web Storage Demo</a>.</p>
-</div>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('HTML WHATWG', 'webstorage.html#the-storage-interface', 'Storage')}}</td>
- <td>{{Spec2('HTML WHATWG')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-
-
-<p>{{Compat("api.Storage")}}</p>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li><a href="/en-US/docs/Web/API/Web_Storage_API/Using_the_Web_Storage_API">Using the Web Storage API</a></li>
- <li><a href="/en-US/docs/Web/API/Window/localStorage">Window.localStorage</a></li>
-</ul>
diff --git a/files/he/web/api/storage/key/index.html b/files/he/web/api/storage/key/index.html
deleted file mode 100644
index 9dfce0e52b..0000000000
--- a/files/he/web/api/storage/key/index.html
+++ /dev/null
@@ -1,55 +0,0 @@
----
-title: Storage.key()
-slug: Web/API/Storage/key
-translation_of: Web/API/Storage/key
----
-<p>{{APIRef("Web Storage API")}}</p>
-
-<p>פונקציית <strong><code>()key</code></strong> מאפשרת לאחזר את שם המפתח באמצעות אינדקס.</p>
-
-<h2 id="תחביר">תחביר</h2>
-
-<pre class="syntaxbox">var <em>aKeyName</em> = <em>storage</em>.key(<em>index</em>);</pre>
-
-<h3 id="פרמטרים">פרמטרים</h3>
-
-<dl>
- <dt><em>index</em></dt>
- <dd>מספר שלם המייצג את מיקום המפתח שברצוננו לאחזר.</dd>
-</dl>
-
-<h3 id="ערך_חוזר">ערך חוזר</h3>
-
-<p>במידה והמפתח קיים באחסון המקומי הוא יחזיר את שמו. במידה והמפתח אינו קיים יוחזר הערך null.</p>
-
-<h2 id="דוגמאות">דוגמאות</h2>
-
-<p>הפונקציה הבאה חוזרת על פריטי האחסון המקומיים ומקבלת את הערך שהוגדר עבור כל מפתח:</p>
-
-<pre class="brush: js">for(var i =0; i &lt; localStorage.length; i++){
-   console.log(localStorage.getItem(localStorage.key(i)));
-}
-</pre>
-
-<h2 id="מפרט">מפרט</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('HTML WHATWG', 'webstorage.html#dom-storage-key', 'Storage.key')}}</td>
- <td>{{Spec2('HTML WHATWG')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-
-
-<p>{{Compat("api.Storage.key")}}</p>
diff --git a/files/he/web/api/storage/length/index.html b/files/he/web/api/storage/length/index.html
deleted file mode 100644
index 6939e0bd1f..0000000000
--- a/files/he/web/api/storage/length/index.html
+++ /dev/null
@@ -1,51 +0,0 @@
----
-title: Storage.length
-slug: Web/API/Storage/length
-translation_of: Web/API/Storage/length
----
-<p>{{APIRef("Web Storage API")}}</p>
-
-<p>המאפיין <strong><code>length</code></strong> מאפשר לאחזר את מספר כל הפריטים שנמצאים באחסון המקומי ולהציגם באמצעות מספר שלם.</p>
-
-<h2 id="תחביר">תחביר</h2>
-
-<pre class="syntaxbox">var <em>aLength</em> = <em>Storage</em>.length;</pre>
-
-<h3 id="ערך_חוזר">ערך חוזר</h3>
-
-<p>מספר שלם.</p>
-
-<h2 id="דוגמאות">דוגמאות</h2>
-
-<p>הפונקציה הבאה מוסיפה שלושה פריטים לאחסון המקומי ולאחר מכן מחזירה את מספר כל הפריטים שנמצאים באחסון המקומי:</p>
-
-<pre class="brush: js">function populateStorage() {
- localStorage.setItem('bgcolor', 'yellow');
- localStorage.setItem('font', 'Helvetica');
- localStorage.setItem('image', 'cats.png');
-
- localStorage.length; // should return 3
-}</pre>
-
-<h2 id="מפרט">מפרט</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('HTML WHATWG', 'webstorage.html#dom-storage-length', 'Storage.length')}}</td>
- <td>{{Spec2('HTML WHATWG')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תאימות_דפדפן">תאימות דפדפן</h2>
-
-
-
-<p>{{Compat("api.Storage.length")}}</p>
diff --git a/files/he/web/api/storage/removeitem/index.html b/files/he/web/api/storage/removeitem/index.html
deleted file mode 100644
index 5760eae6b3..0000000000
--- a/files/he/web/api/storage/removeitem/index.html
+++ /dev/null
@@ -1,66 +0,0 @@
----
-title: Storage.removeItem()
-slug: Web/API/Storage/removeItem
-translation_of: Web/API/Storage/removeItem
----
-<p>{{APIRef("Web Storage API")}}</p>
-
-<p>פונקציית <strong><code>()removeItem</code></strong> מאפשרת לאחזר נתונים מהאחסון המקומי באמצעות שם המפתח.<br>
- ובמידה ושם המפתח לא קיים באחסון המקומי לא יבוצעו שינויים.</p>
-
-<h2 id="תחביר">תחביר</h2>
-
-<pre class="syntaxbox"><em>storage</em>.removeItem(<em>keyName</em>);</pre>
-
-<h3 id="פרמטרים">פרמטרים</h3>
-
-<dl>
- <dt><em><u>keyName</u></em></dt>
- <dd>שם המפתח אותו רוצים למחוק.</dd>
-</dl>
-
-<h3 id="ערך_חוזר">ערך חוזר</h3>
-
-<p>חלל ריק.</p>
-
-<h2 id="דוגמאות">דוגמאות</h2>
-
-<p>הפונקציה הבאה יוצרת שלושה פריטים בתוך האחסון המקומי ולאחר מכן מסירה את פריט התמונה מהאחסון המקומי.</p>
-
-<pre class="brush: js">function populateStorage() {
- localStorage.setItem('bgcolor', 'red');
- localStorage.setItem('font', 'Helvetica');
- localStorage.setItem('image', 'myCat.png');
-
- localStorage.removeItem('image');
-}</pre>
-
-<h2 id="מפרט">מפרט</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('HTML WHATWG', 'webstorage.html#dom-storage-removeitem', 'Storage.removeItem')}}</td>
- <td>{{Spec2('HTML WHATWG')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תאימות_דפדפן">תאימות דפדפן</h2>
-
-
-
-<p>{{Compat("api.Storage.removeItem")}}</p>
-
-<h2 id="ראו_גם">ראו גם</h2>
-
-<ul>
- <li><a href="https://developer.mozilla.org/he/docs/Web/API/Storage/setItem">()Storage.setItem </a></li>
- <li><a href="/he/docs/Web/API/Storage/getItem">()Storage.getItem</a></li>
-</ul>
diff --git a/files/he/web/api/storage/setitem/index.html b/files/he/web/api/storage/setitem/index.html
deleted file mode 100644
index 84225ee467..0000000000
--- a/files/he/web/api/storage/setitem/index.html
+++ /dev/null
@@ -1,69 +0,0 @@
----
-title: Storage.setItem()
-slug: Web/API/Storage/setItem
-translation_of: Web/API/Storage/setItem
----
-<p>{{APIRef("Web Storage API")}}<br>
- פונקציית <strong><code>()setItem</code></strong> מאפשרת להוסיף נתונים אל האחסון המקומי באמצעות שני פרמטרים: שם מפתח וערך שאותם תיצור או תעדכן במידה וקיימים.</p>
-
-<h2 id="תחביר">תחביר</h2>
-
-<pre class="syntaxbox"><em>storage</em>.setItem(<em>keyName</em>, <em>keyValue</em>);</pre>
-
-<h3 id="פרמטרים">פרמטרים</h3>
-
-<dl>
- <dt><code>keyName</code></dt>
- <dd>מכיל את שמו של המפתח אותו יש ליצור או לעדכן.</dd>
- <dt><code>keyValue</code></dt>
- <dd>מכיל את שם הערך שיתווסף למפתח אותו אנו יוצרים או מעדכנים.</dd>
-</dl>
-
-<h3 id="ערך_חוזר">ערך חוזר</h3>
-
-<p><code>undefined</code>.</p>
-
-<h3 id="החרגות">החרגות</h3>
-
-<p>במידה והאחסון מלא המערכות עשויה לנקות נתונים מהאחסון המקומי.<br>
- בגרסה הניידת של דפדפן Safari, במידה והמשתמש נכנס אל מצב פרטי המערכת אינה שומרת נתונים באחסון המקומי ומסירה אותם באופן אוטומטי בשל מגבלת גודל של 0 בתים.</p>
-
-<h2 id="דוגמאות">דוגמאות</h2>
-
-<p>הפונקציה הבאה יוצרת שלושה פריטי נתונים בתוך האחסון המקומי.</p>
-
-<pre class="brush: js">function populateStorage() {
- localStorage.setItem('bgcolor', 'red');
- localStorage.setItem('font', 'Helvetica');
- localStorage.setItem('image', 'myCat.png');
-}</pre>
-
-<h2 id="מפרט">מפרט</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('HTML WHATWG', 'webstorage.html#dom-storage-setitem', 'Storage.setItem')}}</td>
- <td>{{Spec2('HTML WHATWG')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תאימות_דפדפן">תאימות דפדפן</h2>
-
-
-
-<p>{{Compat("api.Storage.setItem")}}</p>
-
-<h2 id="ראו_גם">ראו גם</h2>
-
-<ul>
- <li><a href="/he/docs/Web/API/Storage/getItem">()Storage.getItem</a></li>
- <li><a href="/he/docs/Web/API/Storage/removeItem">()Storage.removeItem</a></li>
-</ul>
diff --git a/files/he/web/api/web_storage_api/index.html b/files/he/web/api/web_storage_api/index.html
deleted file mode 100644
index 51a64e09b3..0000000000
--- a/files/he/web/api/web_storage_api/index.html
+++ /dev/null
@@ -1,111 +0,0 @@
----
-title: ממשק פיתוח היישומים Web Storage
-slug: Web/API/Web_Storage_API
-translation_of: Web/API/Web_Storage_API
----
-<div style="direction: ltr !important;">{{DefaultAPISidebar("Web Storage API")}}</div>
-
-<p>The <strong>Web Storage API</strong> provides mechanisms by which browsers can store key/value pairs, in a much more intuitive fashion than using {{glossary("cookie", "cookies")}}.</p>
-
-<h2 id="Web_Storage_concepts_and_usage">Web Storage concepts and usage</h2>
-
-<p>The two mechanisms within Web Storage are as follows:</p>
-
-<ul>
- <li><code>sessionStorage</code> maintains a separate storage area for each given origin that's available for the duration of the page session (as long as the browser is open, including page reloads and restores)
-
- <ul>
- <li>Stores data only for a session, meaning that the data is stored until the browser (or tab) is closed.</li>
- <li>Data is never transferred to the server.</li>
- <li>Storage limit is larger than a cookie (at most 5MB).</li>
- </ul>
- </li>
- <li><code>localStorage</code> does the same thing, but persists even when the browser is closed and reopened.
- <ul>
- <li>Stores data with no expiration date, and gets cleared only through JavaScript, or clearing the Browser cache / Locally Stored Data.</li>
- <li>Storage limit is the maximum amongst the three.</li>
- </ul>
- </li>
-</ul>
-
-<p>These mechanisms are available via the {{domxref("Window.sessionStorage")}} and {{domxref("Window.localStorage")}} properties (to be more precise, in supporting browsers the <code>Window</code> object implements the <code>WindowLocalStorage</code> and <code>WindowSessionStorage</code> objects, which the <code>localStorage</code> and <code>sessionStorage</code> properties hang off) — invoking one of these will create an instance of the {{domxref("Storage")}} object, through which data items can be set, retrieved and removed. A different Storage object is used for the <code>sessionStorage</code> and <code>localStorage</code> for each origin — they function and are controlled separately.</p>
-
-<div class="note">
-<p><strong>Note</strong>: From Firefox 45 onwards, when the browser crashes/restarts, the amount of data saved per origin is limited to 10MB. This has been done to avoid memory issues caused by excessive usage of web storage.</p>
-</div>
-
-<div class="note">
-<p><strong>Note</strong>: Access to Web Storage from third-party IFrames is denied if the user has <a href="https://support.mozilla.org/en-US/kb/disable-third-party-cookies">disabled third-party cookies</a> (Firefox implements this behaviour from <a href="/en-US/docs/Mozilla/Firefox/Releases/43">version 43</a> onwards.)</p>
-</div>
-
-<div class="note">
-<p><strong>Note:</strong> Web Storage is not the same as <a href="/en-US/docs/Storage" title="Storage">mozStorage</a> (Mozilla's XPCOM interfaces to SQLite) or the <a href="/en-US/docs/Session_store_API" title="Session_store_API">Session store API</a> (an <a href="/en-US/docs/XPCOM" title="XPCOM">XPCOM</a> storage utility for use by extensions).</p>
-</div>
-
-<h2 id="Web_Storage_interfaces">Web Storage interfaces</h2>
-
-<dl>
- <dt>{{domxref("Storage")}}</dt>
- <dd>Allows you to set, retrieve and remove data for a specific domain and storage type (session or local.)</dd>
- <dt>{{domxref("Window")}}</dt>
- <dd>The Web Storage API extends the {{domxref("Window")}} object with two new properties — {{domxref("Window.sessionStorage")}} and {{domxref("Window.localStorage")}} — which provide access to the current domain's session and local {{domxref("Storage")}} objects respectively, and a {{domxref("Window.onstorage")}} event handler that fires when a storage area changes (e.g. a new item is stored.)</dd>
- <dt>{{domxref("StorageEvent")}}</dt>
- <dd>The <code title="event-storage">storage</code> event is fired on a document's <code>Window</code> object when a storage area changes.</dd>
-</dl>
-
-<h2 id="Examples">Examples</h2>
-
-<p>To illustrate some typical web storage usage, we have created a simple example, imaginatively called <a href="https://github.com/mdn/dom-examples/tree/master/web-storage">Web Storage Demo</a>. The <a href="https://mdn.github.io/dom-examples/web-storage/">landing page</a> provides controls that can be used to customize the colour, font and decorative image. When you choose different options, the page is instantly updated; in addition your choices are stored in <code>localStorage</code>, so that when you leave the page then load it again later on your choices are remembered.</p>
-
-<p>In addition, we have provided an <a href="https://mdn.github.io/dom-examples/web-storage/event.html">event output page</a> — if you load this page in another tab, then make changes to your choices in the landing page, you'll see the updated storage information outputted as the {{domxref("StorageEvent")}} is fired.</p>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('HTML WHATWG', 'webstorage.html#webstorage')}}</td>
- <td>{{Spec2('HTML WHATWG')}}</td>
- <td></td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-<h3 id="Window.localStorage"><code>Window.localStorage</code></h3>
-
-<div>
-
-
-<p>{{Compat("api.Window.localStorage")}}</p>
-
-<h3 id="Window.sessionStorage"><code>Window.sessionStorage</code></h3>
-
-<div>
-<div class="hidden">The compatibility table on this page is generated from structured data. If you'd like to contribute to the data, please check out <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> and send us a pull request.</div>
-
-<p>{{Compat("api.Window.sessionStorage")}}</p>
-</div>
-</div>
-
-<h2 id="Private_Browsing_Incognito_modes">Private Browsing / Incognito modes</h2>
-
-<p>Most modern browsers support a privacy option called 'Incognito', 'Private Browsing' or something similar that doesn't store data like history and cookies. This is fundamentally incompatible with Web Storage for obvious reasons. As such, browser vendors are experimenting with different scenarios for how to deal with this incompatibility.</p>
-
-<p>Most browsers have opted for a strategy where storage APIs are still available and seemingly fully functional, with the one big difference that all stored data is wiped after the browser is closed. For these browsers there are still different interpretations of what should be done with existing stored data (from a regular browsing session). Should it be available to read when in Private mode? Then there are some browsers, most notably Safari, that have opted for a solution where storage is available, but is empty and has a quota of 0 bytes assigned, effectively making it impossible to write data to it.</p>
-
-<p>Developers should be aware of these different implementations and take them into account when developing websites depending on Web Storage APIs. For more information please have a look at <a href="https://blog.whatwg.org/this-week-in-html-5-episode-30">this WHATWG blog post</a> that specifically deals with this topic.</p>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li><a href="/en-US/docs/Web/API/Web_Storage_API/Using_the_Web_Storage_API">Using the Web Storage API</a></li>
- <li><a href="/en-US/docs/Web/API/IndexedDB_API/Browser_storage_limits_and_eviction_criteria">Browser storage limits and eviction criteria</a></li>
- <li><a href="https://medium.com/@ramsunvtech/onfocus-html5-storage-apis-b45d92aa424b">HTML5 Storage API By Venkatraman</a></li>
-</ul>
diff --git a/files/he/web/api/window/alert/index.html b/files/he/web/api/window/alert/index.html
deleted file mode 100644
index 0346b5f73a..0000000000
--- a/files/he/web/api/window/alert/index.html
+++ /dev/null
@@ -1,70 +0,0 @@
----
-title: Window.alert()
-slug: Web/API/Window/alert
-tags:
- - אזהרה
- - חלון הודעה
- - פופ-אפ
-translation_of: Web/API/Window/alert
----
-<p>{{ APIRef }}</p>
-
-<p><strong><code>Window.alert()</code></strong> - מציגה הודעת אזהרה עם תוכן וכפתור לאישור וסגירה.</p>
-
-<h2 id="Syntax" name="Syntax">תחביר</h2>
-
-<pre class="syntaxbox">window.alert(<em>message</em>);</pre>
-
-<h3 id="פרמטרים">פרמטרים</h3>
-
-<dl>
- <dt><code>message</code> {{optional_inline}}</dt>
- <dd>מחרוזת שתופיעה כגוף ההודעה בתיבת הדו-שיח של ההתראה.</dd>
-</dl>
-
-<h2 id="Example" name="Example">דוגמאות</h2>
-
-<pre class="brush: js">window.alert("Hello world!");
-alert("Hello world!");</pre>
-
-<p>שתי הדוגמאות מייצרות את ההודעה הבאה:</p>
-
-<p><img alt="Image:AlertHelloWorld.png" src="/files/130/AlertHelloWorld.png"></p>
-
-<h2 id="Notes" name="Notes">הערות</h2>
-
-<p> </p>
-
-<p>תפקידן של תיבות ההתראה הינן להצגת הודעות שאינן דורשות תגובה מצד המשתמש, מלבד היכרות וקריאת ההודעה.</p>
-
-<p> </p>
-
-<h2 id="Specification" name="Specification">מפרט</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('HTML WHATWG', 'timers-and-user-prompts.html#dom-alert', 'alert()')}}</td>
- <td>{{Spec2('HTML WHATWG')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תאימות_דפדפן">תאימות דפדפן</h2>
-
-
-
-<p>{{Compat("api.Window.alert")}}</p>
-
-<h2 id="See_also" name="See_also">ראה גם</h2>
-
-<ul>
- <li>{{domxref("window.confirm","confirm")}}</li>
- <li>{{domxref("window.prompt","prompt")}}</li>
-</ul>
diff --git a/files/he/web/api/window/confirm/index.html b/files/he/web/api/window/confirm/index.html
deleted file mode 100644
index 54ab3e903a..0000000000
--- a/files/he/web/api/window/confirm/index.html
+++ /dev/null
@@ -1,70 +0,0 @@
----
-title: Window.confirm()
-slug: Web/API/Window/confirm
-tags:
- - אישור הודעה
- - דפדפן
- - הודעה
- - חלון התראה
- - פופ-אפ
-translation_of: Web/API/Window/confirm
----
-<div>{{ApiRef("Window")}}</div>
-
-<div><code><strong>Window.confirm()</strong></code> - מציגה תיבת דו-שיח עם תוכן וכפתורי אישור וביטול.</div>
-
-<h2 id="Syntax" name="Syntax">תחביר</h2>
-
-<pre><em>result</em> = window.confirm(<em>message</em>);
-</pre>
-
-<ul>
- <li><code>message</code> - מחרוזת שתופיע בגוף ההודעה.</li>
- <li><code>result</code> - ערך בוליאני בו מצוינת בחירת המשתמש (אישור או ביטול).</li>
-</ul>
-
-<h2 id="Example" name="Example">דוגמאות</h2>
-
-<pre>if (window.confirm("Do you really want to leave?")) {
- window.open("exit.html", "Thanks for Visiting!");
-}
-</pre>
-
-<p>הדוגמה תציג את ההודעה הבאה:</p>
-
-<p><img alt="firefox confirm" src="https://mdn.mozillademos.org/files/7163/firefoxcomfirmdialog_zpsf00ec381.png" style="height: 119px; width: 354px;"><br>
-  </p>
-
-<h2 id="Notes" name="Notes">הערות</h2>
-
-<p><span class="comment">The following text is shared between this article, DOM:window.prompt and DOM:window.alert</span> תיבות דו-שיח מונעות מהמשתמש גישה לממשק התוכנית עד אשר היא תיסגר.</p>
-
-<h2 id="Specification" name="Specification">מפרט</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('HTML WHATWG', 'timers-and-user-prompts.html#dom-confirm', 'confirm()')}}</td>
- <td>{{Spec2('HTML WHATWG')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תאימות_דפדפן">תאימות דפדפן</h2>
-
-
-
-<p>{{Compat("api.Window.confirm")}}</p>
-
-<h2 id="See_also" name="See_also">ראה גם</h2>
-
-<ul>
- <li>{{domxref("window.alert","alert")}}</li>
- <li>{{domxref("window.prompt","prompt")}}</li>
-</ul>
diff --git a/files/he/web/api/window/index.html b/files/he/web/api/window/index.html
deleted file mode 100644
index c9c96d5672..0000000000
--- a/files/he/web/api/window/index.html
+++ /dev/null
@@ -1,509 +0,0 @@
----
-title: Window
-slug: Web/API/Window
-tags:
- - API
- - DOM
- - Interface
- - JavaScript
- - NeedsTranslation
- - Reference
- - Tab
- - TopicStub
- - Window
-translation_of: Web/API/Window
----
-<div>{{APIRef("DOM")}}</div>
-
-<p><span class="seoSummary">The <strong><code>Window</code></strong> interface represents a window containing a DOM document; the <code>document</code> property points to the <a href="/en-US/docs/DOM/document">DOM document</a> loaded in that window.</span> A window for a given document can be obtained using the {{domxref("document.defaultView")}} property.</p>
-
-<p>A global variable, <code>window</code>, representing the window in which the script is running, is exposed to JavaScript code.</p>
-
-<p>The <code>Window</code> interface is home to a variety of functions, namespaces, objects, and constructors which are not necessarily directly associated with the concept of a user interface window. However, the <code>Window</code> interface is a suitable place to include these items that need to be globally available. Many of these are documented in the  <a href="/en-US/docs/Web/JavaScript/Reference">JavaScript Reference</a> and the <a href="/en-US/docs/Web/API/Document_Object_Model" title="/en-US/docs/Web/API/Document_Object_Model">DOM Reference</a>.</p>
-
-<p>In a tabbed browser, each tab is represented by its own <code>Window</code> object; the global <code>window</code> seen by JavaScript code running within a given tab always represents the tab in which the code is running. That said, even in a tabbed browser, some properties and methods still apply to the overall window that contains the tab, such as {{Domxref("Window.resizeTo", "resizeTo()")}} and {{Domxref("Window.innerHeight", "innerHeight")}}. Generally, anything that can't reasonably pertain to a tab pertains to the window instead.</p>
-
-<p>{{InheritanceDiagram}}</p>
-
-<h2 id="Properties">Properties</h2>
-
-<p><em>This interface inherits properties from the {{domxref("EventTarget")}} interface and implements properties from the {{domxref("WindowOrWorkerGlobalScope")}} and {{domxref("WindowEventHandlers")}} mixins.</em></p>
-
-<p>Note that properties which are objects (e.g.,. for overriding the prototype of built-in elements) are listed in a separate section below.</p>
-
-<dl>
- <dt>{{domxref("Window.closed")}} {{Non-standard_inline}} {{readOnlyInline}}</dt>
- <dd>This property indicates whether the current window is closed or not.</dd>
- <dt>{{domxref("Window.console")}} {{ReadOnlyInline}}</dt>
- <dd>Returns a reference to the console object which provides access to the browser's debugging console.</dd>
- <dt>{{domxref("Window.content")}} and Window._content {{Non-standard_inline}} {{obsolete_inline}} {{ReadOnlyInline}}</dt>
- <dd>Returns a reference to the content element in the current window. Since Firefox 57 (initially Nightly-only), both versions are only available from chrome (privileged) code, and not available to the web anymore.</dd>
- <dt>{{domxref("Window.controllers")}} {{non-standard_inline}} {{ReadOnlyInline}}</dt>
- <dd>Returns the XUL controller objects for the current chrome window.</dd>
- <dt>{{domxref("Window.customElements")}} {{ReadOnlyInline}}</dt>
- <dd>returns a reference to the {{domxref("CustomElementRegistry")}} object, which can be used to register new <a href="/en-US/docs/Web/Web_Components/Using_custom_elements">custom elements</a> and get information about previously registered custom elements.</dd>
- <dt>{{domxref("Window.crypto")}} {{readOnlyInline}}</dt>
- <dd>Returns the browser crypto object.</dd>
- <dt>{{domxref("Window.defaultStatus")}} {{Obsolete_inline("gecko23")}}</dt>
- <dd>Gets/sets the status bar text for the given window.</dd>
- <dt>{{domxref("Window.devicePixelRatio")}} {{non-standard_inline}} {{ReadOnlyInline}}</dt>
- <dd>Returns the ratio between physical pixels and device independent pixels in the current display.</dd>
- <dt>{{domxref("Window.dialogArguments")}} {{ReadOnlyInline}}</dt>
- <dd>Gets the arguments passed to the window (if it's a dialog box) at the time {{domxref("window.showModalDialog()")}} was called. This is an {{Interface("nsIArray")}}.</dd>
- <dt>{{domxref("Window.directories")}} {{obsolete_inline}}</dt>
- <dd>Synonym of {{domxref("window.personalbar")}}</dd>
- <dt>{{domxref("Window.document")}} {{ReadOnlyInline}}</dt>
- <dd>Returns a reference to the document that the window contains.</dd>
- <dt>{{domxref("Window.DOMMatrix")}} {{readOnlyInline}} {{experimental_inline}}</dt>
- <dd>Returns a reference to a {{domxref("DOMMatrix")}} object, which represents 4x4 matrices, suitable for 2D and 3D operations.</dd>
- <dt>{{domxref("Window.DOMMatrixReadOnly")}} {{readOnlyInline}} {{experimental_inline}}</dt>
- <dd>Returns a reference to a {{domxref("DOMMatrixReadOnly")}} object, which represents 4x4 matrices, suitable for 2D and 3D operations.</dd>
- <dt>{{domxref("Window.DOMPoint")}} {{readOnlyInline}} {{experimental_inline}}</dt>
- <dd>Returns a reference to a {{domxref("DOMPoint")}} object, which represents a 2D or 3D point in a coordinate system.</dd>
- <dt>{{domxref("Window.DOMPointReadOnly")}} {{readOnlyInline}} {{experimental_inline}}</dt>
- <dd>Returns a reference to a {{domxref("DOMPointReadOnly")}} object, which represents a 2D or 3D point in a coordinate system.</dd>
- <dt>{{domxref("Window.DOMQuad")}} {{readOnlyInline}} {{experimental_inline}}</dt>
- <dd>Returns a reference to a {{domxref("DOMQuad")}} object, which provides represents a quadrilaterial object, that is one having four corners and four sides.</dd>
- <dt>{{domxref("Window.DOMRect")}} {{readOnlyInline}} {{experimental_inline}}</dt>
- <dd>Returns a reference to a {{domxref("DOMRect")}} object, which represents a rectangle.</dd>
- <dt>{{domxref("Window.DOMRectReadOnly")}} {{readOnlyInline}} {{experimental_inline}}</dt>
- <dd>Returns a reference to a {{domxref("DOMRectReadOnly")}} object, which represents a rectangle.</dd>
- <dt>{{domxref("Window.event")}} {{ReadOnlyInline}}</dt>
- <dd>Returns the <strong>current event</strong>, which is the event currently being handled by the JavaScript code's context, or <code>undefined</code> if no event is currently being handled. The {{domxref("Event")}} object passed directly to event handlers should be used instead whenever possible.</dd>
- <dt>{{domxref("Window.frameElement")}} {{readOnlyInline}}</dt>
- <dd>Returns the element in which the window is embedded, or null if the window is not embedded.</dd>
- <dt>{{domxref("Window.frames")}} {{readOnlyInline}}</dt>
- <dd>Returns an array of the subframes in the current window.</dd>
- <dt>{{domxref("Window.fullScreen")}} {{gecko_minversion_inline("1.9")}}</dt>
- <dd>This property indicates whether the window is displayed in full screen or not.</dd>
- <dt>{{domxref("Window.globalStorage")}} {{gecko_minversion_inline("1.8.1")}} {{Non-standard_inline}} {{Obsolete_inline("gecko13")}}</dt>
- <dd>Unsupported since Gecko 13 (Firefox 13). Use {{domxref("Window.localStorage")}} instead.<br>
- Was: Multiple storage objects that are used for storing data across multiple pages.</dd>
- <dt>{{domxref("Window.history")}} {{ReadOnlyInline}}</dt>
- <dd>Returns a reference to the history object.</dd>
- <dt>{{domxref("Window.innerHeight")}} {{readOnlyInline}}</dt>
- <dd>Gets the height of the content area of the browser window including, if rendered, the horizontal scrollbar.</dd>
- <dt>{{domxref("Window.innerWidth")}} {{readOnlyInline}}</dt>
- <dd>Gets the width of the content area of the browser window including, if rendered, the vertical scrollbar.</dd>
- <dt>{{domxref("Window.isSecureContext")}} {{experimental_inline}} {{readOnlyInline}}</dt>
- <dd>Indicates whether a context is capable of using features that require secure contexts.</dd>
- <dt>{{domxref("Window.length")}} {{readOnlyInline}}</dt>
- <dd>Returns the number of frames in the window. See also {{domxref("window.frames")}}.</dd>
- <dt>{{domxref("Window.location")}}</dt>
- <dd>Gets/sets the location, or current URL, of the window object.</dd>
- <dt>{{domxref("Window.locationbar")}} {{ReadOnlyInline}}</dt>
- <dd>Returns the locationbar object, whose visibility can be toggled in the window.</dd>
- <dt>{{domxref("Window.localStorage")}} {{readOnlyInline}} {{gecko_minversion_inline("1.9.1")}}</dt>
- <dd>Returns a reference to the local storage object used to store data that may only be accessed by the origin that created it.</dd>
- <dt>{{domxref("Window.menubar")}} {{ReadOnlyInline}}</dt>
- <dd>Returns the menubar object, whose visibility can be toggled in the window.</dd>
- <dt>{{domxref("Window.messageManager")}} {{gecko_minversion_inline("2.0")}}</dt>
- <dd>Returns the <a href="/en-US/docs/The_message_manager">message manager</a> object for this window.</dd>
- <dt>{{domxref("Window.mozAnimationStartTime")}} {{ReadOnlyInline}} {{gecko_minversion_inline("2.0")}} {{Deprecated_inline}}</dt>
- <dd>The time in milliseconds since epoch at which the current animation cycle began. Use {{domxref("Animation.startTime")}} instead.</dd>
- <dt>{{domxref("Window.mozInnerScreenX")}} {{ReadOnlyInline}} {{non-standard_inline}} {{gecko_minversion_inline("1.9.2")}}</dt>
- <dd>Returns the horizontal (X) coordinate of the top-left corner of the window's viewport, in screen coordinates. This value is reported in CSS pixels. See <code>mozScreenPixelsPerCSSPixel</code> in {{interface("nsIDOMWindowUtils")}} for a conversion factor to adapt to screen pixels if needed.</dd>
- <dt>{{domxref("Window.mozInnerScreenY")}} {{ReadOnlyInline}} {{non-standard_inline}} {{gecko_minversion_inline("1.9.2")}}</dt>
- <dd>Returns the vertical (Y) coordinate of the top-left corner of the window's viewport, in screen coordinates. This value is reported in CSS pixels. See <code>mozScreenPixelsPerCSSPixel</code> for a conversion factor to adapt to screen pixels if needed.</dd>
- <dt>{{domxref("Window.mozPaintCount")}} {{non-standard_inline}} {{ReadOnlyInline}} {{gecko_minversion_inline("2.0")}}</dt>
- <dd>Returns the number of times the current document has been rendered to the screen in this window. This can be used to compute rendering performance.</dd>
- <dt>{{domxref("Window.name")}}</dt>
- <dd>Gets/sets the name of the window.</dd>
- <dt>{{domxref("Window.navigator")}} {{readOnlyInline}}</dt>
- <dd>Returns a reference to the navigator object.</dd>
- <dt>{{domxref("Window.opener")}}</dt>
- <dd>Returns a reference to the window that opened this current window.</dd>
- <dt>{{domxref("Window.orientation")}} {{non-standard_inline}} {{deprecated_inline}} {{readOnlyInline}}</dt>
- <dd>Returns the orientation in degrees (in 90 degree increments) of the viewport relative to the device's natural orientation.</dd>
- <dt>{{domxref("Window.outerHeight")}} {{readOnlyInline}}</dt>
- <dd>Gets the height of the outside of the browser window.</dd>
- <dt>{{domxref("Window.outerWidth")}} {{readOnlyInline}}</dt>
- <dd>Gets the width of the outside of the browser window.</dd>
- <dt>{{domxref("Window.scrollX","Window.pageXOffset")}} {{readOnlyInline}}</dt>
- <dd>An alias for {{domxref("window.scrollX")}}.</dd>
- <dt>{{domxref("Window.scrollY","Window.pageYOffset")}} {{readOnlyInline}}</dt>
- <dd>An alias for {{domxref("window.scrollY")}}</dd>
- <dt>{{domxref("Window.parent")}} {{readOnlyInline}}</dt>
- <dd>Returns a reference to the parent of the current window or subframe.</dd>
- <dt>{{domxref("Window.performance")}} {{readOnlyInline}}</dt>
- <dd>Returns a {{domxref("Performance")}} object, which includes the {{domxref("Performance.timing", "timing")}} and {{domxref("Performance.navigation", "navigation")}} attributes, each of which is an object providing <a href="/en-US/docs/Navigation_timing">performance-related</a> data. See also <a href="/en-US/docs/Web/API/Navigation_timing_API/Using_Navigation_Timing">Using Navigation Timing</a> for additional information and examples.</dd>
- <dt>{{domxref("Window.personalbar")}} {{readOnlyInline}}</dt>
- <dd>Returns the personalbar object, whose visibility can be toggled in the window.</dd>
- <dt>{{domxref("Window.pkcs11")}} {{obsolete_inline(29)}}</dt>
- <dd>Formerly provided access to install and remove PKCS11 modules.</dd>
- <dt>{{domxref("Window.returnValue")}}</dt>
- <dd>The return value to be returned to the function that called {{domxref("window.showModalDialog()")}} to display the window as a modal dialog.</dd>
- <dt>{{domxref("Window.screen")}} {{readOnlyInline}}</dt>
- <dd>Returns a reference to the screen object associated with the window.</dd>
-
- <dt>{{domxref("Window.screenX")}} {{readOnlyInline}}</dt>
- <dd>Returns the horizontal distance of the left border of the user's browser from the left side of the screen.</dd>
- <dt>{{domxref("Window.screenY")}} {{readOnlyInline}}</dt>
- <dd>Returns the vertical distance of the top border of the user's browser from the top side of the screen.</dd>
- <dt>{{domxref("Window.scrollbars")}} {{readOnlyInline}}</dt>
- <dd>Returns the scrollbars object, whose visibility can be toggled in the window.</dd>
- <dt>{{domxref("Window.scrollMaxX")}} {{non-standard_inline}} {{ReadOnlyInline}}</dt>
- <dd>The maximum offset that the window can be scrolled to horizontally, that is the document width minus the viewport width.</dd>
- <dt>{{domxref("Window.scrollMaxY")}} {{non-standard_inline}} {{ReadOnlyInline}}</dt>
- <dd>The maximum offset that the window can be scrolled to vertically (i.e., the document height minus the viewport height).</dd>
- <dt>{{domxref("Window.scrollX")}} {{readOnlyInline}}</dt>
- <dd>Returns the number of pixels that the document has already been scrolled horizontally.</dd>
- <dt>{{domxref("Window.scrollY")}} {{readOnlyInline}}</dt>
- <dd>Returns the number of pixels that the document has already been scrolled vertically.</dd>
- <dt>{{domxref("Window.self")}} {{ReadOnlyInline}}</dt>
- <dd>Returns an object reference to the window object itself.</dd>
- <dt>{{domxref("Window.sessionStorage")}}</dt>
- <dd>Returns a reference to the session storage object used to store data that may only be accessed by the origin that created it.</dd>
- <dt>{{domxref("Window.sidebar")}} {{non-standard_inline}} {{ReadOnlyInline}}</dt>
- <dd>Returns a reference to the window object of the sidebar.</dd>
- <dt>{{domxref("Window.speechSynthesis")}} {{ReadOnlyInline}}</dt>
- <dd>Returns a {{domxref("SpeechSynthesis")}} object, which is the entry point into using <a href="/en-US/docs/Web/API/Web_Speech_API">Web Speech API</a> speech synthesis functionality.</dd>
- <dt>{{domxref("Window.status")}}</dt>
- <dd>Gets/sets the text in the statusbar at the bottom of the browser.</dd>
- <dt>{{domxref("Window.statusbar")}} {{readOnlyInline}}</dt>
- <dd>Returns the statusbar object, whose visibility can be toggled in the window.</dd>
- <dt>{{domxref("Window.toolbar")}} {{readOnlyInline}}</dt>
- <dd>Returns the toolbar object, whose visibility can be toggled in the window.</dd>
- <dt>{{domxref("Window.top")}} {{readOnlyInline}}</dt>
- <dd>Returns a reference to the topmost window in the window hierarchy. This property is read only.</dd>
- <dt>{{domxref("Window.visualViewport")}} {{readOnlyInline}}</dt>
- <dd>Returns a {{domxref("VisualViewport")}} object which represents the visual viewport for a given window.</dd>
- <dt>{{domxref("Window.window")}} {{ReadOnlyInline}}</dt>
- <dd>Returns a reference to the current window.</dd>
- <dt><code>window[0]</code>,<code> window[1]</code>, etc.</dt>
- <dd>Returns a reference to the <code>window</code> object in the frames. See {{domxref("Window.frames")}} for more details.</dd>
-</dl>
-
-<h3 id="Properties_implemented_from_elsewhere">Properties implemented from elsewhere</h3>
-
-<dl>
- <dt>{{domxref("WindowOrWorkerGlobalScope.caches")}} {{readOnlyinline}}</dt>
- <dd>Returns the {{domxref("CacheStorage")}} object associated with the current context. This object enables functionality such as storing assets for offline use, and generating custom responses to requests.</dd>
- <dt>{{domxref("WindowOrWorkerGlobalScope.indexedDB")}} {{readonlyInline}}</dt>
- <dd>Provides a mechanism for applications to asynchronously access capabilities of indexed databases; returns an {{domxref("IDBFactory")}} object.</dd>
- <dt>{{domxref("WindowOrWorkerGlobalScope.isSecureContext")}} {{readOnlyinline}}</dt>
- <dd>Returns a boolean indicating whether the current context is secure (<code>true</code>) or not (<code>false</code>).</dd>
- <dt>{{domxref("WindowOrWorkerGlobalScope.origin")}} {{readOnlyinline}}</dt>
- <dd>Returns the global object's origin, serialized as a string. (This does not yet appear to be implemented in any browser.)</dd>
-</dl>
-
-<h2 id="Methods">Methods</h2>
-
-<p><em>This interface inherits methods from the {{domxref("EventTarget")}} interface and implements methods from {{domxref("WindowOrWorkerGlobalScope")}} and {{domxref("EventTarget")}}.</em></p>
-
-<dl>
- <dt>{{domxref("Window.alert()")}}</dt>
- <dd>Displays an alert dialog.</dd>
-
- <dt>{{domxref("Window.back()")}} {{Non-standard_inline}} {{obsolete_inline}}</dt>
- <dd>Moves back one in the window history. This method is obsolete; you should instead use {{domxref("History.back", "window.history.back()")}}.</dd>
- <dt>{{domxref("Window.blur()")}}</dt>
- <dd>Sets focus away from the window.</dd>
- <dt>{{domxref("Window.cancelAnimationFrame()")}} {{experimental_inline}}</dt>
- <dd>Enables you to cancel a callback previously scheduled with {{domxref("Window.requestAnimationFrame")}}.</dd>
- <dt>{{domxref("Window.cancelIdleCallback()")}} {{experimental_inline}}</dt>
- <dd>Enables you to cancel a callback previously scheduled with {{domxref("Window.requestIdleCallback")}}.</dd>
- <dt>{{domxref("Window.captureEvents()")}} {{Deprecated_inline}}</dt>
- <dd>Registers the window to capture all events of the specified type.</dd>
- <dt>{{domxref("Window.clearImmediate()")}}</dt>
- <dd>Cancels the repeated execution set using <code>setImmediate</code>.</dd>
- <dt>{{domxref("Window.close()")}}</dt>
- <dd>Closes the current window.</dd>
- <dt>{{domxref("Window.confirm()")}}</dt>
- <dd>Displays a dialog with a message that the user needs to respond to.</dd>
- <dt>{{domxref("Window.disableExternalCapture()")}} {{obsolete_inline(24)}}</dt>
- <dd>{{todo("NeedsContents")}}</dd>
- <dt>{{domxref("Window.dispatchEvent()")}}</dt>
- <dd>Used to trigger an event.</dd>
- <dt>{{domxref("Window.dump()")}} {{Non-standard_inline}}</dt>
- <dd>Writes a message to the console.</dd>
- <dt>{{domxref("Window.enableExternalCapture()")}} {{obsolete_inline(24)}}</dt>
- <dd>{{todo("NeedsContents")}}</dd>
- <dt>{{domxref("Window.find()")}}</dt>
- <dd>Searches for a given string in a window.</dd>
- <dt>{{domxref("Window.focus()")}}</dt>
- <dd>Sets focus on the current window.</dd>
- <dt>{{domxref("Window.forward()")}} {{Non-standard_inline}} {{obsolete_inline}}</dt>
- <dd>Moves the window one document forward in the history. This method is obsolete; you should instead use {{domxref("History.forward", "window.history.forward()")}}.</dd>
- <dt>{{domxref("Window.getAttention()")}} {{Non-standard_inline}} {{obsolete_inline}}</dt>
- <dd>Flashes the application icon.</dd>
- <dt>{{domxref("Window.getAttentionWithCycleCount()")}}</dt>
- <dd>{{todo("NeedsContents")}}</dd>
- <dt>{{domxref("Window.getComputedStyle()")}}</dt>
- <dd>Gets computed style for the specified element. Computed style indicates the computed values of all CSS properties of the element.</dd>
- <dt>{{domxref("Window.getDefaultComputedStyle()")}} {{Non-standard_inline}}</dt>
- <dd>Gets default computed style for the specified element, ignoring author stylesheets.</dd>
- <dt>{{domxref("Window.getSelection()")}}</dt>
- <dd>Returns the selection object representing the selected item(s).</dd>
- <dt>{{domxref("Window.home()")}} {{Non-standard_inline}} {{obsolete_inline}}</dt>
- <dd>Returns the browser to the home page.</dd>
- <dt>{{domxref("Window.matchMedia()")}} {{gecko_minversion_inline("6.0")}}</dt>
- <dd>Returns a {{domxref("MediaQueryList")}} object representing the specified media query string.</dd>
- <dt>{{domxref("Window.maximize()")}}</dt>
- <dd>{{todo("NeedsContents")}}</dd>
- <dt>{{domxref("Window.minimize()")}} (top-level XUL windows only)</dt>
- <dd>Minimizes the window.</dd>
- <dt>{{domxref("Window.moveBy()")}}</dt>
- <dd>Moves the current window by a specified amount.</dd>
- <dt>{{domxref("Window.moveTo()")}}</dt>
- <dd>Moves the window to the specified coordinates.</dd>
- <dt>{{domxref("Window.open()")}}</dt>
- <dd>Opens a new window.</dd>
- <dt>{{domxref("Window.openDialog()")}} {{Non-standard_inline}} {{obsolete_inline}}</dt>
- <dd>Opens a new dialog window.</dd>
- <dt>{{domxref("Window.postMessage()")}}</dt>
- <dd>Provides a secure means for one window to send a string of data to another window, which need not be within the same domain as the first.</dd>
- <dt>{{domxref("Window.print()")}}</dt>
- <dd>Opens the Print Dialog to print the current document.</dd>
- <dt>{{domxref("Window.prompt()")}}</dt>
- <dd>Returns the text entered by the user in a prompt dialog.</dd>
- <dt>{{domxref("Window.releaseEvents()")}} {{Non-standard_inline}} {{Deprecated_inline}}</dt>
- <dd>Releases the window from trapping events of a specific type.</dd>
- <dt>{{domxref("Window.requestAnimationFrame()")}} {{gecko_minversion_inline("2.0")}}</dt>
- <dd>Tells the browser that an animation is in progress, requesting that the browser schedule a repaint of the window for the next animation frame.</dd>
- <dt>{{domxref("Window.requestIdleCallback()")}}  {{experimental_inline}}</dt>
- <dd>Enables the scheduling of tasks during a browser's idle periods.</dd>
- <dt>{{domxref("Window.resizeBy()")}}</dt>
- <dd>Resizes the current window by a certain amount.</dd>
- <dt>{{domxref("Window.resizeTo()")}}</dt>
- <dd>Dynamically resizes window.</dd>
- <dt>{{domxref("Window.restore()")}} {{Non-standard_inline}} {{obsolete_inline}}</dt>
- <dd>{{todo("NeedsContents")}}</dd>
- <dt>{{domxref("Window.routeEvent()")}} {{obsolete_inline(24)}}</dt>
- <dd>{{todo("NeedsContents")}}</dd>
- <dt>{{domxref("Window.scroll()")}}</dt>
- <dd>Scrolls the window to a particular place in the document.</dd>
- <dt>{{domxref("Window.scrollBy()")}}</dt>
- <dd>Scrolls the document in the window by the given amount.</dd>
- <dt>{{domxref("Window.scrollByLines()")}} {{Non-standard_inline}}</dt>
- <dd>Scrolls the document by the given number of lines.</dd>
- <dt>{{domxref("Window.scrollByPages()")}} {{Non-standard_inline}}</dt>
- <dd>Scrolls the current document by the specified number of pages.</dd>
- <dt>{{domxref("Window.scrollTo()")}}</dt>
- <dd>Scrolls to a particular set of coordinates in the document.</dd>
- <dt>{{domxref("Window.setCursor()")}} {{Non-standard_inline}} (top-level XUL windows only)</dt>
- <dd>Changes the cursor for the current window</dd>
- <dt>{{domxref("Window.setImmediate()")}}</dt>
- <dd>Executes a function after the browser has finished other heavy tasks</dd>
- <dt>{{domxref("Window.setResizable()")}} {{Non-standard_inline}}</dt>
- <dd>Toggles a user's ability to resize a window.</dd>
- <dt>{{domxref("Window.sizeToContent()")}} {{Non-standard_inline}}</dt>
- <dd>Sizes the window according to its content.</dd>
- <dt>{{domxref("Window.stop()")}}</dt>
- <dd>This method stops window loading.</dd>
- <dt>{{domxref("Window.updateCommands()")}} {{Non-standard_inline}}</dt>
- <dd>Updates the state of commands of the current chrome window (UI).</dd>
-</dl>
-
-<h3 id="Methods_implemented_from_elsewhere">Methods implemented from elsewhere</h3>
-
-<dl>
- <dt>{{domxref("EventTarget.addEventListener()")}}</dt>
- <dd>Register an event handler to a specific event type on the window.</dd>
- <dt>{{domxref("WindowOrWorkerGlobalScope.atob()")}}</dt>
- <dd>Decodes a string of data which has been encoded using base-64 encoding.</dd>
- <dt>{{domxref("WindowOrWorkerGlobalScope.btoa()")}}</dt>
- <dd>Creates a base-64 encoded ASCII string from a string of binary data.</dd>
- <dt>{{domxref("WindowOrWorkerGlobalScope.clearInterval()")}}</dt>
- <dd>Cancels the repeated execution set using {{domxref("WindowOrWorkerGlobalScope.setInterval()")}}.</dd>
- <dt>{{domxref("WindowOrWorkerGlobalScope.clearTimeout()")}}</dt>
- <dd>Cancels the delayed execution set using {{domxref("WindowOrWorkerGlobalScope.setTimeout()")}}.</dd>
- <dt>{{domxref("WindowOrWorkerGlobalScope.createImageBitmap()")}}</dt>
- <dd>Accepts a variety of different image sources, and returns a {{domxref("Promise")}} which resolves to an {{domxref("ImageBitmap")}}. Optionally the source is cropped to the rectangle of pixels originating at <em>(sx, sy)</em> with width sw, and height sh.</dd>
- <dt>{{domxref("WindowOrWorkerGlobalScope.fetch()")}}</dt>
- <dd>Starts the process of fetching a resource from the network.</dd>
- <dt>{{domxref("EventTarget.removeEventListener")}}</dt>
- <dd>Removes an event listener from the window.</dd>
- <dt>{{domxref("WindowOrWorkerGlobalScope.setInterval()")}}</dt>
- <dd>Schedules a function to execute every time a given number of milliseconds elapses.</dd>
- <dt>{{domxref("WindowOrWorkerGlobalScope.setTimeout()")}}</dt>
- <dd>Schedules a function to execute in a given amount of time.</dd>
-</dl>
-
-<h3 id="Obsolete_methods">Obsolete methods</h3>
-
-<dl>
- <dt>{{domxref("Window.showModalDialog()")}} {{obsolete_inline}}</dt>
- <dd>Displays a modal dialog. <strong>This method was removed completely in Chrome 43, and Firefox 55.</strong></dd>
-</dl>
-
-<h2 id="Event_handlers">Event handlers</h2>
-
-<p>These are properties of the window object that can be set to establish event handlers for the various things that can happen in the window that might be of interest.</p>
-
-<p><em>This interface inherits event handlers from the {{domxref("EventTarget")}} interface and implements event handlers from {{domxref("WindowEventHandlers")}}.</em></p>
-
-<div class="note">
-<p><strong>Note:</strong> Starting in {{Gecko("9.0")}}, you can now use the syntax <code>if ("onabort" in window)</code> to determine whether or not a given event handler property exists. This is because event handler interfaces have been updated to be proper web IDL interfaces. See <a href="/en-US/docs/DOM/DOM_event_handlers">DOM event handlers</a> for details.</p>
-</div>
-
-<dl>
- <dt>{{domxref("Window.onappinstalled")}}</dt>
- <dd>Called when the page is installed as a webapp. See {{event('appinstalled')}} event.</dd>
- <dt>{{domxref("Window.onbeforeinstallprompt")}}</dt>
- <dd>An event handler property dispatched before a user is prompted to save a web site to a home screen on mobile.</dd>
- <dt>{{domxref("Window.ondevicelight")}}</dt>
- <dd>An event handler property for any ambient light levels changes</dd>
- <dt>{{domxref("Window.ondevicemotion")}} {{gecko_minversion_inline("6.0")}}</dt>
- <dd>Called if accelerometer detects a change (For mobile devices)</dd>
- <dt>{{domxref("Window.ondeviceorientation")}} {{gecko_minversion_inline("6.0")}}</dt>
- <dd>Called when the orientation is changed (For mobile devices)</dd>
- <dt>{{domxref("Window.ondeviceorientationabsolute")}} {{non-standard_inline}} Chrome only</dt>
- <dd>An event handler property for any device orientation changes.</dd>
- <dt>{{domxref("Window.ondeviceproximity")}}</dt>
- <dd>An event handler property for device proximity event</dd>
- <dt>{{domxref("Window.ongamepadconnected")}}</dt>
- <dd>Represents an event handler that will run when a gamepad is connected (when the {{event('gamepadconnected')}} event fires).</dd>
- <dt>{{domxref("Window.ongamepaddisconnected")}}</dt>
- <dd>Represents an event handler that will run when a gamepad is disconnected (when the {{event('gamepaddisconnected')}} event fires).</dd>
- <dt>{{domxref("Window.onmozbeforepaint")}} {{gecko_minversion_inline("2.0")}}</dt>
- <dd>An event handler property for the <code>MozBeforePaint</code> event, which is sent before repainting the window if the event has been requested by a call to the {{domxref("Window.mozRequestAnimationFrame()")}} method.</dd>
- <dt>{{domxref("Window.onpaint")}}</dt>
- <dd>An event handler property for paint events on the window.</dd>
- <dt>{{domxref("Window.onrejectionhandled")}} {{experimental_inline}}</dt>
- <dd>An event handler for handled {{jsxref("Promise")}} rejection events.</dd>
- <dt>{{domxref("Window.onuserproximity")}}</dt>
- <dd>An event handler property for user proximity events.</dd>
- <dt>{{domxref("Window.onvrdisplayconnect")}}</dt>
- <dd>Represents an event handler that will run when a compatible VR device has been connected to the computer (when the {{event("vrdisplayconnected")}} event fires).</dd>
- <dt>{{domxref("Window.onvrdisplaydisconnect")}}</dt>
- <dd>Represents an event handler that will run when a compatible VR device has been disconnected from the computer (when the {{event("vrdisplaydisconnected")}} event fires).</dd>
- <dt>{{domxref("Window.onvrdisplayactivate")}}</dt>
- <dd>Represents an event handler that will run when a display is able to be presented to (when the {{event("vrdisplayactivate")}} event fires), for example if an HMD has been moved to bring it out of standby, or woken up by being put on.</dd>
- <dt>{{domxref("Window.onvrdisplaydeactivate")}}</dt>
- <dd>Represents an event handler that will run when a display can no longer be presented to (when the {{event("vrdisplaydeactivate")}} event fires), for example if an HMD has gone into standby or sleep mode due to a period of inactivity.</dd>
- <dt>{{domxref("Window.onvrdisplayblur")}}</dt>
- <dd>Represents an event handler that will run when presentation to a display has been paused for some reason by the browser, OS, or VR hardware (when the {{event("vrdisplayblur")}} event fires) — for example, while the user is interacting with a system menu or browser, to prevent tracking or loss of experience.</dd>
- <dt>{{domxref("Window.onvrdisplayfocus")}}</dt>
- <dd>Represents an event handler that will run when presentation to a display has resumed after being blurred (when the {{event("vrdisplayfocus")}} event fires).</dd>
- <dt>{{domxref("Window.onvrdisplaypresentchange")}}</dt>
- <dd>represents an event handler that will run when the presenting state of a VR device changes — i.e. goes from presenting to not presenting, or vice versa (when the {{event("vrdisplaypresentchange")}} event fires).</dd>
-</dl>
-
-<h3 id="Event_handlers_implemented_from_elsewhere">Event handlers implemented from elsewhere</h3>
-
-<dl>
- <dt>{{domxref("GlobalEventHandlers.onabort")}}</dt>
- <dd>Called when the loading of a resource has been aborted, such as by a user canceling the load while it is still in progress</dd>
- <dt>{{domxref("WindowEventHandlers.onafterprint")}}</dt>
- <dd>Called when the print dialog box is closed. See {{event("afterprint")}} event.</dd>
- <dt>{{domxref("WindowEventHandlers.onbeforeprint")}}</dt>
- <dd>Called when the print dialog box is opened. See {{event("beforeprint")}} event.</dd>
- <dt>{{domxref("WindowEventHandlers.onbeforeunload")}}</dt>
- <dd>An event handler property for before-unload events on the window.</dd>
- <dt>{{domxref("GlobalEventHandlers.onblur")}}</dt>
- <dd>Called after the window loses focus, such as due to a popup.</dd>
- <dt>{{domxref("GlobalEventHandlers.onchange")}}</dt>
- <dd>An event handler property for change events on the window.</dd>
- <dt>{{domxref("GlobalEventHandlers.onclick")}}</dt>
- <dd>Called after the ANY mouse button is pressed &amp; released</dd>
- <dt>{{domxref("GlobalEventHandlers.ondblclick")}}</dt>
- <dd>Called when a double click is made with ANY mouse button.</dd>
- <dt>{{domxref("GlobalEventHandlers.onclose")}}</dt>
- <dd>Called after the window is closed</dd>
- <dt>{{domxref("GlobalEventHandlers.oncontextmenu")}}</dt>
- <dd>Called when the RIGHT mouse button is pressed</dd>
- <dt>{{domxref("GlobalEventHandlers.onerror")}}</dt>
- <dd>Called when a resource fails to load OR when an error occurs at runtime. See {{event("error")}} event.</dd>
- <dt>{{domxref("GlobalEventHandlers.onfocus")}}</dt>
- <dd>Called after the window receives or regains focus. See {{event("focus")}} events.</dd>
- <dt>{{domxref("WindowEventHandlers.onhashchange")}} {{gecko_minversion_inline("1.9.2")}}</dt>
- <dd>An event handler property for {{event('hashchange')}} events on the window; called when the part of the URL after the hash mark ("#") changes.</dd>
- <dt>{{domxref("GlobalEventHandlers.oninput")}}</dt>
- <dd>Called when the value of an &lt;input&gt; element changes</dd>
- <dt>{{domxref("GlobalEventHandlers.onkeydown")}}</dt>
- <dd>Called when you begin pressing ANY key. See {{event("keydown")}} event.</dd>
- <dt>{{domxref("GlobalEventHandlers.onkeypress")}}</dt>
- <dd>Called when a key (except Shift, Fn, and CapsLock) is in pressed position. See {{event("keypress")}} event.</dd>
- <dt>{{domxref("GlobalEventHandlers.onkeyup")}}</dt>
- <dd>Called when you finish releasing ANY key. See {{event("keyup")}} event.</dd>
- <dt>{{domxref("WindowEventHandlers.onlanguagechange")}}</dt>
- <dd>An event handler property for {{event("languagechange")}} events on the window.</dd>
- <dt>{{domxref("GlobalEventHandlers.onload")}}</dt>
- <dd>Called after all resources and the DOM are fully loaded. WILL NOT get called when the page is loaded from cache, such as with back button.</dd>
- <dt>{{domxref("WindowEventHandlers.onmessage")}}</dt>
- <dd>Is an {{domxref("EventHandler")}} representing the code to be called when the {{event("message")}} event is raised.</dd>
- <dt>{{domxref("GlobalEventHandlers.onmousedown")}}</dt>
- <dd>Called when ANY mouse button is pressed.</dd>
- <dt>{{domxref("GlobalEventHandlers.onmousemove")}}</dt>
- <dd>Called continously when the mouse is moved inside the window.</dd>
- <dt>{{domxref("GlobalEventHandlers.onmouseout")}}</dt>
- <dd>Called when the pointer leaves the window.</dd>
- <dt>{{domxref("GlobalEventHandlers.onmouseover")}}</dt>
- <dd>Called when the pointer enters the window</dd>
- <dt>{{domxref("GlobalEventHandlers.onmouseup")}}</dt>
- <dd>Called when ANY mouse button is released</dd>
- <dt>{{domxref("WindowEventHandlers.onoffline")}}</dt>
- <dd>Called when network connection is lost. See {{event("offline")}} event.</dd>
- <dt>{{domxref("WindowEventHandlers.ononline")}}</dt>
- <dd>Called when network connection is established. See {{event("online")}} event.</dd>
- <dt>{{domxref("WindowEventHandlers.onpagehide")}}</dt>
- <dd>Called when the user navigates away from the page, before the onunload event. See {{event("pagehide")}} event.</dd>
- <dt>{{domxref("WindowEventHandlers.onpageshow")}}</dt>
- <dd>Called after all resources and the DOM are fully loaded. See {{event("pageshow")}} event.</dd>
- <dt>{{domxref("WindowEventHandlers.onpopstate")}} {{gecko_minversion_inline("2.0")}}</dt>
- <dd>Called when a back button is pressed.</dd>
- <dt>{{domxref("GlobalEventHandlers.onreset")}}</dt>
- <dd>Called when a form is reset</dd>
- <dt>{{domxref("GlobalEventHandlers.onresize")}}</dt>
- <dd>Called continuously as you are resizing the window.</dd>
- <dt>{{domxref("GlobalEventHandlers.onscroll")}}</dt>
- <dd>Called when the scroll bar is moved via ANY means. If the resource fully fits in the window, then this event cannot be invoked</dd>
- <dt>{{domxref("GlobalEventHandlers.onwheel")}}</dt>
- <dd>Called when the mouse wheel is rotated around any axis</dd>
- <dt>{{domxref("GlobalEventHandlers.onselect")}}</dt>
- <dd>Called after text in an input field is selected</dd>
- <dt>{{domxref("GlobalEventHandlers.onselectionchange")}}</dt>
- <dd>Is an {{domxref("EventHandler")}} representing the code to be called when the {{event("selectionchange")}} event is raised.</dd>
- <dt>{{domxref("WindowEventHandlers.onstorage")}}</dt>
- <dd>Called when there is a change in session storage or local storage. See {{event("storage")}} event</dd>
- <dt>{{domxref("GlobalEventHandlers.onsubmit")}}</dt>
- <dd>Called when a form is submitted</dd>
- <dt>{{domxref("WindowEventHandlers.onunhandledrejection")}} {{experimental_inline}}</dt>
- <dd>An event handler for unhandled {{jsxref("Promise")}} rejection events.</dd>
- <dt>{{domxref("WindowEventHandlers.onunload")}}</dt>
- <dd>Called when the user navigates away from the page.</dd>
-</dl>
-
-<h2 id="Constructors">Constructors</h2>
-
-<p>See also the <a href="/en-US/docs/DOM/DOM_Reference" title="/en-US/docs/DOM/DOM_Reference">DOM Interfaces</a>.</p>
-
-<dl>
- <dt>{{domxref("DOMParser")}}</dt>
- <dd><code>DOMParser</code> can parse XML or HTML source stored in a string into a DOM <a href="https://developer.mozilla.org/en-US/docs/DOM/document" title="document">Document</a>. <code>DOMParser</code> is specified in <a href="https://w3c.github.io/DOM-Parsing/" title="http://html5.org/specs/dom-parsing.html">DOM Parsing and Serialization</a>.</dd>
- <dt>{{domxref("Window.GeckoActiveXObject")}}</dt>
- <dd>{{todo("NeedsContents")}}</dd>
- <dt>{{domxref("Image")}}</dt>
- <dd>Used for creating an {{domxref("HTMLImageElement")}}.</dd>
- <dt>{{domxref("Option")}}</dt>
- <dd>Used for creating an {{domxref("HTMLOptionElement")}}</dd>
- <dt>{{domxref("Window.QueryInterface")}}</dt>
- <dd>{{todo("NeedsContents")}}</dd>
- <dt>{{domxref("Window.StaticRange")}} {{experimental_inline}} {{readonlyinline}}</dt>
- <dd>Returns a {{domxref('StaticRange.StaticRange','StaticRange()')}} constructor which creates a {{domxref('StaticRange')}} object.</dd>
- <dt>{{domxref("Worker")}}</dt>
- <dd>Used for creating a <a href="/en-US/docs/DOM/Using_web_workers">Web worker</a></dd>
- <dt>{{domxref("Window.XMLSerializer")}}</dt>
- <dd>{{todo("NeedsContents")}}</dd>
- <dt>{{domxref("Window.XPCNativeWrapper")}}</dt>
- <dd>{{todo("NeedsContents")}}</dd>
- <dt>{{domxref("Window.XPCSafeJSObjectWrapper")}}</dt>
- <dd>{{todo("NeedsContents")}}</dd>
-</dl>
-
-<h2 id="Interfaces">Interfaces</h2>
-
-<p>See <a href="/en-US/docs/DOM/DOM_Reference" title="/en-US/docs/DOM/DOM_Reference">DOM Reference</a></p>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-
-
-<p>{{Compat("api.Window")}}</p>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li><a href="/en-US/docs/Working_with_windows_in_chrome_code">Working with windows in chrome code</a></li>
-</ul>
diff --git a/files/he/web/api/window/localstorage/index.html b/files/he/web/api/window/localstorage/index.html
deleted file mode 100644
index 1f423a8ef1..0000000000
--- a/files/he/web/api/window/localstorage/index.html
+++ /dev/null
@@ -1,82 +0,0 @@
----
-title: Window.localStorage
-slug: Web/API/Window/localStorage
-translation_of: Web/API/Window/localStorage
----
-<p>{{APIRef("Web Storage API")}}</p>
-
-<p>התכונה לקריאה בלבד <span class="seoSummary"> <strong><code>localStorage</code></strong>  מאפשרת לך לגשת לאובייקט מסוג {{DOMxRef("Storage")}} עבור המקור של   {{DOMxRef("Document")}}; הנתונים המאוחסנים</span><span class="seoSummary">נשמרים בכל מפגשי הדפדפן.</span> <code>localStorage</code>   דומה ל-{{DOMxRef("Window.sessionStorage", "sessionStorage")}}, פרט לכך שבעוד תוקפם של הנתונים הנשמרים ב- <code>localStorage</code> אינו פג, נתונים הנשמרים ב-,<code>sessionStorage</code> נמחקים עם תום המפגש של הדף  —  כלומר, כשהדף נסגר.</p>
-
-<p>יש לציין כי נתונים הנשמרים  ב-<code>localStorage</code> או ב-<code>sessionStorage</code>  הם מפורטים בפרוטוקול הדף.</p>
-
-<p>המפתחות והערכים יביו <strong>תמיד מחרוזות</strong> (לתשומת לבך, בדומה לאובייקטים, מפתחות מטיפוס מספר שלם יומרו אוטומטית למחרוזות).</p>
-
-<h2 id="תחביר">תחביר</h2>
-
-<pre class="syntaxbox"><em>myStorage</em> = <em>window</em>.localStorage;</pre>
-
-<h3 id="ערך">ערך</h3>
-
-<p>אובייקט מסוג {{DOMxRef("Storage")}} שניתן להשתמש בו לגישה לשטח האיחסון המקומי של המקור הנוכחי.</p>
-
-<h3 id="חריגות">חריגות</h3>
-
-<dl>
- <dt><code>SecurityError</code></dt>
- <dd>הבקשה מפרה החלטות מדיניות, או שהמקור אינו  <a href="/en-US/docs/Web/Security/Same-origin_policy#Definition_of_an_origin">a valid scheme/host/port tuple</a> (זה יכול לקרות אם המקור משתמש בסכמת (t <code>file:</code> או <code>data:</code>, למשל). לדוגמא, ייתכן שלמשתמש דפדפן המוגדר כך שישלול הרשאה לשמור נתונים כבלתי משתנים עבור מקור מסויים.</dd>
-</dl>
-
-<h2 id="דוגמא">דוגמא</h2>
-
-<p>קטע הקוד הבא ניגש לאובייקט ה-{{DOMxRef("Storage")}} המקומי של המתחם הנוכחי , ומוסיף לו נתון באמצעות {{DOMxRef("Storage.setItem()")}}.</p>
-
-<pre class="brush: js">localStorage.setItem('myCat', 'Tom');</pre>
-
-<p>התחביר לקריאת נתון ה-<code>localStorage</code> הוא כדלקמן:</p>
-
-<pre class="brush: js">var cat = localStorage.getItem('myCat');</pre>
-
-<p> התחביר למחיקת נתון ה-<code>localStorage</code> הוא כדלקמן:</p>
-
-<pre class="brush: js">localStorage.removeItem('myCat');</pre>
-
-<p>התחביר למחיקת כל הנתונים ב-<code>localStorage</code>  הוא כדלקמן:</p>
-
-<pre class="brush: js">// Clear all items
-localStorage.clear();
-</pre>
-
-<div class="note">
-<p><strong>לתשומת לבך</strong>: נא לעיין במאמר  <a href="/en-US/docs/Web/API/Web_Storage_API/Using_the_Web_Storage_API">Using the Web Storage API</a>   כדי לצפות בדוגמא השלמה.</p>
-</div>
-
-<h2 id="מפרטים">מפרטים</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">מפרט</th>
- <th scope="col">מצב</th>
- <th scope="col">הערה</th>
- </tr>
- <tr>
- <td>{{SpecName("HTML WHATWG", "webstorage.html#dom-localstorage", "localStorage")}}</td>
- <td>{{Spec2("HTML WHATWG")}}</td>
- <td></td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תאימות_דפדפנים">תאימות דפדפנים</h2>
-
-<div class="hidden">טבלת התאימות בדף זה נוצרה מנתונים המסודרים במבנה. אם תרצו לתרום לנתונים, אנא שלפו מ- <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a>  pull request ושלחו לנו בקשת משיכה.</div>
-
-<p>{{Compat("api.Window.localStorage")}}</p>
-
-<h2 id="לעיון_נוסף">לעיון נוסף</h2>
-
-<ul>
- <li><a href="/en-US/docs/Web/API/Web_Storage_API/Using_the_Web_Storage_API">Using the Web Storage API</a></li>
- <li><a href="/en-US/docs/Web/API/Web_Storage_API/Local_storage">Local storage with Window.localStorage</a></li>
- <li><span style="font-size: 1rem; letter-spacing: -0.00278rem;">{{DOMxRef("Window.sessionStorage")}}</span></li>
-</ul>
diff --git a/files/he/web/api/window/prompt/index.html b/files/he/web/api/window/prompt/index.html
deleted file mode 100644
index a57610aa13..0000000000
--- a/files/he/web/api/window/prompt/index.html
+++ /dev/null
@@ -1,90 +0,0 @@
----
-title: Window.prompt()
-slug: Web/API/Window/prompt
-tags:
- - דו-שיח
- - הודעה
- - פופ-אפ
-translation_of: Web/API/Window/prompt
----
-<div>{{ApiRef("Window")}}</div>
-
-<p><strong><code>Window.prompt()</code></strong> - מציגה תיבת דו-שיח עם תוכן, כפתורי אישור וביטול ומאפשרת למשתמש להזין טקסט ומספרים.</p>
-
-<h2 id="Syntax" name="Syntax">תחביר</h2>
-
-<pre class="syntaxbox"><em>result</em> = window.prompt(<em>message</em>);
-</pre>
-
-<h3 id="פרמטרים">פרמטרים</h3>
-
-<dl>
- <dt><code>message</code> {{optional_inline}}</dt>
- <dd>מחרוזת שתופיע בגוף ההודעה.</dd>
-</dl>
-
-<h2 id="Example" name="Example">דוגמאות</h2>
-
-<pre class="brush: js">let sign = prompt("What's your sign?");
-
-if (sign.toLowerCase() == "scorpio") {
- alert("Wow! I'm a Scorpio too!");
-}
-
-// there are many ways to use the prompt feature
-sign = window.prompt(); // open the blank prompt window
-sign = prompt(); // open the blank prompt window
-sign = window.prompt('Are you feeling lucky'); // open the window with Text "Are you feeling lucky"
-sign = window.prompt('Are you feeling lucky', 'sure'); // open the window with Text "Are you feeling lucky" and default value "sure"</pre>
-
-<p> </p>
-
-<p>כאשר המשתמש לוחץ על לחצן האישור, הטקסט שהוזן בשדה הקלט מוחזר. במידה והמשתמש לוחץ על אישור מבלי להזין טקסט, מחרוזת ריקה מוחזרת. במידה והמשתמש לוחץ על לחצן ביטול, פונקציה זו מחזירה null.</p>
-
-<p>ההודעה הנ"ל מופיעה כדלקמן (בדפדפן Chrome במערכת הפעלה OS X):</p>
-
-<p> </p>
-
-<p><a href="https://mdn.mozillademos.org/files/11303/prompt.png"><img alt="prompt() dialog in Chrome on OS X" src="https://mdn.mozillademos.org/files/11303/prompt.png" style="height: 298px; width: 535px;"></a></p>
-
-<h2 id="Notes" name="Notes">הערות</h2>
-
-<p> </p>
-
-<p>תיבת הדו-שיח מכילה תיבת טקסט בת שורה אחת, לחצני ביטול ואישור ומחזירה את הטקסט שהמשתמש הזין בתיבת הטקסט. תיבות דו-שיח מונעות מהמשתמש גישה לממשק התוכנית עד אשר היא תיסגר.</p>
-
-<p>יש לשים לב שהערך המחוזר מהשתמש יהיה מחרוזת. במידה והתשובה שלו צריכה להיות מספר, יש להמיר את הערך למספר.</p>
-
-<p> </p>
-
-<pre class="brush: js">const aNumber = Number(window.prompt("Type a number", ""));</pre>
-
-<h2 id="Specification" name="Specification">מפרט</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('HTML WHATWG', 'timers-and-user-prompts.html#dom-prompt', 'prompt()')}}</td>
- <td>{{Spec2('HTML WHATWG')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="See_also" name="See_also">תאימות דפדפן</h2>
-
-
-
-<p>{{Compat("api.Window.prompt")}}</p>
-
-<h2 id="See_also" name="See_also">ראה גם</h2>
-
-<ul>
- <li>{{domxref("window.alert", "alert")}}</li>
- <li>{{domxref("window.confirm", "confirm")}}</li>
-</ul>
diff --git a/files/he/web/api/xmlhttprequest/index.html b/files/he/web/api/xmlhttprequest/index.html
deleted file mode 100644
index 8a5c739854..0000000000
--- a/files/he/web/api/xmlhttprequest/index.html
+++ /dev/null
@@ -1,172 +0,0 @@
----
-title: XMLHttpRequest
-slug: Web/API/XMLHttpRequest
-tags:
- - AJAX
- - API
- - Communication
- - HTTP
- - Interface
- - NeedsTranslation
- - Reference
- - TopicStub
- - Web
- - XHR
- - XMLHttpRequest
-translation_of: Web/API/XMLHttpRequest
----
-<div>{{APIRef("XMLHttpRequest")}}</div>
-
-<p><span class="seoSummary">Use <code>XMLHttpRequest</code> (XHR) objects to interact with servers. You can retrieve data from a URL without having to do a full page refresh. This enables a Web page to update just part of a page without disrupting what the user is doing.</span> <code>XMLHttpRequest</code> is used heavily in <a href="/en-US/docs/AJAX">Ajax</a> programming.</p>
-
-<p>{{InheritanceDiagram(650, 150)}}</p>
-
-<p>Despite its name, <code>XMLHttpRequest</code> can be used to retrieve any type of data, not just XML, and it supports protocols other than <a href="/en-US/docs/Web/HTTP">HTTP</a> (including <code>file</code> and <code>ftp</code>).</p>
-
-<p>If your communication needs to involve receiving event data or message data from a server, consider using <a href="/en-US/docs/Web/API/Server-sent_events">server-sent events</a> through the {{domxref("EventSource")}} interface. For full-duplex communication, <a href="/en-US/docs/Web/API/WebSockets_API">WebSockets</a> may be a better choice.</p>
-
-<h2 id="Constructor">Constructor</h2>
-
-<dl>
- <dt>{{domxref("XMLHttpRequest.XMLHttpRequest", "XMLHttpRequest()")}}</dt>
- <dd>The constructor initializes an XMLHttpRequest. It must be called before any other method calls.</dd>
-</dl>
-
-<h2 id="Properties">Properties</h2>
-
-<p><em>This interface also inherits properties of {{domxref("XMLHttpRequestEventTarget")}} and of {{domxref("EventTarget")}}.</em></p>
-
-<dl>
- <dt id="xmlhttprequest-onreadystatechange">{{domxref("XMLHttpRequest.onreadystatechange")}}</dt>
- <dd>An {{domxref("EventHandler")}} that is called whenever the <code>readyState</code> attribute changes.</dd>
- <dt id="xmlhttprequest-readystate">{{domxref("XMLHttpRequest.readyState")}} {{readonlyinline}}</dt>
- <dd>Returns an <code>unsigned short</code>, the state of the request.</dd>
- <dt>{{domxref("XMLHttpRequest.response")}} {{readonlyinline}}</dt>
- <dd>Returns an {{domxref("ArrayBuffer")}}, {{domxref("Blob")}}, {{domxref("Document")}}, JavaScript object, or a {{domxref("DOMString")}}, depending on the value of {{domxref("XMLHttpRequest.responseType")}}. that contains the response entity body.</dd>
- <dt id="xmlhttprequest-responsetext">{{domxref("XMLHttpRequest.responseText")}} {{readonlyinline}}</dt>
- <dd>Returns a {{domxref("DOMString")}} that contains the response to the request as text, or <code>null</code> if the request was unsuccessful or has not yet been sent.</dd>
- <dt id="xmlhttprequest-responsetype">{{domxref("XMLHttpRequest.responseType")}}</dt>
- <dd>Is an enumerated value that defines the response type.</dd>
- <dt id="xmlhttprequest-responsexml">{{domxref("XMLHttpRequest.responseURL")}} {{readonlyinline}}</dt>
- <dd>Returns the serialized URL of the response or the empty string if the URL is null.</dd>
- <dt id="xmlhttprequest-responsexml">{{domxref("XMLHttpRequest.responseXML")}} {{readonlyinline}}</dt>
- <dd>Returns a {{domxref("Document")}} containing the response to the request, or <code>null</code> if the request was unsuccessful, has not yet been sent, or cannot be parsed as XML or HTML.</dd>
- <dt id="xmlhttprequest-status">{{domxref("XMLHttpRequest.status")}} {{readonlyinline}}</dt>
- <dd>Returns an <code>unsigned short</code> with the status of the response of the request.</dd>
- <dt id="xmlhttprequest-statustext">{{domxref("XMLHttpRequest.statusText")}} {{readonlyinline}}</dt>
- <dd>Returns a {{domxref("DOMString")}} containing the response string returned by the HTTP server. Unlike {{domxref("XMLHTTPRequest.status")}}, this includes the entire text of the response message ("<code>200 OK</code>", for example).</dd>
-</dl>
-
-<div class="note">
-<p><strong>Note:</strong> According to the HTTP/2 specification (<a href="https://http2.github.io/http2-spec/#rfc.section.8.1.2.4">8.1.2.4</a> <a href="https://http2.github.io/http2-spec/#HttpResponse">Response Pseudo-Header Fields</a>), HTTP/2 does not define a way to carry the version or reason phrase that is included in an HTTP/1.1 status line.</p>
-</div>
-
-<dl>
- <dt id="xmlhttprequest-timeout">{{domxref("XMLHttpRequest.timeout")}}</dt>
- <dd>Is an <code>unsigned long</code> representing the number of milliseconds a request can take before automatically being terminated.</dd>
- <dt id="xmlhttprequesteventtarget-ontimeout">{{domxref("XMLHttpRequestEventTarget.ontimeout")}}</dt>
- <dd>Is an {{domxref("EventHandler")}} that is called whenever the request times out. {{gecko_minversion_inline("12.0")}}</dd>
- <dt id="xmlhttprequest-upload">{{domxref("XMLHttpRequest.upload")}} {{readonlyinline}}</dt>
- <dd>Is an {{domxref("XMLHttpRequestUpload")}}, representing the upload process.</dd>
- <dt id="xmlhttprequest-withcredentials">{{domxref("XMLHttpRequest.withCredentials")}}</dt>
- <dd>Is a {{domxref("Boolean")}} that indicates whether or not cross-site <code>Access-Control</code> requests should be made using credentials such as cookies or authorization headers.</dd>
-</dl>
-
-<h3 id="Non-standard_properties">Non-standard properties</h3>
-
-<dl>
- <dt>{{domxref("XMLHttpRequest.channel")}}{{ReadOnlyInline}}</dt>
- <dd>Is a {{Interface("nsIChannel")}}. The channel used by the object when performing the request.</dd>
- <dt>{{domxref("XMLHttpRequest.mozAnon")}}{{ReadOnlyInline}}</dt>
- <dd>Is a boolean. If true, the request will be sent without cookie and authentication headers.</dd>
- <dt>{{domxref("XMLHttpRequest.mozSystem")}}{{ReadOnlyInline}}</dt>
- <dd>Is a boolean. If true, the same origin policy will not be enforced on the request.</dd>
- <dt>{{domxref("XMLHttpRequest.mozBackgroundRequest")}}</dt>
- <dd>Is a boolean. It indicates whether or not the object represents a background service request.</dd>
- <dt>{{domxref("XMLHttpRequest.mozResponseArrayBuffer")}}{{gecko_minversion_inline("2.0")}} {{obsolete_inline("6")}} {{ReadOnlyInline}}</dt>
- <dd>Is an <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/ArrayBuffer"><code>ArrayBuffer</code></a>. The response to the request, as a JavaScript typed array.</dd>
- <dt>{{domxref("XMLHttpRequest.multipart")}}{{obsolete_inline("22")}}</dt>
- <dd><strong>This Gecko-only feature, a boolean, was removed in Firefox/Gecko 22.</strong> Please use <a href="/en-US/docs/Web/API/Server-sent_events">Server-Sent Events</a>, <a href="/en-US/docs/Web/API/WebSockets_API">Web Sockets</a>, or <code>responseText</code> from progress events instead.</dd>
-</dl>
-
-<h3 id="Event_handlers">Event handlers</h3>
-
-<p><code>onreadystatechange</code> as a property of the <code>XMLHttpRequest</code> instance is supported in all browsers.</p>
-
-<p>Since then, a number of additional event handlers have been implemented in various browsers (<code>onload</code>, <code>onerror</code>, <code>onprogress</code>, etc.). See <a href="https://developer.mozilla.org/en-US/docs/Web/API/XMLHttpRequest/Using_XMLHttpRequest">Using XMLHttpRequest</a>.</p>
-
-<p>More recent browsers, including Firefox, also support listening to the <code>XMLHttpRequest</code> events via standard <code><a href="https://developer.mozilla.org/en-US/docs/Web/API/EventTarget/addEventListener">addEventListener()</a></code> APIs in addition to setting <code>on*</code> properties to a handler function.</p>
-
-<h2 id="Methods">Methods</h2>
-
-<dl>
- <dt>{{domxref("XMLHttpRequest.abort()")}}</dt>
- <dd>Aborts the request if it has already been sent.</dd>
- <dt>{{domxref("XMLHttpRequest.getAllResponseHeaders()")}}</dt>
- <dd>Returns all the response headers, separated by <a href="https://developer.mozilla.org/en-US/docs/Glossary/CRLF">CRLF</a>, as a string, or <code>null</code> if no response has been received.</dd>
- <dt>{{domxref("XMLHttpRequest.getResponseHeader()")}}</dt>
- <dd>Returns the string containing the text of the specified header, or <code>null</code> if either the response has not yet been received or the header doesn't exist in the response.</dd>
- <dt>{{domxref("XMLHttpRequest.open()")}}</dt>
- <dd>Initializes a request. This method is to be used from JavaScript code; to initialize a request from native code, use <a class="internal" href="/en-US/docs/Mozilla/Tech/XPCOM/Reference/Interface/nsIXMLHttpRequest#openRequest()"><code>openRequest()</code></a> instead.</dd>
- <dt>{{domxref("XMLHttpRequest.overrideMimeType()")}}</dt>
- <dd>Overrides the MIME type returned by the server.</dd>
- <dt>{{domxref("XMLHttpRequest.send()")}}</dt>
- <dd>Sends the request. If the request is asynchronous (which is the default), this method returns as soon as the request is sent.</dd>
- <dt>{{domxref("XMLHttpRequest.setRequestHeader()")}}</dt>
- <dd>Sets the value of an HTTP request header. You must call <code>setRequestHeader()</code>after <a href="#open"><code>open()</code></a>, but before <code>send()</code>.</dd>
-</dl>
-
-<h3 id="Non-standard_methods">Non-standard methods</h3>
-
-<dl>
- <dt>{{domxref("XMLHttpRequest.init()")}}</dt>
- <dd>Initializes the object for use from C++ code.</dd>
-</dl>
-
-<div class="warning"><strong>Warning:</strong> This method must <em>not</em> be called from JavaScript.</div>
-
-<dl>
- <dt>{{domxref("XMLHttpRequest.openRequest()")}}</dt>
- <dd>Initializes a request. This method is to be used from native code; to initialize a request from JavaScript code, use <a class="internal" href="/en-US/docs/Mozilla/Tech/XPCOM/Reference/Interface/nsIXMLHttpRequest#open()"><code>open()</code></a> instead. See the documentation for <code>open()</code>.</dd>
- <dt>{{domxref("XMLHttpRequest.sendAsBinary()")}}{{deprecated_inline()}}</dt>
- <dd>A variant of the <code>send()</code> method that sends binary data.</dd>
-</dl>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>{{SpecName('XMLHttpRequest')}}</td>
- <td>{{Spec2('XMLHttpRequest')}}</td>
- <td>Live standard, latest version</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-<p class="hidden">The compatibility table in this page is generated from structured data. If you'd like to contribute to the data, please check out <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> and send us a pull request.</p>
-
-<p>{{Compat("api.XMLHttpRequest")}}</p>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li>{{domxref("XMLSerializer")}}: Serializing a DOM tree into XML</li>
- <li>MDN tutorials covering <code>XMLHttpRequest</code>:
- <ul>
- <li><a href="/en-US/docs/AJAX/Getting_Started">Ajax — Getting Started</a></li>
- <li><a href="/en-US/docs/Web/API/XMLHttpRequest/Using_XMLHttpRequest">Using XMLHttpRequest</a></li>
- <li><a href="/en-US/docs/Web/API/XMLHttpRequest/HTML_in_XMLHttpRequest">HTML in XMLHttpRequest</a></li>
- </ul>
- </li>
- <li><a class="external" href="http://www.html5rocks.com/en/tutorials/file/xhr2/">HTML5 Rocks — New Tricks in XMLHttpRequest2</a></li>
-</ul>
diff --git a/files/he/web/css/index.html b/files/he/web/css/index.html
deleted file mode 100644
index 55679b0c8b..0000000000
--- a/files/he/web/css/index.html
+++ /dev/null
@@ -1,97 +0,0 @@
----
-title: 'CSS: גיליונות סגנון מדורגים'
-slug: Web/CSS
-translation_of: Web/CSS
----
-<div>{{CSSRef}}</div>
-
-<p class="summary"><span class="seoSummary"><strong>Cascading Style Sheets</strong> (<strong>CSS</strong>) is a <a href="/en-US/docs/DOM/stylesheet">stylesheet</a> language used to describe the presentation of a document written in <a href="/en-US/docs/Web/HTML" title="HyperText Markup Language">HTML</a></span> or <a href="/en-US/docs/XML_introduction">XML</a> (including XML dialects such as <a href="/en-US/docs/Web/SVG">SVG</a>, <a href="/en-US/docs/Web/MathML">MathML</a> or {{Glossary("XHTML", "", 1)}}). CSS describes how elements should be rendered on screen, on paper, in speech, or on other media.</p>
-
-<p>CSS is one of the core languages of the <strong>open Web</strong> and is standardized across Web browsers according to the <a class="external" href="http://w3.org/Style/CSS/#specs">W3C specification</a>. Developed in levels, CSS1 is now obsolete, CSS2.1 is a recommendation, and <a href="/en-US/docs/Web/CSS/CSS3" title="CSS3">CSS3</a>, now split into smaller modules, is progressing on the standardization track.</p>
-
-<section id="sect1">
-<ul class="card-grid">
- <li><span>CSS Introduction</span>
-
- <p>If you're new to web development, be sure to read our <a href="/en-US/docs/Learn/Getting_started_with_the_web/CSS_basics">CSS basics</a> article to learn what CSS is and how to use it.</p>
- </li>
- <li><span>CSS Tutorials</span>
- <p>Our <a href="/en-US/docs/Learn/CSS">CSS learning area</a> contains a wealth of tutorials to take you from beginner level to proficiency, covering all the fundamentals.</p>
- </li>
- <li><span>CSS Reference</span>
- <p>Our <a href="/en-US/docs/Web/CSS/Reference">exhaustive CSS reference</a> for seasoned Web developers describes every property and concept of CSS.</p>
- </li>
-</ul>
-
-<div class="row topicpage-table">
-<div class="section">
-<h2 class="Documentation" id="Tutorials">Tutorials</h2>
-
-<p>Our <a href="/en-US/docs/Learn/CSS">CSS Learning Area</a> features multiple modules that teach CSS from the ground up — no previous knowledge required.</p>
-
-<dl>
- <dt><a href="/en-US/docs/Learn/CSS/Introduction_to_CSS">Introduction to CSS</a></dt>
- <dd>This module starts with the basics of how CSS works, including selectors and properties, writing CSS rules, applying CSS to HTML, how to specify length, color, and other units in CSS, cascade and inheritance, box model basics, and debugging CSS.</dd>
- <dt><a href="/en-US/docs/Learn/CSS/Styling_text">Styling text</a></dt>
- <dd>This module discusses text styling fundamentals, including setting fonts, boldness, italics, line and letter spacing, text drop shadows, and other text properties. This module finishes with applying custom fonts to your page, and styling lists and links.</dd>
- <dt><a href="/en-US/docs/Learn/CSS/Styling_boxes">Styling boxes</a></dt>
- <dd>This module looks at styling boxes, one of the fundamental steps towards laying out a web page. In this module we recap the box model, then look at controlling box layouts by setting margins, borders, and padding, custom background colors, images and other features, and fancy features such as drop shadows and filters on boxes.</dd>
- <dt><a href="/en-US/docs/Learn/CSS/CSS_layout">CSS layout</a></dt>
- <dd>At this point we've already looked at CSS fundamentals, how to style text, and how to style and manipulate the boxes that your content sits inside. Now it's time to look at how to place your boxes in the right place in relation to the viewport, and one another. We have covered the necessary prerequisites so you can now dive deep into CSS layout, looking at different display settings, traditional layout methods involving float and positioning, and newfangled layout tools like flexbox.</dd>
-</dl>
-</div>
-
-<div class="section">
-<h2 class="Tools" id="Reference">Reference</h2>
-
-<ul>
- <li><a href="/en-US/docs/Web/CSS/Reference">CSS reference</a>: This exhaustive reference for seasoned Web developers describes every property and concept of CSS.</li>
- <li>CSS key concepts:
- <ul>
- <li>The <a href="/en-US/docs/Web/CSS/Syntax">syntax and forms of the language</a></li>
- <li><a href="/en-US/docs/Web/CSS/Specificity">Specificity</a>, <a href="/en-US/docs/Web/CSS/Inheritance">inheritance</a> and <a href="/en-US/docs/Web/CSS/Cascade">the Cascade</a></li>
- <li><a href="/en-US/docs/Web/CSS/CSS_Values_and_Units">CSS units and values</a></li>
- <li><a href="/en-US/docs/Web/CSS/box_model">Box model</a> and <a href="/en-US/docs/Web/CSS/margin_collapsing">margin collapse</a></li>
- <li>The <a href="/en-US/docs/Web/CSS/All_About_The_Containing_Block">containing block</a></li>
- <li><a href="/en-US/docs/Web/CSS/CSS_Positioning/Understanding_z_index/The_stacking_context" title="The stacking context">Stacking</a> and <a href="/en-US/docs/Web/CSS/block_formatting_context" title="block formatting context">block-formatting</a> contexts</li>
- <li><a href="/en-US/docs/Web/CSS/initial_value">Initial</a>, <a href="/en-US/docs/Web/CSS/computed_value">computed</a>, <a href="/en-US/docs/Web/CSS/used_value">used</a>, and <a href="/en-US/docs/Web/CSS/actual_value">actual</a> values</li>
- <li><a href="/en-US/docs/Web/CSS/Shorthand_properties">CSS shorthand properties</a></li>
- <li><a href="/en-US/docs/Web/CSS/CSS_Flexible_Box_Layout">CSS Flexible Box Layout</a></li>
- <li><a href="/en-US/docs/Web/CSS/CSS_Grid_Layout">CSS Grid Layout</a></li>
- <li><a href="/en-US/docs/Web/CSS/Media_Queries">Media queries</a></li>
- <li><a href="/en-US/docs/Web/CSS/animation">Animation</a></li>
- </ul>
- </li>
-</ul>
-
-<h2 class="Tools" id="Cookbook">Cookbook</h2>
-
-<p>The <a href="/en-US/docs/Web/CSS/Layout_cookbook">CSS layout cookbook</a> aims to bring together recipes for common layout patterns, things you might need to implement in your own sites. In addition to providing code you can use as a starting point in your projects, these recipes highlight the different ways layout specifications can be used, and the choices you can make as a developer.</p>
-
-<h2 class="Tools" id="Tools_for_CSS_development">Tools for CSS development</h2>
-
-<ul>
- <li>You can use the <a class="external" href="https://jigsaw.w3.org/css-validator/">W3C CSS Validation Service</a> to check if your CSS is valid. This is an invaluable debugging tool.</li>
- <li><a href="/en-US/docs/Tools">Firefox Developer Tools</a> lets you view and edit a page's live CSS via the <a href="/en-US/docs/Tools/Page_Inspector">Inspector</a> and <a href="/en-US/docs/Tools/Style_Editor">Style Editor</a> tools.</li>
- <li>The <a class="link-https" href="https://addons.mozilla.org/en-US/firefox/addon/web-developer/">Web Developer extension</a> for Firefox lets you track and edit live CSS on watched sites.</li>
- <li>The Web community has created various other <a href="/en-US/docs/Web/CSS/Tools">miscellaneous CSS tools</a> for you to use.</li>
-</ul>
-
-<h2 id="Meta_bugs">Meta bugs</h2>
-
-<ul>
- <li>Firefox: {{bug(1323667)}}</li>
-</ul>
-</div>
-</div>
-</section>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li><a href="/en-US/docs/Web/Demos_of_open_web_technologies#CSS">CSS demos</a>: Get a creative boost by exploring examples of the latest CSS technologies in action.</li>
- <li>Web languages to which CSS is often applied: <a href="/en-US/docs/Web/HTML">HTML</a>, <a href="/en-US/docs/Web/SVG">SVG</a>, <a href="/en-US/docs/Web/MathML">MathML</a>, {{Glossary("XHTML", "", 1)}}, and <a href="/en-US/docs/XML_introduction">XML</a>.</li>
- <li>Mozilla technologies that make extensive use of CSS: <a href="/en-US/docs/Mozilla/Tech/XUL">XUL</a>, <a href="/en-US/docs/Mozilla/Firefox">Firefox</a>, and <a href="/en-US/docs/Mozilla/Thunderbird">Thunderbird</a> <a href="/en-US/docs/Mozilla/Add-ons">extensions</a> and <a href="/en-US/docs/Mozilla/Add-ons/Themes">themes</a>.</li>
- <li><a href="https://lists.mozilla.org/listinfo/dev-tech-layout">Mozilla mailing list</a></li>
- <li><a href="Stack Overflow|http://stackoverflow.com/questions/tagged/css">Stack Overflow questions about CSS</a></li>
-</ul>
diff --git a/files/he/web/css/position/index.html b/files/he/web/css/position/index.html
deleted file mode 100644
index 41438b26a1..0000000000
--- a/files/he/web/css/position/index.html
+++ /dev/null
@@ -1,274 +0,0 @@
----
-title: 'position: מיקומים'
-slug: Web/CSS/position
-tags:
- - Position
- - css positions
- - מיקום
- - מיקומים ב-CSS
-translation_of: Web/CSS/position
----
-<div>{{CSSRef}}</div>
-
-<div>מיקומים הינם חוקי CSS המאפשרים לסדר אלמנטים שונים ולשלוט באופן התצוגה שלהם באמצעות מאפיינים שונים:</div>
-
-<div>{{Cssxref("top")}} ,{{Cssxref("right")}}, {{Cssxref("bottom")}} {{Cssxref("left")}}</div>
-
-<div> </div>
-
-<div>{{EmbedInteractiveExample("pages/css/position.html")}}</div>
-
-
-
-<dl>
- <dd>
- <h3 id="סוגי_מיקומים">סוגי מיקומים</h3>
- </dd>
- <dd>
- <p>אלמנט ממוקם הוא אלמנט שערכו המחושב הוא ערך יחסי (<code>relative</code>), מוחלט (<code>absolute</code>), קבוע (<code>fixed</code>) או דביק (<code>sticky</code>) וכל דבר שאינו סטטי (<code>static</code>).</p>
- </dd>
-</dl>
-
-{{csssyntax}}
-
-<dl>
- <dt id="static"><code>static</code></dt>
- <dd>זהו מאפיין ברירת המחדל הממקם את האלמנט בהתאם לכללים הסטנדרטים של הדף, כמו כן למאפיין {{cssxref("z-index")}} אין השפעה על סדר הדף.</dd>
- <dt id="relative"><code>relative</code></dt>
- <dd>האלמנט ממוקם בהתאם לזרימה הרגילה של המסמך ולאחר מכן מזיז את עצמו באמצעות הערכים <code>top</code>, <code>right</code>, <code>bottom</code>, <code>left</code>. הזזתו אינה משפיע על מיקומם של מרכיבים אחרים ולכן, המרחב שניתן עבור האלמנט בפריסת הדף זהה לזה של המיקום הסטטי.</dd>
- <dt id="absolute"><code>absolute</code></dt>
- <dd>האלמנט מוסר מהזרימה הרגילה של המסמך, לא נוצר מרווח יחודי עבור האלמנט אותו הוא מייצג. האלמנט ממוקם ביחס לאלמנט <code>relative</code> הקרוב ביותר אליו, במידה ואין כזה הוא ימוקם באופן יחסי לאלמנט האב הראשון של המסמך. ניתן להזיז אותו באמצעות הערכים <code>top</code>, <code>right</code>, <code>bottom</code>, <code>left</code>.</dd>
- <dt id="fixed"><code>fixed</code></dt>
- <dd>האלמנט מוסר מהזרימה הרגילה של המסמך, לא נוצר מרווח יחודי עבור האלמנט אותו הוא מייצג. האלמנט ימוקם באופן קבוע ויחסי לאלמנט האב הראשון של המסמך. ניתן להזיז אותו באמצעות הערכים <code>top</code>, <code>right</code>, <code>bottom</code>, <code>left</code>.</dd>
- <dt id="sticky"><code>sticky</code></dt>
- <dd>האלמנט ממוקם בהתאם לזרימה הרגילה של המסמך ולאחר מכן מזיז את עצמו ביחס לאלמנט האב הקרוב ביותר אליו. ניתן להזיז אותו באמצעות הערכים top, right, bottom, left והתזוזה שלו אינה משפיעה על המיקום של שאר האלמנטים. כאשר משתמשים בתכונה זו יש לשים לב שבעת הגלילה האלמנט יסתיר אלמנטים אחרים שנמצאים מתחתיו.</dd>
-</dl>
-
-<h2 id="דוגמאות">דוגמאות</h2>
-
-<h3 id="Relative_positioning" name="Relative_positioning">מיקום אלמנט באמצעות Relative </h3>
-
-<h4 id="HTML">HTML</h4>
-
-<pre class="brush: html">&lt;div class="box" id="one"&gt;One&lt;/div&gt;
-&lt;div class="box" id="two"&gt;Two&lt;/div&gt;
-&lt;div class="box" id="three"&gt;Three&lt;/div&gt;
-&lt;div class="box" id="four"&gt;Four&lt;/div&gt;
-</pre>
-
-<h4 id="CSS">CSS</h4>
-
-<pre class="brush: css">.box {
- display: inline-block;
- width: 100px;
- height: 100px;
- background: red;
- color: white;
-}
-
-#two {
- position: relative;
- top: 20px;
- left: 20px;
- background: blue;
-}
-</pre>
-
-<p>{{ EmbedLiveSample('Relative_positioning', '600px', '200px') }}</p>
-
-<h3 id="Absolute_positioning" name="Absolute_positioning">מיקום אלמנט באמצעות Absolute</h3>
-
-<pre class="brush: html">&lt;h1&gt;Absolute positioning&lt;/h1&gt;
-
-&lt;p&gt;I am a basic block level element. My adjacent block level elements sit on new lines below me.&lt;/p&gt;
-
-&lt;p class="positioned"&gt;By default we span 100% of the width of our parent element, and we are as tall as our child content. Our total width and height is our content + padding + border width/height.&lt;/p&gt;
-
-&lt;p&gt;We are separated by our margins. Because of margin collapsing, we are separated by the width of one of our margins, not both.&lt;/p&gt;
-
-&lt;p&gt;inline elements &lt;span&gt;like this one&lt;/span&gt; and &lt;span&gt;this one&lt;/span&gt; sit on the same line as one another, and adjacent text nodes, if there is space on the same line. Overflowing inline elements &lt;span&gt;wrap onto a new line if possible — like this one containing text&lt;/span&gt;, or just go on to a new line if not, much like this image will do: &lt;img src="https://mdn.mozillademos.org/files/13360/long.jpg"&gt;&lt;/p&gt;</pre>
-
-<pre class="brush: css">body {
-  width: 500px;
-  margin: 0 auto;
-}
-
-p {
- background: aqua;
- border: 3px solid blue;
- padding: 10px;
- margin: 10px;
-}
-
-span {
- background: red;
- border: 1px solid black;
-}
-
-.positioned {
- position: absolute;
- background: yellow;
- top: 30px;
- left: 30px;
-}</pre>
-
-<p>{{ EmbedLiveSample('Absolute_positioning', '100%', 420) }}</p>
-
-<p> </p>
-
-<h3 id="Fixed_positioning" name="Fixed_positioning">מיקום אלמנט באמצעות Fixed</h3>
-
-<h4 id="HTML_2">HTML</h4>
-
-<pre class="brush: html">&lt;div class="outer"&gt;
- &lt;p&gt;
- Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nam congue tortor eget pulvinar lobortis.
- Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Nam ac dolor augue.
- Pellentesque mi mi, laoreet et dolor sit amet, ultrices varius risus. Nam vitae iaculis elit.
- Aliquam mollis interdum libero. Sed sodales placerat egestas. Vestibulum ut arcu aliquam purus viverra dictum vel sit amet mi.
- Duis nisl mauris, aliquam sit amet luctus eget, dapibus in enim. Sed velit augue, pretium a sem aliquam, congue porttitor tortor.
- Sed tempor nisl a lorem consequat, id maximus erat aliquet. Sed sagittis porta libero sed condimentum.
- Aliquam finibus lectus nec ante congue rutrum. Curabitur quam quam, accumsan id ultrices ultrices, tempor et tellus.
- &lt;/p&gt;
- &lt;p&gt;
- Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nam congue tortor eget pulvinar lobortis.
- Vestibulum ante ipsum primis in faucibus orci luctus et ultrices posuere cubilia Curae; Nam ac dolor augue.
- Pellentesque mi mi, laoreet et dolor sit amet, ultrices varius risus. Nam vitae iaculis elit.
- Aliquam mollis interdum libero. Sed sodales placerat egestas. Vestibulum ut arcu aliquam purus viverra dictum vel sit amet mi.
- Duis nisl mauris, aliquam sit amet luctus eget, dapibus in enim. Sed velit augue, pretium a sem aliquam, congue porttitor tortor.
- Sed tempor nisl a lorem consequat, id maximus erat aliquet. Sed sagittis porta libero sed condimentum.
- Aliquam finibus lectus nec ante congue rutrum. Curabitur quam quam, accumsan id ultrices ultrices, tempor et tellus.
- &lt;/p&gt;
- &lt;div class="box" id="one"&gt;One&lt;/div&gt;
-&lt;/div&gt;
-</pre>
-
-<h4 id="CSS_2">CSS</h4>
-
-<pre class="brush: css">.box {
- width: 100px;
- height: 100px;
- background: red;
- color: white;
-}
-
-#one {
- position: fixed;
- top: 80px;
- left: 10px;
- background: blue;
-}
-
-.outer {
- width: 500px;
- height: 300px;
- overflow: scroll;
- padding-left: 150px;
-}
-</pre>
-
-<p>{{ EmbedLiveSample('Fixed_positioning', '800px', '300px') }}</p>
-
-<h3 id="Sticky_positioning" name="Sticky_positioning">מיקום אלמנט באמצעות Sticky </h3>
-
-<h4 id="HTML_3">HTML</h4>
-
-<pre class="brush: html">&lt;dl&gt;
- &lt;div&gt;
- &lt;dt&gt;A&lt;/dt&gt;
- &lt;dd&gt;Andrew W.K.&lt;/dd&gt;
- &lt;dd&gt;Apparat&lt;/dd&gt;
- &lt;dd&gt;Arcade Fire&lt;/dd&gt;
- &lt;dd&gt;At The Drive-In&lt;/dd&gt;
- &lt;dd&gt;Aziz Ansari&lt;/dd&gt;
- &lt;/div&gt;
- &lt;div&gt;
- &lt;dt&gt;C&lt;/dt&gt;
- &lt;dd&gt;Chromeo&lt;/dd&gt;
- &lt;dd&gt;Common&lt;/dd&gt;
- &lt;dd&gt;Converge&lt;/dd&gt;
- &lt;dd&gt;Crystal Castles&lt;/dd&gt;
- &lt;dd&gt;Cursive&lt;/dd&gt;
- &lt;/div&gt;
- &lt;div&gt;
- &lt;dt&gt;E&lt;/dt&gt;
- &lt;dd&gt;Explosions In The Sky&lt;/dd&gt;
- &lt;/div&gt;
- &lt;div&gt;
- &lt;dt&gt;T&lt;/dt&gt;
- &lt;dd&gt;Ted Leo &amp;amp; The Pharmacists&lt;/dd&gt;
- &lt;dd&gt;T-Pain&lt;/dd&gt;
- &lt;dd&gt;Thrice&lt;/dd&gt;
- &lt;dd&gt;TV On The Radio&lt;/dd&gt;
- &lt;dd&gt;Two Gallants&lt;/dd&gt;
- &lt;/div&gt;
-&lt;/dl&gt;
-</pre>
-
-<h4 id="CSS_3">CSS</h4>
-
-<pre class="brush: css">* {
- box-sizing: border-box;
-}
-
-dl &gt; div {
- background: #FFF;
- padding: 24px 0 0 0;
-}
-
-dt {
- background: #B8C1C8;
- border-bottom: 1px solid #989EA4;
- border-top: 1px solid #717D85;
- color: #FFF;
- font: bold 18px/21px Helvetica, Arial, sans-serif;
- margin: 0;
- padding: 2px 0 0 12px;
- position: -webkit-sticky;
- position: sticky;
- top: -1px;
-}
-
-dd {
- font: bold 20px/45px Helvetica, Arial, sans-serif;
- margin: 0;
- padding: 0 0 0 12px;
- white-space: nowrap;
-}
-
-dd + dd {
- border-top: 1px solid #CCC;
-}
-</pre>
-
-<p>{{ EmbedLiveSample('Sticky_positioning', '500px', '300px') }}</p>
-
-<h2 id="Specifications" name="Specifications">מפרטים</h2>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>{{SpecName('CSS2.1', 'visuren.html#propdef-position', 'position')}}</td>
- <td>{{Spec2('CSS2.1')}}</td>
- <td> </td>
- </tr>
- <tr>
- <td>{{SpecName('CSS3 Positioning','#position-property','position')}}</td>
- <td>{{Spec2('CSS3 Positioning')}}</td>
- <td>Adds <code>sticky</code> property value.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Browser_compatibility" name="Browser_compatibility">תאימות לדפדפן</h2>
-
-
-
-<p>{{Compat("css.properties.position")}}</p>
diff --git a/files/he/web/guide/html/html5/index.html b/files/he/web/guide/html/html5/index.html
deleted file mode 100644
index 80107c9424..0000000000
--- a/files/he/web/guide/html/html5/index.html
+++ /dev/null
@@ -1,177 +0,0 @@
----
-title: HTML5
-slug: Web/Guide/HTML/HTML5
-tags:
- - Guide
- - HELP
- - HTML
- - HTML5
- - NeedsTranslation
- - Overview
- - TopicStub
- - Web
- - Web Development
-translation_of: Web/Guide/HTML/HTML5
----
-<p><span class="seoSummary"><strong>HTML5</strong> is the latest evolution of the standard that defines <a href="/en-US/docs/HTML" title="HTML">HTML</a>. </span>The term represents two different concepts:</p>
-
-<ul>
- <li><span class="seoSummary">It is a new version of the <em>language</em> HTML, with new elements, attributes, and behaviors,</span></li>
- <li><span class="seoSummary">and a larger set of <strong>technologies</strong> that allows more diverse and powerful Web sites and applications.</span> This set is sometimes called <em>HTML5 &amp; friends</em> and often shortened to just <em>HTML5</em>.</li>
-</ul>
-
-<p>Designed to be usable by all Open Web developers, this reference page links to numerous resources about HTML5 technologies, classified into several groups based on their function.</p>
-
-<ul>
- <li><em>Semantics</em>: allowing you to describe more precisely what your content is.</li>
- <li><em>Connectivity</em>: allowing you to communicate with the server in new and innovative ways.</li>
- <li><em>Offline &amp; Storage</em>: allowing webpages to store data on the client-side locally and operate offline more efficiently.</li>
- <li><em>Multimedia</em>: making video and audio first-class citizens in the Open Web.</li>
- <li><em>2D/3D Graphics &amp; Effects</em>: allowing a much more diverse range of presentation options.</li>
- <li><em>Performance &amp; Integration</em>: providing greater speed optimization and better usage of computer hardware.</li>
- <li><em>Device Access</em>: allowing for the usage of various input and output devices.</li>
- <li><em>Styling</em>: letting authors write more sophisticated themes.</li>
-</ul>
-
-<div class="cleared row topicpage-table">
-<h2 id="Semantics" style="margin: 0pt 0pt 0.25em; font: 200 24px/1 'Bebas Neue','League Gothic',Haettenschweiler,'Arial Narrow',sans-serif; letter-spacing: 1px; text-transform: uppercase; border: medium none;"><img alt="" src="/files/3827/HTML5_Semantics_512.png" style="height: 64px; padding-right: 0.5em; vertical-align: middle; width: 64px;">Semantics</h2>
-
-<dl>
- <dt><a href="/en-US/docs/Sections_and_Outlines_of_an_HTML5_document" title="Sections and Outlines of an HTML5 document">Sections and outlines in HTML5</a></dt>
- <dd>A look at the new outlining and sectioning elements in HTML5: {{HTMLElement("section")}}, {{HTMLElement("article")}}, {{HTMLElement("nav")}}, {{HTMLElement("header")}}, {{HTMLElement("footer")}} and {{HTMLElement("aside")}}.</dd>
- <dt><a href="/en-US/docs/Using_HTML5_audio_and_video" title="Using_audio_and_video_in_Firefox">Using HTML5 audio and video</a></dt>
- <dd>The {{HTMLElement("audio")}} and {{HTMLElement("video")}} elements embed and allow the manipulation of new multimedia content.</dd>
- <dt><a href="/en-US/docs/HTML/Forms_in_HTML" title="Forms in HTML5">Forms in HTML5</a></dt>
- <dd>A look at improvements to web forms in HTML5: the constraint validation API, several new attributes, new values for the {{HTMLElement("input")}} attribute {{htmlattrxref("type", "input")}} and the new {{HTMLElement("output")}} element.</dd>
- <dt>New semantic elements</dt>
- <dd>Beside sections, media and forms elements, there are numerous new elements, like {{HTMLElement("mark")}}, {{HTMLElement("figure")}}, {{HTMLElement("figcaption")}}, {{HTMLElement("data")}}, {{HTMLElement("time")}}, {{HTMLElement("output")}}, {{HTMLElement("progress")}}, or {{HTMLElement("meter")}} and {{HTMLElement("main")}}, increasing the amount of <a href="/en-US/docs/HTML/HTML5/HTML5_element_list" title="HTML/HTML5/HTML5_element_list">valid HTML5 elements</a>.</dd>
- <dt>Improvement in {{HTMLElement("iframe")}}</dt>
- <dd>Using the {{htmlattrxref("sandbox", "iframe")}}, {{htmlattrxref("seamless", "iframe")}}, and {{htmlattrxref("srcdoc", "iframe")}} attributes, authors can now be precise about the level of security and the wished rendering of an {{HTMLElement("iframe")}} element.</dd>
- <dt><a href="/en-US/docs/MathML" title="MathML">MathML</a></dt>
- <dd>Allows directly embedding mathematical formulas.</dd>
- <dt><a href="/en-US/docs/HTML/HTML5/Introduction_to_HTML5" title="HTML/HTML5/Introduction_to_HTML5">Introduction to HTML5</a></dt>
- <dd>This article introduces how to indicate to the browser that you are using HTML5 in your web design or web application.</dd>
- <dt><a href="/en-US/docs/HTML/HTML5/HTML5_Parser" title="HTML/HTML5/HTML5 parser">HTML5-compliant parser</a></dt>
- <dd>The parser, which turns the bytes of an HTML document into a DOM, has been extended and now precisely defines the behavior to use in all cases, even when faced with invalid HTML. This leads to far greater predictability and interoperability between HTML5-compliant browsers.</dd>
-</dl>
-
-<h2 id="Connectivity" style="margin: 0pt 0pt 0.25em; font: 200 24px/1 'Bebas Neue','League Gothic',Haettenschweiler,'Arial Narrow',sans-serif; letter-spacing: 1px; text-transform: uppercase; border: medium none;"><img alt="" src="/files/3839/HTML5_Connectivity_512.png" style="height: 64px; padding-right: 0.5em; vertical-align: middle; width: 64px;">Connectivity</h2>
-
-<dl>
- <dt><a href="/en-US/docs/WebSockets" title="WebSockets">Web Sockets</a></dt>
- <dd>Allows creating a permanent connection between the page and the server and to exchange non-HTML data through that means.</dd>
- <dt><a href="/en-US/docs/Server-sent_events/Using_server-sent_events" title="Server-sent_events/Using_server-sent_events">Server-sent events</a></dt>
- <dd>Allows a server to push events to a client, rather than the classical paradigm where the server could send data only in response to a client's request.</dd>
- <dt><a href="/en-US/docs/WebRTC" title="WebRTC">WebRTC</a></dt>
- <dd>This technology, where RTC stands for Real-Time Communication, allows connecting to other people and controlling videoconferencing directly in the browser, without the need for a plugin or an external application.</dd>
-</dl>
-
-<h2 id="Offline_storage" style="margin: 0pt 0pt 0.25em; font: 200 24px/1 'Bebas Neue','League Gothic',Haettenschweiler,'Arial Narrow',sans-serif; letter-spacing: 1px; text-transform: uppercase; border: medium none;"><img alt="" src="/files/3833/HTML5_Offline_Storage_512.png" style="height: 64px; padding-right: 0.5em; vertical-align: middle; width: 64px;">Offline &amp; storage</h2>
-
-<dl>
- <dt><a href="/en-US/docs/HTML/Using_the_application_cache" title="Offline_resources_in_Firefox">Offline resources: the application cache</a></dt>
- <dd>Firefox fully supports the HTML5 offline resource specification. Most others have offline resource support at some level.</dd>
- <dt><a href="/en-US/docs/Online_and_offline_events" title="Online_and_offline_events">Online and offline events</a></dt>
- <dd>Firefox 3 supports WHATWG online and offline events, which let applications and extensions detect whether or not there's an active Internet connection, as well as to detect when the connection goes up and down.</dd>
- <dt><a href="/en-US/docs/DOM/Storage" title="DOM/Storage">WHATWG client-side session and persistent storage (aka DOM Storage)</a></dt>
- <dd>Client-side session and persistent storage allows web applications to store structured data on the client side.</dd>
- <dt><a href="/en-US/docs/IndexedDB" title="IndexedDB">IndexedDB</a></dt>
- <dd>IndexedDB is a web standard for the storage of significant amounts of structured data in the browser and for high performance searches on this data using indexes.</dd>
- <dt><a href="/en-US/docs/Using_files_from_web_applications" title="Using_files_from_web_applications">Using files from web applications</a></dt>
- <dd>Support for the new HTML5 File API has been added to Gecko, making it possible for web applications to access local files selected by the user. This includes support for selecting multiple files using the <span style="font-family: monospace;">{{HTMLElement("input")}}</span> of <a href="/en-US/docs/HTML/Element/Input#attr-type" title="HTML/Element/input#attr-type"><strong>type</strong></a> <span style="font-family: courier new;">file</span> HTML element's new <a href="/en-US/docs/HTML/Element/Input#attr-multiple" title="HTML/Element/input#attr-multiple"><strong>multiple</strong></a> attribute. There also is <a href="/en-US/docs/DOM/FileReader" title="DOM/FileReader"><code>FileReader</code></a>.</dd>
-</dl>
-
-<h2 id="Multimedia" style="margin: 0pt 0pt 0.25em; font: 200 24px/1 'Bebas Neue','League Gothic',Haettenschweiler,'Arial Narrow',sans-serif; letter-spacing: 1px; text-transform: uppercase; border: medium none;"><img alt="" src="/files/3835/HTML5_Multimedia_512.png" style="height: 64px; padding-right: 0.5em; vertical-align: middle; width: 64px;">Multimedia</h2>
-
-<dl>
- <dt><a href="/en-US/docs/Using_HTML5_audio_and_video" title="Using_audio_and_video_in_Firefox">Using HTML5 audio and video</a></dt>
- <dd>The {{HTMLElement("audio")}} and {{HTMLElement("video")}} elements embed and allow the manipulation of new multimedia content.</dd>
- <dt><a href="/en-US/docs/WebRTC" title="WebRTC">WebRTC</a></dt>
- <dd>This technology, where RTC stands for Real-Time Communication, allows connecting to other people and controlling videoconferencing directly in the browser, without the need for a plugin or an external application.</dd>
- <dt><a href="/en-US/docs/DOM/Using_the_Camera_API" title="DOM/Using_the_Camera_API">Using the Camera API</a></dt>
- <dd>Allows using, manipulating, and storing an image from the computer's camera.</dd>
- <dt>Track and WebVTT</dt>
- <dd>The {{HTMLElement("track")}} element allows subtitles and chapters. <a href="/en-US/docs/HTML/WebVTT" title="HTML/WebVTT">WebVTT</a> is a text track format.</dd>
-</dl>
-
-<h2 id="3D_graphics_effects" style="margin: 0pt 0pt 0.25em; font: 200 24px/1 'Bebas Neue','League Gothic',Haettenschweiler,'Arial Narrow',sans-serif; letter-spacing: 1px; text-transform: uppercase; border: medium none;"><img alt="" src="/files/3841/HTML5_3D_Effects_512.png" style="height: 64px; padding-right: 0.5em; vertical-align: middle; width: 64px;">3D, graphics &amp; effects</h2>
-
-<dl>
- <dt><a href="/en-US/docs/Canvas_tutorial" title="Canvas tutorial">Canvas Tutorial</a></dt>
- <dd>Learn about the new <code>{{HTMLElement("canvas")}}</code> element and how to draw graphs and other objects in Firefox.</dd>
- <dt><a href="/en-US/docs/Drawing_text_using_a_canvas" title="Drawing_text_using_a_canvas">HTML5 text API for <code>&lt;canvas&gt;</code> elements</a></dt>
- <dd>The HTML5 text API is now supported by {{HTMLElement("canvas")}} elements.</dd>
- <dt><a href="/en-US/docs/WebGL" title="WebGL">WebGL</a></dt>
- <dd>WebGL brings 3D graphics to the Web by introducing an API that closely conforms to OpenGL ES 2.0 that can be used in HTML5 {{HTMLElement("canvas")}} elements.</dd>
- <dt><a href="/en-US/docs/SVG" title="SVG">SVG</a></dt>
- <dd>An XML-based format of vectorial images that can directly be embedded in the HTML.</dd>
- <br>
- <br>
-
-</dl>
-
-<div class="section">
-<h2 id="Performance_integration" style="margin: 0pt 0pt 0.25em; font: 200 24px/1 'Bebas Neue','League Gothic',Haettenschweiler,'Arial Narrow',sans-serif; letter-spacing: 1px; text-transform: uppercase; border: medium none;"><img alt="" src="/files/3831/HTML5_Performance_512.png" style="height: 64px; padding-right: 0.5em; vertical-align: middle; width: 64px;">Performance &amp; integration</h2>
-
-<dl>
- <dt><a href="/en-US/docs/DOM/Using_web_workers" title="Using web workers">Web Workers</a></dt>
- <dd>Allows delegation of JavaScript evaluation to background threads, allowing these activities to prevent slowing down interactive events.</dd>
- <dt><code><a href="/en-US/docs/DOM/XMLHttpRequest" title="XMLHttpRequest">XMLHttpRequest</a></code> Level 2</dt>
- <dd>Allows fetching asynchronously some parts of the page, allowing it to display dynamic content, varying according to the time and user actions. This is the technology behind <a href="/en-US/docs/AJAX" title="AJAX">Ajax</a>.</dd>
- <dt>JIT-compiling JavaScript engines</dt>
- <dd>The new generation of JavaScript engines is much more powerful, leading to greater performance.</dd>
- <dt><a href="https://developer.mozilla.org/en-US/docs/DOM/Manipulating_the_browser_history" title="DOM/Manipulating_the_browser_history">History API</a></dt>
- <dd>Allows the manipulation of the browser history. This is especially useful for pages loading interactively new information.</dd>
- <dt><a href="/en-US/docs/HTML/Content_Editable" title="HTML/Content Editable">The contentEditable attribute: transform your website to a wiki!</a></dt>
- <dd>HTML5 has standardized the contentEditable attribute. Learn more about this feature.</dd>
- <dt><a href="/en-US/docs/DragDrop/Drag_and_Drop" title="DragDrop/Drag_and_Drop">Drag and drop</a></dt>
- <dd>The HTML5 drag and drop API allows support for dragging and dropping items within and between web sites. This also provides a simpler API for use by extensions and Mozilla-based applications.</dd>
- <dt><a href="/en-US/docs/Focus_management_in_HTML" title="Focus_management_in_HTML">Focus management in HTML</a></dt>
- <dd>The new HTML5 <code>activeElement</code> and <code>hasFocus</code> attributes are supported.</dd>
- <dt><a href="/en-US/docs/Web-based_protocol_handlers" title="Web-based_protocol_handlers">Web-based protocol handlers</a></dt>
- <dd>You can now register web applications as protocol handlers using the <code>navigator.registerProtocolHandler()</code> method.</dd>
- <dt><a href="/en-US/docs/DOM/window.requestAnimationFrame" title="DOM/window.requestAnimationFrame"><code>requestAnimationFrame</code></a></dt>
- <dd>Allows control of animations rendering to obtain optimal performance.</dd>
- <dt><a href="/en-US/docs/DOM/Using_full-screen_mode" title="DOM/Using_full-screen_mode">Fullscreen API</a></dt>
- <dd>Controls the usage of the whole screen for a Web page or application, without the browser UI displayed.</dd>
- <dt><a href="/en-US/docs/API/Pointer_Lock_API" title="API/Pointer_Lock_API">Pointer Lock API</a></dt>
- <dd>Allows locking the pointer to the content, so games and similar applications don't lose focus when the pointer reaches the window limit.</dd>
- <dt><a href="/en-US/docs/Online_and_offline_events" title="Online_and_offline_events">Online and offline events</a></dt>
- <dd>In order to build a good offline-capable web application, you need to know when your application is actually offline. Incidentally, you also need to know when your application has returned to an online status again.</dd>
-</dl>
-
-<h2 id="Device_access" style="margin: 0pt 0pt 0.25em; font: 200 24px/1 'Bebas Neue','League Gothic',Haettenschweiler,'Arial Narrow',sans-serif; letter-spacing: 1px; text-transform: uppercase; border: medium none;"><img alt="" src="/files/3837/HTML5_Device_Access_512.png" style="height: 66px; padding-right: 0.5em; vertical-align: middle; width: 77px;">Device access</h2>
-
-<dl>
- <dt><a href="/en-US/docs/DOM/Using_the_Camera_API" title="DOM/Using_the_Camera_API">Using the Camera API</a></dt>
- <dd>Allows using, manipulating, and storing an image from the computer's camera.</dd>
- <dt><a href="/en-US/docs/DOM/Touch_events" title="DOM/Touch_events">Touch events</a></dt>
- <dd>Handlers to react to events created by a user pressing touch screens.</dd>
- <dt><a href="/en-US/docs/Using_geolocation" title="Using geolocation">Using geolocation</a></dt>
- <dd>Let browsers locate the position of the user using geolocation.</dd>
- <dt><a href="/en-US/docs/Detecting_device_orientation" title="Detecting_device_orientation">Detecting device orientation</a></dt>
- <dd>Get the information when the device on which the browser runs changes orientation. This can be used as an input device (e.g., to make games that react to the position of the device) or to adapt the layout of a page to the orientation of the screen (portrait or landscape).</dd>
- <dt><a href="/en-US/docs/API/Pointer_Lock_API" title="API/Pointer_Lock_API">Pointer Lock API</a></dt>
- <dd>Allows locking the pointer to the content, so games and similar application don't lose focus when the pointer reaches the window limit.</dd>
-</dl>
-
-<h2 id="Styling" style="margin: 0pt 0pt 0.25em; font: 200 24px/1 'Bebas Neue','League Gothic',Haettenschweiler,'Arial Narrow',sans-serif; letter-spacing: 1px; text-transform: uppercase; border: medium none;"><img alt="" src="/files/3829/HTML5_Styling_512.png" style="height: 64px; padding-right: 0.5em; vertical-align: middle; width: 64px;">Styling</h2>
-
-<p><a href="/en-US/docs/CSS" title="CSS">CSS</a> has been extended to be able to style elements in a much more complex way. This is often referred as <a href="/en-US/docs/CSS/CSS3" title="CSS/CSS3">CSS3</a>, though CSS is not a monolithic specification any more and the different modules are not all at level 3: some are at level 1 and others at level 4, with all the intermediate levels covered.</p>
-
-<dl>
- <dt>New background styling features</dt>
- <dd>It is now possible to put a shadow to a box, using {{cssxref("box-shadow")}} and <a href="/en-US/docs/CSS/Multiple_backgrounds" title="CSS/Multiple_backgrounds">multiple backgrounds</a> can be set.</dd>
- <dt>More fancy borders</dt>
- <dd>Not only it is now possible to use images to style borders, using {{cssxref("border-image")}} and its associated longhand properties, but rounded borders are supported via the {{cssxref("border-radius")}} property.</dd>
- <dt>Animating your style</dt>
- <dd>Using <a href="/en-US/docs/CSS/Using_CSS_transitions" title="CSS/Using_CSS_transitions">CSS Transitions</a> to animate between different states or using <a href="/en-US/docs/CSS/Using_CSS_animations" title="CSS/Using_CSS_animations">CSS Animations</a> to animate parts of the page without a triggering event, you can now control mobile elements on your page.</dd>
- <dt>Typography improvement</dt>
- <dd>Authors have better control to reach better typography. They can control {{cssxref("text-overflow")}} and <a href="/en-US/docs/CSS/hyphens" title="CSS/hyphens">hyphenation</a>, but also can add a <a href="/en-US/docs/CSS/text-shadow" title="CSS/text-shadow">shadow</a> to it or control more precisely its <a href="/en-US/docs/CSS/text-decoration" title="SVG/Attribute/text-decoration">decorations</a>. Custom typefaces can be downloaded and applied thanks to the new {{cssxref("@font-face")}} at-rule.</dd>
- <dt>New presentational layouts</dt>
- <dd>In order to improve the flexibility of designs, two new layouts have been added: the <a href="/en-US/docs/CSS/Using_CSS_multi-column_layouts" title="CSS/Using_CSS_multi-column_layouts">CSS multi-column layout</a>, and the <a href="/en-US/docs/CSS/Flexbox" title="CSS/Flexbox">CSS flexible box layout</a>.</dd>
-</dl>
-</div>
-</div>
-
-<p> </p>
diff --git a/files/he/web/guide/index.html b/files/he/web/guide/index.html
deleted file mode 100644
index e6e9e81592..0000000000
--- a/files/he/web/guide/index.html
+++ /dev/null
@@ -1,62 +0,0 @@
----
-title: מדריך למפתח אינטרנט
-slug: Web/Guide
-tags:
- - Guide
- - Landing
- - NeedsTranslation
- - TopicStub
- - Web
-translation_of: Web/Guide
----
-<p dir="rtl"><strong>מאמרים אלה מספקים עזרה לגבי שימוש בטכנלוגיות אינטרנט ו- API מסוימים.</strong></p>
-
-<div class="row topicpage-table" dir="rtl">
-<div class="section">
-<dl>
- <dt class="landingPageList"><a href="/he/docs/Learn/HTML">אזור לימוד HTML</a></dt>
- <dd class="landingPageList"><strong>HTML (שפת תגיות לתמליל-על או HyperText Markup Language)</strong> הינה שפת הליבה של כמעט כל תוכן הרשת. מרבית הדברים על המסך בדפדפן שלך מתוארים בבסיסם על-ידי שימוש ב- HTML.</dd>
- <dt class="landingPageList"><a href="/he/docs/Learn/CSS">אזור לימוד CSS</a></dt>
- <dd class="landingPageList"><strong>CSS (גליונות סגנון מדורגים, או Cascading Style Sheets stylesheet)</strong> הינה שפה המשמשת להגדיר תצוגת מסמך HTML.</dd>
- <dt class="landingPageList"><a href="https://developer.mozilla.org/he/docs/Web/Guide/Events">מדריך אירועים (Events) למפתח</a></dt>
- <dd class="landingPageList">אירועים (Events) מתייחסים לשני דברים:<br>
- תבנית עיצוב המשמשת לטיפול אסינכרוני במקרים שונים המתרחשים במהלך חיי עמוד האינטרנט;<br>
- והשיום (naming), אפיון והשימוש במספר גדול של מקרים מסוגים שונים.</dd>
- <dt class="landingPageList"><a href="/he/docs/Web/Guide/AJAX">AJAX</a></dt>
- <dd class="landingPageList">AJAX הוא מונח המגדיר קבוצת טכנולוגיות המאפשרות לאפליקציות רשת לבצע עדכונים מהירים ומצטברים לממשק המשתמש ללא טעינה מחדש של כל העמוד. דבר זה הופך את האפליקציה למהירה ותגובתית יותר לפעולות המשתמש.</dd>
- <dt class="landingPageList"><a href="https://developer.mozilla.org/he/docs/Web/Guide/Graphics">גרפיקה ברשת</a></dt>
- <dd class="landingPageList">אתרי אינטרנט ואפליקציות מודרניות זקוקים לעתים להציג גרפיקה עם רמות תחכום שונות.</dd>
- <dt class="landingPageList"><a href="https://developer.mozilla.org/he/docs/Web/Guide/API">מדריך ל- API ברשת</a></dt>
- <dd class="landingPageList">רשימה של כל ה- API האינטרנטיים, ומה הם עושים.</dd>
- <dt><a href="https://developer.mozilla.org/he/docs/JavaScript" title="/he/docs/JavaScript">ג'אווה-סקריפט (JavaScript)</a></dt>
- <dd>JavaScript היא שפת תסריט (סקריפטינג) חזקה, המשמשת ליצירת אפליקציות באינטרנט.</dd>
- <dt class="landingPageList"><a href="https://developer.mozilla.org/he/docs/Localizations_and_character_encodings">לוקליזציה וקידוד תווים</a></dt>
- <dd class="landingPageList">Browsers process text as Unicode internally. However, a way of representing characters in terms of bytes (character encoding) is used for transferring text over the network to the browser. The <a class="external external-icon" href="http://www.whatwg.org/specs/web-apps/current-work/multipage/semantics.html#charset">HTML specification recommends the use of the UTF-8 encoding</a> (which can represent all of Unicode), and regardless of the encoding used requires Web content to declare that encoding.</dd>
- <dt class="landingPageList"><a href="https://developer.mozilla.org/he/docs/Web/Guide/Mobile">פיתוח אינטרנט למובייל</a></dt>
- <dd class="landingPageList">This article provides an overview of some of the main techniques needed to design web sites that work well on mobile devices. If you're looking for information on Mozilla's Firefox OS project, see the <a href="https://developer.mozilla.org/en/Mozilla/Firefox_OS" title="Boot to Gecko">Firefox OS</a> page. Or you might be interested in details about <a href="https://developer.mozilla.org/en/Mozilla/Firefox_for_Android">Firefox for Android</a>.</dd>
-</dl>
-</div>
-
-<div class="section">
-<dl>
- <dt class="landingPageList"><a href="https://developer.mozilla.org/he/Apps/Progressive#Core_PWA_guides">אפליקציות אינטרנט מתקדמות (PWA)</a></dt>
- <dd class="landingPageList">Progressive web apps (PWAs) use modern web APIs along with traditional progressive enhancement strategy to create cross-platform web applications. These apps work everywhere and provide several features that give them the same user experience advantages as native apps. This set of guides tells you all you need to know about PWAs.</dd>
- <dt class="landingPageList"><a href="https://developer.mozilla.org/he/docs/Web/Guide/Performance">אופטימיזציות וביצועים</a></dt>
- <dd class="landingPageList">When building modern web apps and sites, it's important to make your content work quickly and efficiently. This lets it perform effectively for both powerful desktop systems and weaker handheld devices.</dd>
- <dt class="landingPageList"><a href="https://developer.mozilla.org/he/docs/Web/Guide/Parsing_and_serializing_XML">ניתוח וסריאליזציה של XML</a></dt>
- <dd class="landingPageList">פלטפורמת הרשת מספקת שיטות שונות לניתוח וסריאליזציה (סדרות) של XML, כל אחת מהן עם יתרונותיה וחסרונותיה.</dd>
- <dt class="landingPageList"><a href="https://developer.mozilla.org/he/docs/Web/Guide/WOFF">פורמט גופן אינטרנט פתוח (WOFF, Web Open Font Format)</a></dt>
- <dd class="landingPageList">WOFF (Web Open Font Format) הוא תצורת קובץ גופן (פונט) זמינה לשימוש ברשת בחינם.</dd>
- <dt class="landingPageList"><a href="https://developer.mozilla.org/he/docs/Web/Guide/Using_FormData_Objects">שימוש באובייקט FormData</a></dt>
- <dd class="landingPageList">אובייקט <code><a href="https://developer.mozilla.org/en/DOM/XMLHttpRequest/FormData">FormData</a></code> מאפשר להדר אוסף של זוגות מפתח/ערך (key/value), כדי לשלוח בקשת <code>XMLHttpRequest</code>. הוא מיועד בעיקר לשלוחת פרטי טופס, אבל ניתן להשתמש בו באופן נפרד מטפסים, כדי לשלוח מידע. התשדורת נעשית באותה תצורה כמו שמתודת <code style="display: inline-block; direction: ltr;">submit()</code> שולחת טופס שהקידוד שלו הוא "multipart/form-data".</dd>
- <dt class="landingPageList"><a href="/he/docs/Glossary">מילון מלים</a></dt>
- <dd class="landingPageList">מגדיר מספר מונחים טכניים הקשורים לרשת ולאינטרנט.</dd>
-</dl>
-</div>
-</div>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul dir="rtl">
- <li><a href="/he/docs/Web/Reference" title="/he/docs/Web/Reference">הפניות לפיתוח אינטרנט</a></li>
-</ul>
diff --git a/files/he/web/guide/localizations_and_character_encodings/index.html b/files/he/web/guide/localizations_and_character_encodings/index.html
deleted file mode 100644
index 7ab8aa2ba4..0000000000
--- a/files/he/web/guide/localizations_and_character_encodings/index.html
+++ /dev/null
@@ -1,62 +0,0 @@
----
-title: התאמות למיקומים וקידוד תווים
-slug: Web/Guide/Localizations_and_character_encodings
-tags:
- - HTML
- - התאמה למיקום
- - צורך בעבודת markup
- - קידוד תווים
-translation_of: Web/Guide/Localizations_and_character_encodings
----
-<p>דפדפנים מעבדים טקסט כיוניקוד בתוכם. אולם, דרך לייצג תווים במונחים של בייטים (קידוד תווים) משמשת להעברת טקסט על גבי הרשת לדפדפן. <a href="http://www.whatwg.org/specs/web-apps/current-work/multipage/semantics.html#charset" title="http://www.whatwg.org/specs/web-apps/current-work/multipage/semantics.html#charset">מפרט ה-HTML ממליץ</a> על שימוש בקידוד UTF-8  (היכול לייצג את כל היוניקוד) ובלי קשר לקידוד שבשימוש מצריך כי בתוכן שברשת יוצהר באיזה קידוד השתמשו.</p>
-
-<p>המאפיין {{htmlattrxref("charset", "meta")}}  של אלמנט ה-{{HTMLElement("meta")}} משמש לציין את קידוד התווים של הדף.</p>
-
-<p>כדי לציין כי הדף משתמש, לדוגמאף בקידוד תווים UTF-8 (על פי ההמלצה), יש פשוט למקם את השורה הבאה בבלוק ה-{{HTMLElement("head")}}:</p>
-
-<pre class="brush: html">&lt;meta charset="utf-8"&gt;
-</pre>
-
-<h2 id="פרטים_וקרבי_הדפדפן">פרטים וקרבי הדפדפן</h2>
-
-<p>כשהקידוד מוצהר בתוכן הרשת כמתחייב ממפרט ה-HTML, פיירפוקס ישתמש בקידוד זה כדי להפוך את הבעעטם לייצוג הפנימי. לרוע המזל, שימוש ב-UTF-8 והצהרה כי UTF-8 הוא הקידוד שבשימוש לא היו תמיד הדרך הנפוצה להציע תוכן ברשת. בשנות ה-1990, היה נפוץ להשאיר את הקידוד לא מוצהר ולהשתמש בקידוד האופייני לאזור שלא היה מסוגל לייצג את כל היוניקוד.</p>
-
-<p>פיירפוקס זקוק לקידוד לעת-מצוא שישמש לתוכן לא-תואם במתכונת הישנה שאינו מצהיר על קידודו. עבור רוב המיקומים, הקידוד לעת-מצוא הוא windows-1252 (הקרוי לעתים קרובות ISO-8859-1), שהוא הקידוד המתקבל כפלט מרוב אפילקציות ה-Windows בשנות ה-1990 וקבוצת על של הקידוד המתקבל כקלט מרוב יישומי היוניקס בשנות ה-1990 כפי שהתפרש באמריקה ובמערב אירופה.  אולם, קיימים מיקומים שבהם פרסום ברשת היה נפוץ כבר בשנות ה-1990 שקידוד windows-1252 לא התאים לשפה המקומית. במיקומים האלה תוכן במתכונת הישנה שאינו מצהיר את קידודו בופן טיפוסי מקודד באמצעות שיטת קידוד ישנה שאינה windows-1252. על מנת לעבוד עם תוכן המופיע במתכונת הישנה, חלק ממיקומי פיירפוקס זקוקים לקידוד לעת-מצוא שאינו windows-1252.</p>
-
-<p>לרוע המזל, משמעות הדבר היא כי פונקציונליות פיירפוקס החשופה לרשת נבדלת במיקום וקשה לקרוא תוכן שנכתב במתכונת הישנה בכל המיקומים עם קידודים שונים לעת-מצוא. כדי להימנע היתקלות בבעיות במיקומים בהם פרסומים ברשת באו אחרי אימוץ UTF-8, מיקומים שאין בהם קידוד במתכונת הישנה שצצה מהפרקטיקות של שנות ה-1990, צריכים להשאיר את הקידוד לשעת-מצוא להיות windows-1252 כדי להקל על קריאת תוכן בעל מיקומים שונים ממיקומים שבהם הקידוד לעת מצוא הוא windows-1252. תוכן מקודד UTF-8 בשפת המקום, הנכתב כחדש, מצופה להצהיר על קידודו, שבמקרה זה הקידוד לעת-מצוא אינו חלק מעיבוד התוכן.</p>
-
-<p>בנוסף, קיים מספר קטן של מיקומים בהם בשנות ה-1990 לא היה קידוד ברור מאליו האופייני לאזור, והזיהוי הראשוני מבין הקידודים בתמכונת הישנה הוצג לראשונה לדפדפני הרשת. לדבר  הייתה השפעה בכך שהמחברים ברשת היו תלויים בנוכחותו של זיהוי ראשוני, ולכן לפיירפוקס עדיין יש זיהוי ראשוני במיקומים אלה.</p>
-
-<h2 id="מציאת_שמות_קידוד_קאנוניים">מציאת שמות קידוד קאנוניים</h2>
-
-<p>הטקסט שלהלן מתייחס לשמות קאנוניים של קידודים. השמות הקאנוניים הם הערכים מימין לשימן השוויון ב-<a href="https://mxr.mozilla.org/mozilla-central/source/intl/locale/unix/unixcharset.properties" title="https://mxr.mozilla.org/mozilla-central/source/intl/locale/unix/unixcharset.properties">unixcharset.properties</a>.</p>
-
-<h2 id="ציון_הקידוד_לעת_מצוא">ציון הקידוד לעת מצוא</h2>
-
-<p><strong>מאז פיירפוקס 28, עבר זמנו של קטע זה, משום שההעדפה <code>intl.charset.default</code> אינה קיימת עוד. ההתאמה בין המיקומים לקידודים לעת מצוא  כעת בנויה לתוך  Gecko עצמו.</strong></p>
-
-<p> הקידודים לעת מצוא מצויינים על ידי ההעדפה<code>intl.charset.default</code> ב- <code>intl.properties</code>. הן אמורות להיות מוגדרות כשמות הקאנוניים של הקידודים על פי המתכונת הישנה  שהכי צפוי שמשתמשי ההתאמות למיקומים   יפגשו בעת גלישה בתכנים במתכונת הישנה ברשת שאינם מצייתים לכללים ואינם מצהירים על קידודם.  יש לשים לב לכך שקידודים לעת מצוא כפי שהם מוגדרים על ידי המשפט הקודם לא בהכרח צריכים להיות מסוגלים לייצג את התווים הדרושים עבור שפת המיקום!</p>
-
-<p>הקידוד לעת מצוא צריך להישאר מוגדר כ-windows-1252 עבור מיקומים מערב אירופאיים, מיקומים צפון-, מרכז- ודרום אמריקאיים, מיקומים אפריקאיים, מיקומים מקכז אסיאניים ומיקומים אוקיאניים. טיפוסית המיקום צריך להיות מוגדר אחרת מ-windows-1252 עבור  מיקומים מזרח אירופאיים, מיקומים מזרח תיכוניים ומיקומים צזרח אסיאניים.</p>
-
-<p>על מנת להימנע מבעיות של יוצרי תוכן ברשת היוצרים תוכן מקודד UTF-8 בלי להצהיר כי UTF-8 הוא הקידוד שבשימוש ועל מנת להעלות למקסימום את היכולת של משתמשים לקרוא תוכן בעל מספר מיקומים, אין להגדיר את הקידוד לעת מצוא ל-UTF-8 לכל מיקום מוגדר כחדש. יש לשים לב שפיירפוקס כבר אינו שולח כותרת HTTP בשם <code>Accept-Charset</code>, כך שאין צורך לקחת בחשבון מה יפורסם ב-<code>Accept-Charset</code> כאשר מגדירים קידוד לעת מצוא.</p>
-
-<p>למיקומים בהם הקידוד לעת מצוא הוא כעת  ISO-8859-1, הקידוד חייב להשתנות ל-windows-1252. ISO-8859-1 is decoded באותה דרך בדיוק כמו windows-1252, אך פיירפוקס עובר לטפל ב- windows-1252 כמו בתווית המועדפת עבור קידוד זה בהתאם ל- <a href="http://encoding.spec.whatwg.org/" title="http://encoding.spec.whatwg.org/">Encoding Standard</a>.</p>
-
-<p>עבור מיקומים שבהם ל- Internet Explorer נתח שוק יותר גדול מזה של  Firefox, הקידוד לעת מצוא צריך באופן טיפוסי להיות מוגדר לאותו ערך כמו ב-Internet Explorer. .ניתן לראות את הקידוד לעת מצוא שיש לדפדפן מסויים על ידי טעינת  <a href="http://hsivonen.iki.fi/test/moz/check-charset.htm" title="http://hsivonen.iki.fi/test/moz/check-charset.htm">test page</a>. (יש לדאוג להשתמש בהתקנת דפדפן שנותרה לה הגדרות ברירת מחדל כשחוקרים זאת!)</p>
-
-<p>עבור מיקומים שבהם ל- Firefox מתח שוק גדול יותר מזה של Internet Explorer, סביר להניח כי הטוב ביותר הוא לא לשנות את הקידוד לעת מצוא  אפילו אם אינו תואם את ההדרכה שניתנה לעיל . (לדוגמא, קידוד פיירפוקס עבור המיקומים  הפולני, ההונגרי והצ'כי  סביר שיהיה צריך להמשיך להיות   ISO-8859-2 למרות של-IE הגדרת מיקום לעת-מצוא שונה.)</p>
-
-<p>כאשר בספק יש להשתמש ב-windows-1252 כקידוד לעת-מצוא.</p>
-
-<h2 id="ציון_אופן_הזיהוי_ההתחלתי">ציון אופן הזיהוי ההתחלתי</h2>
-
-<p>אופן הזיהוי ההתחלתי מצויין בהעדפה  <code>intl.charset.detector</code> ב- <code>intl.properties</code>. הגדרה זו חייבת לישאר ריקה לכל המיקומים  שאינם הרוסי, האוקראיני והיפני.  . באף מצב אין לציין את הגלאי "universal". הוא אינו אוניברסלי למרות שמו!</p>
-
-<h2 id="חריגים_עבור_שפות_מיעוט">חריגים עבור שפות מיעוט</h2>
-
-<p>אם ההתאמה למיקומים היא עבור שפת מיעוט והמשתמש הטיפוסי יודע לקרוא את שפת הרוב  של האזור והשתמשים קוראים תוכן אינטרנטי בשפת הרוב של האזר לעתים קרובות מואוד, יהא זה הולם לציין את הקידוד לעת מצוא ואת הזיהוי הראשוני להיות זהה לזה של ההתאמה למיקום עבור שפת הרוב של האזור,  לדוגמא, עבור הגדרת מיקום של שפת מיעוט ברוסיה, יהא הולם להעתיק רת הגדרות המיקום הרוסיות.</p>
-
-<h2 id="הפיכת_מספר_קידודים_לניתנים_לבחירה_בקלות_מתוך_תפריט_קידודי_תווים">הפיכת מספר קידודים לניתנים לבחירה בקלות מתוך תפריט קידודי תווים</h2>
-
-<p>ההעדפה <code>intl.charsetmenu.browser.static</code> ב- <code>intl.properties</code> הופכת מספר קידודי תווים לזמינים בקלות רבה יותר בתפריט קידודי תווים בדפדפן. על הערך להיות רשימה מופרדת ע"י פסיקים של שמות קידודים קאנוניים.  על הרשימה לכלול לפחות את הקידודים לעת מצוא, את windows-1252 ואת UTF-8. למיקומים שבהם יש יותר מקידוד אחד מהדור הישן, על כל הקידודים האלה להיכלל. לדוגמא, הקידוד לעת מצוא עבור יפני הוא  Shift_JIS, אבל יש עוד קידודים מהדור הישן  : ISO-2022-JP ו- EUC-JP. לכן, יהיה הגיוני אם הרשימה תהיה Shift_JIS, EUC-JP, ISO-2022-JP, windows-1252, UTF-8.</p>
diff --git a/files/he/web/guide/performance/index.html b/files/he/web/guide/performance/index.html
deleted file mode 100644
index 6c363e0a0c..0000000000
--- a/files/he/web/guide/performance/index.html
+++ /dev/null
@@ -1,23 +0,0 @@
----
-title: אופטימיזציה וביצועים
-slug: Web/Guide/Performance
-tags:
- - אופטימיזציה
- - אינטרנט
- - ביצועים
- - נחיתה
- - רשת
-translation_of: Web/Guide/Performance
----
-<p dir="rtl">בעת בניית אתרים ואפליקציות אינטרנט מודרניים, חשוב לגרום לתוכן שלך לתפקד היטב. כלומר לגרום לו להיות מהיר ויעיל. דבר זה מאפשר לתפקד באופן אפקטיבי הן למשתמשי מערכת מחשבים נייחים חזקים, והן למכשירים ניידים פחות חזקיפ. קיימים מספר כלים זמינים לבדיקצת ביצועים של אתר או בלוג. הכלים הראויים ביותר לציון רשומים להלן.</p>
-
-<ul dir="rtl">
- <li><a href="https://developers.google.com/speed/pagespeed/insights/" rel="resources">Google PageSpeed Insights</a></li>
- <li><a href="https://developers.google.com/web/tools/lighthouse/">Lighthouse</a></li>
- <li><a href="https://www.webpagetest.org/">WebPageTest</a></li>
- <li>כלי פיתוח של דפדפנים</li>
-</ul>
-
-<p dir="rtl">המשאבים לעיל כוללים גם את שיטות העבודה המומלצות לשיפור ביצועים. חשוב לתת עדיפות לביצועים, תוך התחשבות בביצועי הרשת במהלך הפיתוח, כדי שמשתמשים יזכו לחווית המשתמש הטובה ביותר.</p>
-
-<p dir="rtl">{{LandingPageListSubpages}}</p>
diff --git a/files/he/web/html/element/a/index.html b/files/he/web/html/element/a/index.html
deleted file mode 100644
index de79afa3e5..0000000000
--- a/files/he/web/html/element/a/index.html
+++ /dev/null
@@ -1,90 +0,0 @@
----
-title: '<a>: תגית קישור'
-slug: Web/HTML/Element/a
-translation_of: Web/HTML/Element/a
----
-<p>{{HTMLRef}}</p>
-
-<p dir="rtl">תגית <strong><code>&lt;a&gt;</code></strong> מוסיפה קישור טקסט/תמונה במסמך ה-HTML. זוהי תגית מסוג Inline המסמנת את האלמנט עצמו בלבד.</p>
-
-<p> </p>
-
-<p>{{EmbedInteractiveExample("pages/tabbed/a.html", "tabbed-standard")}}</p>
-
-<p> </p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות Inline.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>טקסטים, תמונות ומספרים
- <p> </p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>תגית זו מורשית להופיע בגוף המסמך אך אינה חייבת להיות כפופה בצורה ישירה אל תגית {{HTMLElement("body")}}.</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLAnchorElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<p dir="rtl">href - משמש להוספת כתובת קישור.<br>
- target - קובע היכן יפתח הקישור (עמוד הנוכחי, כרטיסייה חדשה וכו').<br>
- id - מזהה המשמש לקישור פנימי בין עמודים.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_1_-_קישור_סטנדרטי">דוגמא 1 - קישור סטנדרטי</h2>
-
- <pre>&lt;!-- anchor linking to external file --&gt;
-&lt;a href="https://www.mozilla.com/"&gt;
-External Link
-&lt;/a&gt;
-</pre>
- </dt>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_2_-_קישור_למזהה_פנימי_בעמוד">דוגמא 2 - קישור למזהה פנימי בעמוד</h2>
-
- <pre>&lt;!-- links to element on this page with id="attr-href" --&gt;
-&lt;a href="#attr-href"&gt;
-Description of Same-Page Links
-&lt;/a&gt;
-
-</pre>
- </dt>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_3_-_תמונה_לחיצה">דוגמא 3 - תמונה לחיצה</h2>
-
- <pre>&lt;a href="https://developer.mozilla.org/en-US/" target="_blank"&gt;
-  &lt;img src="https://mdn.mozillademos.org/files/6851/mdn_logo.png"
-       alt="MDN logo" /&gt;
-&lt;/a&gt;
-</pre>
- </dt>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_4_-_קישור_לדואל">דוגמא 4 - קישור לדוא"ל</h2>
-
- <pre>&lt;a href="mailto:nowhere@mozilla.org"&gt;Send email to nowhere&lt;/a&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("p")}}</li>
- <li>{{HTMLElement("img")}}</li>
- <li>{{HTMLElement("br")}}</li>
-</ul>
diff --git a/files/he/web/html/element/address/index.html b/files/he/web/html/element/address/index.html
deleted file mode 100644
index d7997e2296..0000000000
--- a/files/he/web/html/element/address/index.html
+++ /dev/null
@@ -1,77 +0,0 @@
----
-title: '<address>: תגית לסימון כתובת'
-slug: Web/HTML/Element/address
-tags:
- - Address
- - HTML
- - כתובת
-translation_of: Web/HTML/Element/address
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;address&gt;</code></strong> נועדה כדי להציג מידע ליצירת קשר אודות אדם יחיד או ארגון.</p>
-
-<p>{{EmbedInteractiveExample("pages/tabbed/address.html", "tabbed-standard")}}</p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות לארגון תוכן.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>&lt;hgroup&gt;<br>
- &lt;h1-h6&gt;<br>
- &lt;article&gt;<br>
- &lt;aside&gt;<br>
- &lt;section&gt;<br>
- &lt;nav&gt;<br>
- &lt;header&gt;<br>
- &lt;footer&gt;</p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>תגית זו מורשת להופיע בגוף המסמך אך אינה חייבת להיות כפופה בצורה ישירה אל תגית {{HTMLElement("body")}}.</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <pre>&lt;address&gt;
-  You can contact author at &lt;a href="http://www.somedomain.com/contact"&gt;
-  www.somedomain.com&lt;/a&gt;.&lt;br&gt;
-  If you see any bugs, please &lt;a href="mailto:webmaster@somedomain.com"&gt;
-  contact webmaster&lt;/a&gt;.&lt;br&gt;
-  You may also want to visit us:&lt;br&gt;
-  Mozilla Foundation&lt;br&gt;
-  331 E Evelyn Ave&lt;br&gt;
-  Mountain View, CA 94041&lt;br&gt;
-  USA
-&lt;/address&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("nav")}} </li>
- <li>{{HTMLElement("article")}} </li>
- <li>{{HTMLElement("aside")}} </li>
- <li>{{HTMLElement("h1")}} </li>
- <li>{{HTMLElement("hgroup")}}</li>
-</ul>
diff --git a/files/he/web/html/element/applet/index.html b/files/he/web/html/element/applet/index.html
deleted file mode 100644
index 5c85cfaa83..0000000000
--- a/files/he/web/html/element/applet/index.html
+++ /dev/null
@@ -1,37 +0,0 @@
----
-title: '<applet>: הטמעה של ישומון ג''אווה בעמוד'
-slug: Web/HTML/Element/applet
-translation_of: Web/HTML/Element/applet
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;applet&gt;</code></strong> מטמיעה יישומון Java במסמך ה-HTML. אלמנט זה הוצא משימוש לטובת {{HTMLElement ("object")}}.</p>
-
-<p dir="rtl"><strong>* זוהי תגית ישנה ואינה חלק משפת HTML גרסה 5, השימוש ביישומוני Java בדפדפני אינטרנט הופסק.</strong></p>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<ul>
- <li>{{htmlattrdef("align")}} -  מציינת את שם העמודה מאובייקט מקור הנתונים.</li>
- <li>{{htmlattrdef("alt")}} - תכונה זו משמשת למיקום היישומון בדף ביחס לתוכן.</li>
- <li>{{htmlattrdef("code")}} - תכונה זו מציינת את כתובת האתר של קובץ היישומון.</li>
-</ul>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <pre>&lt;applet code="game.class" align="left" archive="game.zip" height="250" width="350"&gt;
-  &lt;param name="difficulty" value="easy"&gt;
-  &lt;b&gt;Sorry, you need Java to play this game.&lt;/b&gt;
-&lt;/applet&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("object")}}</li>
- <li>{{HTMLElement("embed")}}</li>
-</ul>
diff --git a/files/he/web/html/element/article/index.html b/files/he/web/html/element/article/index.html
deleted file mode 100644
index f58e278fc5..0000000000
--- a/files/he/web/html/element/article/index.html
+++ /dev/null
@@ -1,102 +0,0 @@
----
-title: '<article>: תגית לסימון אזור תוכן'
-slug: Web/HTML/Element/article
-translation_of: Web/HTML/Element/article
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;article&gt;</code></strong> הינה עצמאית ומגדירה אזור תוכן במסמך ה-HTML.<br>
- התוכן שיוזן בין התגיות עשוי להיות כתבה, מאמר, תגובה או הודעה.</p>
-
-<p>{{EmbedInteractiveExample("pages/tabbed/article.html", "tabbed-standard")}}</p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות לארגון תוכן.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>&lt;a&gt;, &lt;abbr&gt;, &lt;address&gt;, &lt;article&gt;, &lt;aside&gt;, &lt;audio&gt;, &lt;b&gt;,&lt;bdo&gt;, &lt;bdi&gt;, &lt;blockquote&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;del&gt;, &lt;details&gt;, &lt;dfn&gt;, &lt;div&gt;, &lt;dl&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;fieldset&gt;, &lt;figure&gt;, &lt;footer&gt;, &lt;form&gt;, &lt;h1&gt;, &lt;h2&gt;, &lt;h3&gt;, &lt;h4&gt;, &lt;h5&gt;, &lt;h6&gt;, &lt;header&gt;, &lt;hgroup&gt;, &lt;hr&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;ins&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;main&gt;, &lt;map&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;menu&gt;, &lt;meter&gt;, &lt;nav&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;ol&gt;, &lt;output&gt;, &lt;p&gt;, &lt;pre&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;s&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;section&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;table&gt;, &lt;template&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;ul&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt;.</p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>תגית זו מורשת להופיע בגוף המסמך אך אינה חייבת להיות כפופה בצורה ישירה אל תגית {{HTMLElement("section")}}.</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <pre>&lt;article class="film_review"&gt;
-  &lt;header&gt;
-    &lt;h2&gt;Jurassic Park&lt;/h2&gt;
-  &lt;/header&gt;
-  &lt;section class="main_review"&gt;
-    &lt;p&gt;Dinos were great!&lt;/p&gt;
-  &lt;/section&gt;
-  &lt;section class="user_reviews"&gt;
-    &lt;article class="user_review"&gt;
-      &lt;p&gt;Way too scary for me.&lt;/p&gt;
-      &lt;footer&gt;
-        &lt;p&gt;
-          Posted on
-          &lt;time datetime="2015-05-16 19:00"&gt;May 16&lt;/time&gt;
-          by Lisa.
-        &lt;/p&gt;
-      &lt;/footer&gt;
-    &lt;/article&gt;
-    &lt;article class="user_review"&gt;
-      &lt;p&gt;I agree, dinos are my favorite.&lt;/p&gt;
-      &lt;footer&gt;
-        &lt;p&gt;
-          Posted on
-          &lt;time datetime="2015-05-17 19:00"&gt;May 17&lt;/time&gt;
-          by Tom.
-        &lt;/p&gt;
-      &lt;/footer&gt;
-    &lt;/article&gt;
-  &lt;/section&gt;
-  &lt;footer&gt;
-    &lt;p&gt;
-      Posted on
-      &lt;time datetime="2015-05-15 19:00"&gt;May 15&lt;/time&gt;
-      by Staff.
-    &lt;/p&gt;
-  &lt;/footer&gt;
-&lt;/article&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="הערות">הערות</h2>
-
-<ul dir="rtl">
- <li>כותרת (&lt;h1&gt; - &lt;h6&gt;) משמשת לרוב כילד של האלמנט &lt;article&gt;.</li>
- <li>ניתן להשתמש באלמנט &lt;article&gt; כפוסט או תגובה כהתייחסות לפוסט החיצוני.</li>
- <li>ניתן להוסיף את פרטי המחבר באמצעות אלמנט &lt;address&gt;.</li>
- <li>ניתן להוסיף תאריך ואת שעת הפרסום התוכן באמצעות מאפיין datetime של אלמנט &lt;time&gt;.</li>
-</ul>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("nav")}} </li>
- <li>{{HTMLElement("address")}} </li>
- <li>{{HTMLElement("aside")}} </li>
- <li>{{HTMLElement("h1")}} </li>
- <li>{{HTMLElement("hgroup")}}</li>
-</ul>
diff --git a/files/he/web/html/element/aside/index.html b/files/he/web/html/element/aside/index.html
deleted file mode 100644
index ae470009c2..0000000000
--- a/files/he/web/html/element/aside/index.html
+++ /dev/null
@@ -1,75 +0,0 @@
----
-title: '<aside>: תגית לסימון תפריט צד'
-slug: Web/HTML/Element/aside
-tags:
- - ארגון טקסט
- - תפריט צד
-translation_of: Web/HTML/Element/aside
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;aside&gt;</code></strong> מייצגת את התפריט / האזור הצדדי במסמך ה-HTML. תחת תגית זו נהוג להוסיף פרסומות, ציטוטים מטקסטים, תוספים, ורכיבי תוכן (ווידג'טים) המציגים מידע בצורה נגישה וישירה.</p>
-
-<div>{{EmbedInteractiveExample("pages/tabbed/aside.html", "tabbed-standard")}}</div>
-
-<p class="hidden">The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples </a> and send us a pull request.</p>
-
-<p> </p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות לארגון תוכן</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>&lt;a&gt;, &lt;abbr&gt;, &lt;address&gt;, &lt;article&gt;, &lt;aside&gt;, &lt;audio&gt;, &lt;b&gt;,&lt;bdo&gt;, &lt;bdi&gt;, &lt;blockquote&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;del&gt;, &lt;details&gt;, &lt;dfn&gt;, &lt;div&gt;, &lt;dl&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;fieldset&gt;, &lt;figure&gt;, &lt;footer&gt;, &lt;form&gt;, &lt;h1&gt;, &lt;h2&gt;, &lt;h3&gt;, &lt;h4&gt;, &lt;h5&gt;, &lt;h6&gt;, &lt;header&gt;, &lt;hgroup&gt;, &lt;hr&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;ins&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;main&gt;, &lt;map&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;menu&gt;, &lt;meter&gt;, &lt;nav&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;ol&gt;, &lt;output&gt;, &lt;p&gt;, &lt;pre&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;s&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;section&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;table&gt;, &lt;template&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;ul&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt;</p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>תגית זו מורשת להופיע בגוף המסמך אך אינה חייבת להיות כפופה בצורה ישירה אל תגית {{HTMLElement("body")}}.<br>
-  </td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <pre>&lt;article&gt;
-  &lt;p&gt;
-    The Disney movie &lt;cite&gt;The Little Mermaid&lt;/cite&gt; was
-    first released to theatres in 1989.
-  &lt;/p&gt;
-  &lt;aside&gt;
-    &lt;p&gt;
-      The movie earned $87 million during its initial release.
-    &lt;/p&gt;
-  &lt;/aside&gt;
-  &lt;p&gt;
-    More info about the movie...
-  &lt;/p&gt;
-&lt;/article&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("header")}}</li>
- <li>{{HTMLElement("aside")}}</li>
- <li>{{HTMLElement("div")}}</li>
-</ul>
diff --git a/files/he/web/html/element/b/index.html b/files/he/web/html/element/b/index.html
deleted file mode 100644
index 4ea004c0c6..0000000000
--- a/files/he/web/html/element/b/index.html
+++ /dev/null
@@ -1,68 +0,0 @@
----
-title: '<b>: תגית להדגשת טקסט'
-slug: Web/HTML/Element/b
-translation_of: Web/HTML/Element/b
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;b&gt;</code></strong> מציגה טקסט באופן מודגש, כיום מומלץ להשתמש בתגית <strong><code>&lt;string&gt;</code></strong> כדי לציין שהטקסט בעל חשיבות. בנוסף ניתן להשתמש בגיליונות סגנון מדורגים (CSS) באמצעות <a href="https://developer.mozilla.org/he/docs/Web/CSS/font-weight">font-weight</a>.</p>
-
-<p dir="rtl">{{EmbedInteractiveExample("pages/tabbed/b.html", "tabbed-standard")}}</p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות מסוג Inline.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p><code>&lt;abbr&gt;</code>, <code>&lt;audio&gt;</code>, <code>&lt;b&gt;</code>, <code>&lt;bdo&gt;</code>, <code>&lt;br&gt;</code>, <code>&lt;button&gt;</code>, <code>&lt;canvas&gt;</code>, <code>&lt;cite&gt;</code>, <code>&lt;code&gt;</code>, <code>&lt;command&gt;</code>, <code>&lt;data&gt;</code>, <code>&lt;datalist&gt;</code>, <code>&lt;dfn&gt;</code>, <code>&lt;em&gt;</code>, <code>&lt;embed&gt;</code>, <code>&lt;i&gt;</code>, <code>&lt;iframe&gt;</code>, <code>&lt;img&gt;</code>, <code>&lt;input&gt;</code>, <code>&lt;kbd&gt;</code>, <code>&lt;keygen&gt;</code>, <code>&lt;label&gt;</code>, <code>&lt;mark&gt;</code>, <code>&lt;math&gt;</code>, <code>&lt;meter&gt;</code>, <code>&lt;noscript&gt;</code>, <code>&lt;object&gt;</code>, <code>&lt;output&gt;</code>, <code>&lt;progress&gt;</code>, <code>&lt;q&gt;</code>, <code>&lt;ruby&gt;</code>, <code>&lt;samp&gt;</code>, <code>&lt;script&gt;</code>, <code>&lt;select&gt;</code>, <code>&lt;small&gt;</code>, <code>&lt;span&gt;</code>, <code>&lt;strong&gt;</code>, <code>&lt;sub&gt;</code>, <code>&lt;sup&gt;</code>, <code>&lt;svg&gt;</code>, <code>&lt;textarea&gt;</code>, <code>&lt;time&gt;</code>, <code>&lt;var&gt;</code>, <code>&lt;video&gt;</code>, <code>&lt;wbr&gt;</code></p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>תגית זו מורשת להופיע בגוף המסמך אך אינה חייבת להיות כפופה בצורה ישירה אל תגית {{HTMLElement("body")}}.</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <pre>&lt;p&gt;
-  This article describes several &lt;b class="keywords"&gt;text-level&lt;/b&gt; elements.
-  It explains their usage in an &lt;b class="keywords"&gt;HTML&lt;/b&gt; document.
-&lt;/p&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="הערות">הערות</h2>
-
-<p dir="rtl"><u>מה ההבדל בין תגית <strong><code>&lt;strong&gt;</code></strong> לתגית <strong><code>&lt;b&gt;</code></strong>?</u><br>
- שתיהן מדגישות את הטקסט בתוך התגית, אך משמעותה של תגית &lt;b&gt; היא השפעה על העיצוב בלבד.  מאידך, כאשר גולשים אל אתר מותאם ולוחצים על הקראה, הדפדפן רואה את תגית &lt;strong&gt; ויודע שיש צורך לקרוא את הטקסט ולהדגיש את הנמצא תחתיה.</p>
-
-<p dir="rtl">תגיות נוספות המשמשות להדגשת טקסט: {{HTMLElement("em")}}, {{HTMLElement("mark")}}. </p>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("a")}}</li>
- <li>{{HTMLElement("em")}}</li>
- <li>{{HTMLElement("strong")}}</li>
- <li>{{HTMLElement("small")}}</li>
- <li>{{HTMLElement("cite")}}</li>
- <li>{{HTMLElement("q")}}</li>
- <li>{{HTMLElement("dfn")}}</li>
-</ul>
diff --git a/files/he/web/html/element/bdi/index.html b/files/he/web/html/element/bdi/index.html
deleted file mode 100644
index 603ab6f015..0000000000
--- a/files/he/web/html/element/bdi/index.html
+++ /dev/null
@@ -1,60 +0,0 @@
----
-title: '<bdi>: תגית לבידוד טקסט בפורמט שונה'
-slug: Web/HTML/Element/bdi
-translation_of: Web/HTML/Element/bdi
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;bdi&gt;</code></strong> משמשת לציון קטע טקסט העשוי להיות מוצג בפורמט אחר או בסדר הפוך מאשר הטקסט שמסביבו.</p>
-
-<div>{{EmbedInteractiveExample("pages/tabbed/bdi.html", "tabbed-standard")}}</div>
-
-<p class="hidden">The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples </a> and send us a pull request.</p>
-
-<p> </p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות מסוג Inline</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>&lt;abbr&gt;, &lt;audio&gt;, &lt;b&gt;, &lt;bdo&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;dfn&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;meter&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;output&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt;</p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>&lt;abbr&gt;, &lt;audio&gt;, &lt;b&gt;, &lt;bdo&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;dfn&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;meter&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;output&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt;</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <p dir="rtl">בדוגמה שלהלן, סדר מחרוזת המילים בערבית יהיה מימין לשמאל.</p>
-
- <pre>&lt;p dir="ltr"&gt;This arabic word &lt;bdi&gt;ARABIC_PLACEHOLDER&lt;/bdi&gt;
-is automatically displayed right-to-left.&lt;/p&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("bdi")}}</li>
- <li>{{HTMLElement("p")}}</li>
-</ul>
diff --git a/files/he/web/html/element/br/index.html b/files/he/web/html/element/br/index.html
deleted file mode 100644
index abdd8960e3..0000000000
--- a/files/he/web/html/element/br/index.html
+++ /dev/null
@@ -1,62 +0,0 @@
----
-title: '<br>: תגית להורדת שורה'
-slug: Web/HTML/Element/br
-translation_of: Web/HTML/Element/br
----
-<p>{{HTMLRef}}</p>
-
-<p dir="rtl">תגית <strong><code>&lt;br&gt;</code></strong> מבצעת הורדת שורה במסמך ה-HTML. תגית זו שימושית לרוב בכתיבת טקסט שבו חלוקת הרווחים משפיעה על הבנתו: שיר, סיפור קצר או כתובת.</p>
-
-<p>{{EmbedInteractiveExample("pages/tabbed/br.html", "tabbed-standard")}}</p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות תוכן.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>לא נהוג לסגור תגית זו אך במסמכי XHTML נהוג לכתוב אותה באופן הבא: <strong><code>&lt;/ br&gt;</code></strong></p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>תגית זו מורשת להופיע בגוף המסמך אך אינה חייבת להיות כפופה בצורה ישירה אל תגית {{HTMLElement("body")}}.</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLBRElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <pre>Mozilla
-&lt;br&gt;
-331 E. Evelyn Avenue
-&lt;br&gt;
-Mountain View, CA
-&lt;br&gt;
-94041
-&lt;br&gt;
-USA
-&lt;br&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("hr")}}</li>
- <li>{{HTMLElement("p")}}</li>
-</ul>
diff --git a/files/he/web/html/element/canvas/index.html b/files/he/web/html/element/canvas/index.html
deleted file mode 100644
index eaac2dff23..0000000000
--- a/files/he/web/html/element/canvas/index.html
+++ /dev/null
@@ -1,70 +0,0 @@
----
-title: '<canvas>: תגית ליצירת צורות דו מימדיות'
-slug: Web/HTML/Element/canvas
-translation_of: Web/HTML/Element/canvas
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;canvas&gt;</code></strong> מאפשרת ליצור צורות דו מימדיות ולהטמיע אותן במסמך ה-HTML. <br>
- אלמנט זה יוצר אזור מלבני בו ניתן לצייר באמצעות קוד.</p>
-
-<div> </div>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>סקריפטים והטמעת תכנים</td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>&lt;abbr&gt;, &lt;audio&gt;, &lt;b&gt;, &lt;bdo&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;dfn&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;meter&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;output&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt; <br>
-  </td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLCanvasElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<p dir="rtl">{{htmlattrdef("height")}} - תכונה להגדרת גובה.</p>
-
-<p dir="rtl">{{htmlattrdef("width")}} - תכונה להגדרת רוחב.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_-_כותרת_ופסקה">דוגמא - כותרת ופסקה</h2>
-
- <pre>&lt;canvas id="canvas" width="300" height="300"&gt;
-  An alternative text describing what your canvas displays.
-&lt;/canvas&gt;</pre>
-
- <h4 dir="rtl" id="דדגכ">דדגכ</h4>
-
- <pre>&lt;script&gt;
-var canvas = document.getElementById('canvas');
-var ctx = canvas.getContext('2d');
-ctx.fillStyle = 'green';
-ctx.fillRect(10, 10, 100, 100);
-&lt;/script&gt;</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="הערות">הערות</h2>
-
-<p dir="rtl">* מומלץ להזין תוכן בין התגיות על מנת שזה יופיע במידה והדפדפן אינו תומך ב-Canvas.<br>
- * חובה להוסיף תג סגירה &lt;canvas/&gt;.<br>
-  </p>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li dir="rtl"><a href="https://developer.apple.com/library/archive/documentation/AudioVideo/Conceptual/HTML-canvas-guide/Introduction/Introduction.html">הקדמה ל-Canvas באתר Apple</a></li>
- <li dir="rtl"><a href="https://developer.mozilla.org/en-US/docs/Web/API/Canvas_API/Tutorial">מדריך למשתמש ב-Canvas</a></li>
- <li dir="rtl"><a href="https://simon.html5.org/dump/html5-canvas-cheat-sheet.html">ריכוז תגיות ותכונות של Canvas</a></li>
-</ul>
diff --git a/files/he/web/html/element/center/index.html b/files/he/web/html/element/center/index.html
deleted file mode 100644
index ed7838fe73..0000000000
--- a/files/he/web/html/element/center/index.html
+++ /dev/null
@@ -1,104 +0,0 @@
----
-title: '<center>: תגית למרכוז טקסט'
-slug: Web/HTML/Element/center
-translation_of: Web/HTML/Element/center
----
-<div> </div>
-
-<div>
-<p>{{HTMLRef}}</p>
-
-<p dir="rtl">תגית <strong><code>&lt;center&gt;</code></strong> מאגדת בתוכה מספר כותרות <strong><code>&lt;h1&gt;</code></strong> עד <strong><code>&lt;h6&gt;</code></strong> ונועדה כדי ליצור כותרות משנה.</p>
-
-<p dir="rtl">* <u><strong>תגית זו אינה חלק מתקן HTML5.</strong></u></p>
-
-<p> </p>
-
-<p>{{EmbedInteractiveExample("pages/tabbed/center.html", "tabbed-standard")}}</p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תוכן.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>{{HTMLElement("h1")}}<br>
- {{HTMLElement("h2")}}<br>
- {{HTMLElement("h3")}}<br>
- {{HTMLElement("h4")}}<br>
- {{HTMLElement("h5")}}<br>
- {{HTMLElement("h6")}}</td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>תגית זו מורשת להופיע בגוף המסמך אך אינה חייבת להיות כפופה בצורה ישירה אל תגית {{HTMLElement("body")}}.</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_-_מרכוז_טקסט_באמצעות_HTML">דוגמא - מרכוז טקסט באמצעות HTML</h2>
-
- <pre>&lt;center&gt;This text will be centered.
-&lt;p&gt;So will this paragraph.&lt;/p&gt;&lt;/center&gt;</pre>
- </dt>
-</dl>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_-_מרכוז_טקסט_באמצעות_CSS">דוגמא - מרכוז טקסט באמצעות CSS</h2>
-
- <pre>&lt;div style="text-align:center"&gt;This text will be centered.
-&lt;p&gt;So will this paragraph.&lt;/p&gt;&lt;/div&gt;</pre>
- </dt>
-</dl>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_2_-_מרכוז_טקסט_באמצעות_CSS">דוגמא 2 - מרכוז טקסט באמצעות CSS</h2>
-
- <pre>&lt;p style="text-align:center"&gt;This line will be centered.&lt;br&gt;
-And so will this line.&lt;/p&gt;</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{Cssxref("text-align")}}</li>
- <li>{{Cssxref("display")}}</li>
-</ul>
-</div>
-
-<div> </div>
-
-<div> </div>
-
-<div>{{obsolete_header()}}</div>
-
-<p><span class="seoSummary">The obsolete <strong>HTML Center Element</strong> (<strong><code>&lt;center&gt;</code></strong>) is a <a href="/en-US/docs/HTML/Block-level_elements" title="HTML/Block-level_elements">block-level element</a> that displays its block-level or inline contents centered horizontally within its containing element.</span> The container is usually, but isn't required to be, {{HTMLElement("body")}}.</p>
-
-<p>This tag has been deprecated in HTML 4 (and XHTML 1) in favor of the <a href="/en-US/docs/Web/CSS" title="/en-US/docs/Web/CSS">CSS</a> {{Cssxref("text-align")}} property, which can be applied to the {{HTMLElement("div")}} element or to an individual {{HTMLElement("p")}}. For centering blocks, use other CSS properties like {{Cssxref("margin-left")}} and {{Cssxref("margin-right")}} and set them to <code>auto</code> (or set {{Cssxref("margin")}} to <code>0 auto</code>).</p>
-
-<h2 id="DOM_interface">DOM interface</h2>
-
-<p>This element implements the {{domxref("HTMLElement")}} interface.</p>
-
-<div class="note">
-<p><strong>Implementation note:</strong> up to Gecko 1.9.2 inclusive, Firefox implements the {{domxref("HTMLSpanElement")}} interface for this element.</p>
-</div>
-
-<h2 id="Example_1" name="Example_1">Note</h2>
-
-<p>Applying {{Cssxref("text-align")}}<code>:center</code> to a {{HTMLElement("div")}} or {{HTMLElement("p")}} element centers the <em>contents</em> of those elements while leaving their overall dimensions unchanged.</p>
diff --git a/files/he/web/html/element/cite/index.html b/files/he/web/html/element/cite/index.html
deleted file mode 100644
index f511031edf..0000000000
--- a/files/he/web/html/element/cite/index.html
+++ /dev/null
@@ -1,52 +0,0 @@
----
-title: '<cite>: תגית ציטוט'
-slug: Web/HTML/Element/cite
-translation_of: Web/HTML/Element/cite
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;cite&gt;</code></strong> מגדירה ציטוט וביצוע הפניה לתוכן ממנו נלקחו הנתונים.</p>
-
-<p>{{EmbedInteractiveExample("pages/tabbed/cite.html", "tabbed-standard")}}</p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות Inline.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>&lt;abbr&gt;, &lt;audio&gt;, &lt;b&gt;, &lt;bdo&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;dfn&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;meter&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;output&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt; </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>&lt;abbr&gt;, &lt;audio&gt;, &lt;b&gt;, &lt;bdo&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;dfn&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;meter&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;output&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt;</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
- </dt>
- <dt dir="rtl">
- <pre>&lt;p&gt;More information can be found in &lt;cite&gt;[ISO-0000]&lt;/cite&gt;.&lt;/p&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("q")}}</li>
- <li>{{HTMLElement("blockquote")}}</li>
-</ul>
diff --git a/files/he/web/html/element/del/index.html b/files/he/web/html/element/del/index.html
deleted file mode 100644
index e024873f58..0000000000
--- a/files/he/web/html/element/del/index.html
+++ /dev/null
@@ -1,64 +0,0 @@
----
-title: '<del>: תגית לסימון טקסט המיועד למחיקה'
-slug: Web/HTML/Element/del
-translation_of: Web/HTML/Element/del
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;del&gt;</code></strong> מציגה טקסט מחוק המסומן בקו בפסקה או בחלק ממאמר.</p>
-
-<div>{{EmbedInteractiveExample("pages/tabbed/del.html", "tabbed-standard")}}</div>
-
-<p class="hidden">The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples </a> and send us a pull request.</p>
-
-<p> </p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות לסימון שינויים</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>טקסט ומספרים</p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>&lt;abbr&gt;, &lt;audio&gt;, &lt;b&gt;, &lt;bdo&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;dfn&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;meter&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;output&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt;</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLModElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<ul>
- <li>{{htmlattrdef("cite")}} - תכונה המסבירה את מהות השינוי.</li>
- <li>{{htmlattrdef("datetime")}} - תכונה זו מציינת את השעה והתאריך של השינוי וחייבת להיות מחרוזת תאריך חוקית.</li>
-</ul>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <pre>&lt;p&gt;&lt;del&gt;This text has been deleted&lt;/del&gt;,
-here is the rest of the paragraph.&lt;/p&gt;
-&lt;del&gt;&lt;p&gt;This paragraph has been deleted.&lt;/p&gt;&lt;/del&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("strong")}}</li>
- <li>{{HTMLElement("ins")}}</li>
-</ul>
diff --git a/files/he/web/html/element/em/index.html b/files/he/web/html/element/em/index.html
deleted file mode 100644
index 469e73abe7..0000000000
--- a/files/he/web/html/element/em/index.html
+++ /dev/null
@@ -1,64 +0,0 @@
----
-title: '<em>: תגית להדגשת טקסט'
-slug: Web/HTML/Element/em
-translation_of: Web/HTML/Element/em
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;em&gt;</code></strong> מציגה פסקת טקסט באופן מודגש.</p>
-
-<p>{{EmbedInteractiveExample("pages/tabbed/em.html", "tabbed-standard")}}</p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות מסוג Inline.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p><code>&lt;abbr&gt;</code>, <code>&lt;audio&gt;</code>, <code>&lt;b&gt;</code>, <code>&lt;bdo&gt;</code>, <code>&lt;br&gt;</code>, <code>&lt;button&gt;</code>, <code>&lt;canvas&gt;</code>, <code>&lt;cite&gt;</code>, <code>&lt;code&gt;</code>, <code>&lt;command&gt;</code>, <code>&lt;data&gt;</code>, <code>&lt;datalist&gt;</code>, <code>&lt;dfn&gt;</code>, <code>&lt;em&gt;</code>, <code>&lt;embed&gt;</code>, <code>&lt;i&gt;</code>, <code>&lt;iframe&gt;</code>, <code>&lt;img&gt;</code>, <code>&lt;input&gt;</code>, <code>&lt;kbd&gt;</code>, <code>&lt;keygen&gt;</code>, <code>&lt;label&gt;</code>, <code>&lt;mark&gt;</code>, <code>&lt;math&gt;</code>, <code>&lt;meter&gt;</code>, <code>&lt;noscript&gt;</code>, <code>&lt;object&gt;</code>, <code>&lt;output&gt;</code>, <code>&lt;progress&gt;</code>, <code>&lt;q&gt;</code>, <code>&lt;ruby&gt;</code>, <code>&lt;samp&gt;</code>, <code>&lt;script&gt;</code>, <code>&lt;select&gt;</code>, <code>&lt;small&gt;</code>, <code>&lt;span&gt;</code>, <code>&lt;strong&gt;</code>, <code>&lt;sub&gt;</code>, <code>&lt;sup&gt;</code>, <code>&lt;svg&gt;</code>, <code>&lt;textarea&gt;</code>, <code>&lt;time&gt;</code>, <code>&lt;var&gt;</code>, <code>&lt;video&gt;</code>, <code>&lt;wbr&gt;</code></p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>תגית זו מורשת להופיע בגוף המסמך אך אינה חייבת להיות כפופה בצורה ישירה אל תגית {{HTMLElement("body")}}.</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">אלמנט זה כולל את <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a> בלבד.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_-_שימוש_בסיסי_בתגית">דוגמא - שימוש בסיסי בתגית</h2>
-
- <pre>&lt;p&gt;Before proceeding, &lt;strong&gt;make sure you put on your safety goggles&lt;/strong&gt;.&lt;/p&gt;
-</pre>
-
- <h2 dir="rtl" id="דוגמא_-_שימוש_בתגית_לצורך_תוית_אזהרה">דוגמא - שימוש בתגית לצורך תוית אזהרה</h2>
-
- <pre>&lt;p&gt;&lt;strong&gt;Important:&lt;/strong&gt; Before proceeding, make sure you add plenty of butter.&lt;/p&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="הערות">הערות</h2>
-
-<p><u>מה ההבדל בין תגית <strong><code>&lt;strong&gt;</code></strong> לתגית <strong><code>&lt;b&gt;</code></strong>?</u><br>
- שתיהן מדגישות את הטקסט בתוך התגית, אך משמעותה של תגית &lt;b&gt; היא השפעה על העיצוב בלבד.  מאידך, כאשר גולשים אל אתר מותאם ולוחצים על הקראה, הדפדפן רואה את תגית &lt;strong&gt; ויודע שיש צורך לקרוא את הטקסט ולהדגיש את הנמצא תחתיה.</p>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("strong")}}</li>
- <li>{{HTMLElement("b")}}</li>
- <li>{{cssxref("font-weight")}}</li>
-</ul>
diff --git a/files/he/web/html/element/figcaption/index.html b/files/he/web/html/element/figcaption/index.html
deleted file mode 100644
index ca4dd15d5b..0000000000
--- a/files/he/web/html/element/figcaption/index.html
+++ /dev/null
@@ -1,67 +0,0 @@
----
-title: '<figcaption>: כותרת לאלמנט Figure'
-slug: Web/HTML/Element/figcaption
-translation_of: Web/HTML/Element/figcaption
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;figcaption&gt;</code></strong> היא תגית המייצגת כותרת או טקסט לאלמנט האב שלו תגית <a href="/he/docs/Web/HTML/Element/figure">&lt;figure&gt;</a>.</p>
-
-<div>{{EmbedInteractiveExample("pages/tabbed/figcaption.html", "tabbed-standard")}}</div>
-
-<p class="hidden">The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples </a> and send us a pull request.</p>
-
-<p> </p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות להזנת תוכן.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>טקסט ומספרים.</p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>תגית זו מורשת להופיע בגוף המסמך אך חייבת להיות כפופה אל תגית {{HTMLElement("figure")}}.</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_-_תמונה">דוגמא - תמונה</h2>
-
-
- <figure>
- <pre class="brush: html">&lt;!-- Image with a caption --&gt;
-&lt;figure&gt;
-  &lt;img
-  src="https://developer.mozilla.org/static/img/favicon144.png"
-  alt="A robotic monster over the letters MDN."&gt;
-  &lt;figcaption&gt;MDN Logo&lt;/figcaption&gt;
-&lt;/figure&gt;
-</pre>
-
- <p> </p>
- </figure>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("figure")}}</li>
-</ul>
diff --git a/files/he/web/html/element/figure/index.html b/files/he/web/html/element/figure/index.html
deleted file mode 100644
index 23751858e3..0000000000
--- a/files/he/web/html/element/figure/index.html
+++ /dev/null
@@ -1,112 +0,0 @@
----
-title: '<figure>: תגית לעטיפת תמונה או גרף'
-slug: Web/HTML/Element/figure
-translation_of: Web/HTML/Element/figure
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;figure&gt;</code></strong> היא תגית עצמאית העוטפת תמונה או גרף במסמך ה-HTML ומאפשרת להוסיף להם כותרת באמצעות תגית משלימה <a href="/he/docs/Web/HTML/Element/figcaption">&lt;figcaption&gt;</a>.</p>
-
-<div>{{EmbedInteractiveExample("pages/tabbed/figure.html", "tabbed-standard")}}</div>
-
-<p class="hidden">The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples </a> and send us a pull request.</p>
-
-<p> </p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות להזנת תוכן.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>&lt;figcaption&gt;,&lt;img&gt;,&lt;abbr&gt;, &lt;audio&gt;, &lt;b&gt;, &lt;bdo&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;dfn&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;meter&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;output&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt;</p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>תגית זו מורשת להופיע בגוף המסמך אך אינה חייבת להיות כפופה בצורה ישירה אל תגית {{HTMLElement("body")}}.</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_-_תמונה">דוגמא - תמונה</h2>
-
-
- <figure>
- <pre class="brush: html">&lt;!-- Just an image --&gt;
-&lt;figure&gt;
-  &lt;img
-  src="https://developer.mozilla.org/static/img/favicon144.png"
-  alt="A robotic monster over the letters MDN."&gt;
-&lt;/figure&gt;
-
-&lt;!-- Image with a caption --&gt;
-&lt;figure&gt;
-  &lt;img
-  src="https://developer.mozilla.org/static/img/favicon144.png"
-  alt="A robotic monster over the letters MDN."&gt;
-  &lt;figcaption&gt;MDN Logo&lt;/figcaption&gt;
-&lt;/figure&gt;
-
-</pre>
-
- <h2 dir="rtl" id="דוגמא_-_קטע_קוד">דוגמא - קטע קוד</h2>
-
-
- <figure>
- <pre class="brush: html">&lt;figure&gt;
-  &lt;figcaption&gt;Get browser details using &lt;code&gt;navigator&lt;/code&gt;.&lt;/figcaption&gt;
-  &lt;pre&gt;
-function NavigatorExample() {
-  var txt;
-  txt = "Browser CodeName: " + navigator.appCodeName;
-  txt+= "Browser Name: " + navigator.appName;
-  txt+= "Browser Version: " + navigator.appVersion ;
-  txt+= "Cookies Enabled: " + navigator.cookieEnabled;
-  txt+= "Platform: " + navigator.platform;
-  txt+= "User-agent header: " + navigator.userAgent;
-}&lt;/pre&gt;
-&lt;/figure&gt;
-</pre>
- </figure>
-
- <h2 dir="rtl" id="דוגמא_-_שיר">דוגמא - שיר</h2>
-
-
- <figure>
- <pre class="brush: html">&lt;figure&gt;
-  &lt;p style="white-space:pre"&gt;
-Bid me discourse, I will enchant thine ear,
-  Or like a fairy trip upon the green,
-Or, like a nymph, with long dishevell'd hair,
-  Dance on the sands, and yet no footing seen:
-Love is a spirit all compact of fire,
-  Not gross to sink, but light, and will aspire.&lt;/p&gt;
-  &lt;figcaption&gt;&lt;cite&gt;Venus and Adonis&lt;/cite&gt;,
-    by William Shakespeare&lt;/figcaption&gt;
-&lt;/figure&gt;</pre>
- </figure>
-
- <p> </p>
- </figure>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("figcaption")}}</li>
-</ul>
diff --git a/files/he/web/html/element/font/index.html b/files/he/web/html/element/font/index.html
deleted file mode 100644
index 307a527f49..0000000000
--- a/files/he/web/html/element/font/index.html
+++ /dev/null
@@ -1,38 +0,0 @@
----
-title: '<font>: תגית להגדרת גופן, צבע וגודל הטקסט'
-slug: Web/HTML/Element/font
-translation_of: Web/HTML/Element/font
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;font&gt;</code></strong> מגדירה את שם הפונט, צבע וגודל הטקסט במסמך ה-HTML.</p>
-
-<p dir="rtl"><strong>* זוהי תגית ישנה ואינה חלק משפת HTML גרסה 5, אלמנט זה עשוי לעבוד בכמה דפדפנים אך יתכן שלא יתמך בעתיד. יש להימנע משימוש בתגית זו.</strong></p>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<ul>
- <li>{{htmlattrdef("color")}} - תכונה זו קובעת את צבע הטקסט באמצעות שם הצבע או בפורמט הקסדצימלי #RRGGBB.</li>
- <li>{{htmlattrdef("face")}} - תכונה זו קובעת את הגופן בו הטקסט יוצג. </li>
- <li>{{htmlattrdef("size")}} - תכונה זו מציינת את גודל הגופן כערך מספרי או יחסי. הערכים המספריים נעים בין 1 ל-7 כאשר 1 הוא הקטן ביותר ו-3 ברירת המחדל.</li>
-</ul>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <pre>&lt;body&gt;
-&lt;font size="5" color="red"&gt;Please Write Your Text Here!&lt;/font&gt;
-&lt;/body&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("p")}}</li>
- <li>{{HTMLElement("body")}}</li>
-</ul>
diff --git a/files/he/web/html/element/footer/index.html b/files/he/web/html/element/footer/index.html
deleted file mode 100644
index 1080feba84..0000000000
--- a/files/he/web/html/element/footer/index.html
+++ /dev/null
@@ -1,62 +0,0 @@
----
-title: '<footer>: תגית לסימון תפריט תחתון'
-slug: Web/HTML/Element/footer
-translation_of: Web/HTML/Element/footer
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;footer&gt;</code></strong> מייצגת את התפריט / האזור התחתון במסמך ה-HTML. תחת תגית זו נהוג לכתוב זכויות יוצרים, קישורים, תנאי שימוש, טופס צור קשר, הרשמה לעדכונים ועוד.</p>
-
-<div>{{EmbedInteractiveExample("pages/tabbed/footer.html", "tabbed-standard")}}</div>
-
-<p class="hidden">The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples </a> and send us a pull request.</p>
-
-<p> </p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות לארגון תוכן</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>&lt;a&gt;, &lt;abbr&gt;, &lt;address&gt;, &lt;article&gt;, &lt;aside&gt;, &lt;audio&gt;, &lt;b&gt;,&lt;bdo&gt;, &lt;bdi&gt;, &lt;blockquote&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;del&gt;, &lt;details&gt;, &lt;dfn&gt;, &lt;div&gt;, &lt;dl&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;fieldset&gt;, &lt;figure&gt;, &lt;footer&gt;, &lt;form&gt;, &lt;h1&gt;, &lt;h2&gt;, &lt;h3&gt;, &lt;h4&gt;, &lt;h5&gt;, &lt;h6&gt;, &lt;header&gt;, &lt;hgroup&gt;, &lt;hr&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;ins&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;main&gt;, &lt;map&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;menu&gt;, &lt;meter&gt;, &lt;nav&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;ol&gt;, &lt;output&gt;, &lt;p&gt;, &lt;pre&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;s&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;section&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;table&gt;, &lt;template&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;ul&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt;</p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>תגית זו מורשת להופיע בגוף המסמך אך אינה חייבת להיות כפופה בצורה ישירה אל תגית {{HTMLElement("body")}}.<br>
-  </td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <pre>&lt;footer&gt;
-  Some copyright info or perhaps some author
-  info for an &amp;lt;article&amp;gt;?
-&lt;/footer&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("header")}}</li>
- <li>{{HTMLElement("aside")}}</li>
- <li>{{HTMLElement("div")}}</li>
-</ul>
diff --git a/files/he/web/html/element/head/index.html b/files/he/web/html/element/head/index.html
deleted file mode 100644
index 852c3fc249..0000000000
--- a/files/he/web/html/element/head/index.html
+++ /dev/null
@@ -1,68 +0,0 @@
----
-title: '<head>: תגית המציינת את ראש המסמך'
-slug: Web/HTML/Element/head
-tags:
- - HTML
- - כותרת
- - מטא-דטה
- - סקריפטים
- - עיצוב
- - תגיות
-translation_of: Web/HTML/Element/head
----
-<p>{{HTMLRef}}</p>
-
-<p dir="rtl">תגית <strong><code>&lt;head&gt;</code></strong> מספקת מידע כללי על מסמך ה-HTML כגון: כותרת, מטא-דאטה, קישורים <strong><a href="https://developer.mozilla.org/he/docs/Web/JavaScript">לסקריפטים (JavaScript)</a></strong> ו<strong><a href="https://developer.mozilla.org/he/docs/Web/CSS">גליונות סגנון מדורגים (CSS)</a></strong>.</p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>ללא.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>{{HTMLElement("title")}}<br>
- {{HTMLElement("link")}}<br>
- {{HTMLElement("meta")}}<br>
- {{HTMLElement("style")}}<br>
- {{HTMLElement("script")}}</p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>כפיפות לתגית {{HTMLElement("html")}} כילד ראשון.</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLHeadElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <pre>&lt;html&gt;
-  &lt;head&gt;
-    &lt;title&gt;Document title&lt;/title&gt;
-  &lt;/head&gt;
-&lt;/html&gt;</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("title")}}</li>
- <li>{{HTMLElement("meta")}}</li>
- <li>{{HTMLElement("link")}}</li>
- <li>{{HTMLElement("style")}}</li>
- <li>{{HTMLElement("script")}}</li>
-</ul>
diff --git a/files/he/web/html/element/header/index.html b/files/he/web/html/element/header/index.html
deleted file mode 100644
index b67364287c..0000000000
--- a/files/he/web/html/element/header/index.html
+++ /dev/null
@@ -1,72 +0,0 @@
----
-title: '<header>: תגית לסימון החלק העליון של המסמך'
-slug: Web/HTML/Element/header
-translation_of: Web/HTML/Element/header
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;header&gt;</code></strong> מייצגת את החלק העליון של מסמך ה-HTML. <br>
- אזור זה משמש ככותרת עבור <strong><code>&lt;section&gt;</code></strong> או בעבור כל הדף.<br>
- מלבד כותרת אזור זה מכיל תוכן עניינים, תיבת חיפוש, לוגו של חברה ועוד.</p>
-
-<div>{{EmbedInteractiveExample("pages/tabbed/header.html", "tabbed-standard")}}</div>
-
-<p class="hidden">The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples </a> and send us a pull request.</p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות לארגון תוכן</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>&lt;a&gt;, &lt;abbr&gt;, &lt;address&gt;, &lt;article&gt;, &lt;aside&gt;, &lt;audio&gt;, &lt;b&gt;,&lt;bdo&gt;, &lt;bdi&gt;, &lt;blockquote&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;del&gt;, &lt;details&gt;, &lt;dfn&gt;, &lt;div&gt;, &lt;dl&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;fieldset&gt;, &lt;figure&gt;, &lt;footer&gt;, &lt;form&gt;, &lt;h1&gt;, &lt;h2&gt;, &lt;h3&gt;, &lt;h4&gt;, &lt;h5&gt;, &lt;h6&gt;, &lt;header&gt;, &lt;hgroup&gt;, &lt;hr&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;ins&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;main&gt;, &lt;map&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;menu&gt;, &lt;meter&gt;, &lt;nav&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;ol&gt;, &lt;output&gt;, &lt;p&gt;, &lt;pre&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;s&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;section&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;table&gt;, &lt;template&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;ul&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt;</p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>&lt;a&gt;, &lt;abbr&gt;, &lt;address&gt;, &lt;article&gt;, &lt;aside&gt;, &lt;audio&gt;, &lt;b&gt;,&lt;bdo&gt;, &lt;bdi&gt;, &lt;blockquote&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;del&gt;, &lt;details&gt;, &lt;dfn&gt;, &lt;div&gt;, &lt;dl&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;fieldset&gt;, &lt;figure&gt;, &lt;footer&gt;, &lt;form&gt;, &lt;h1&gt;, &lt;h2&gt;, &lt;h3&gt;, &lt;h4&gt;, &lt;h5&gt;, &lt;h6&gt;, &lt;header&gt;, &lt;hgroup&gt;, &lt;hr&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;ins&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;main&gt;, &lt;map&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;menu&gt;, &lt;meter&gt;, &lt;nav&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;ol&gt;, &lt;output&gt;, &lt;p&gt;, &lt;pre&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;s&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;section&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;table&gt;, &lt;template&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;ul&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt;<br>
-  </td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_-_כותרת_של_דף">דוגמא - כותרת של דף</h2>
-
- <pre>&lt;header&gt;
-  &lt;h1&gt;Main Page Title&lt;/h1&gt;
-  &lt;img src="mdn-logo-sm.png" alt="MDN logo"&gt;
-&lt;/header&gt;</pre>
-
- <h2 dir="rtl" id="דוגמא_-_כותרת_של_מאמר">דוגמא - כותרת של מאמר</h2>
-
- <pre>&lt;article&gt;
-  &lt;header&gt;
-    &lt;h2&gt;The Planet Earth&lt;/h2&gt;
-    &lt;p&gt;Posted on Wednesday, 4 October 2017 by Jane Smith&lt;/p&gt;
-  &lt;/header&gt;
-  &lt;p&gt;We live on a planet that's blue and green, with so many things still unseen.&lt;/p&gt;
-  &lt;p&gt;&lt;a href="https://janesmith.com/the-planet-earth/"&gt;Continue reading....&lt;/a&gt;&lt;/p&gt;
-&lt;/article&gt;</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("section")}}</li>
- <li>{{HTMLElement("aside")}}</li>
- <li>{{HTMLElement("div")}}</li>
-</ul>
diff --git a/files/he/web/html/element/heading_elements/index.html b/files/he/web/html/element/heading_elements/index.html
deleted file mode 100644
index 6a8de4b0dd..0000000000
--- a/files/he/web/html/element/heading_elements/index.html
+++ /dev/null
@@ -1,77 +0,0 @@
----
-title: '<h1>–<h6>: תגית כותרת'
-slug: Web/HTML/Element/Heading_Elements
-translation_of: Web/HTML/Element/Heading_Elements
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגיות <strong><code>&lt;h1&gt;-&lt;h6&gt;</code></strong> מגדירות כותרת בגדלים שונים במסמך ה-HTML.<br>
- תגית <strong><code>&lt;h1&gt;</code></strong> היא הגדולה ביותר ותגית <strong><code>&lt;h6&gt;</code></strong> היא הקטנה ביותר.</p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות לארגון תוכן</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>&lt;abbr&gt;, &lt;audio&gt;, &lt;b&gt;, &lt;bdo&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;dfn&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;meter&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;output&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt; </p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>
- <p>&lt;a&gt;, &lt;abbr&gt;, &lt;address&gt;, &lt;article&gt;, &lt;aside&gt;, &lt;audio&gt;, &lt;b&gt;,&lt;bdo&gt;, &lt;bdi&gt;, &lt;blockquote&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;del&gt;, &lt;details&gt;, &lt;dfn&gt;, &lt;div&gt;, &lt;dl&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;fieldset&gt;, &lt;figure&gt;, &lt;footer&gt;, &lt;form&gt;, &lt;h1&gt;, &lt;h2&gt;, &lt;h3&gt;, &lt;h4&gt;, &lt;h5&gt;, &lt;h6&gt;, &lt;header&gt;, &lt;hgroup&gt;, &lt;hr&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;ins&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;main&gt;, &lt;map&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;menu&gt;, &lt;meter&gt;, &lt;nav&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;ol&gt;, &lt;output&gt;, &lt;p&gt;, &lt;pre&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;s&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;section&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;table&gt;, &lt;template&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;ul&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt;</p>
-
- <p>לעיתים תהיה כפופה באופן ישיר לאלמנט {{HTMLElement("hgroup")}} </p>
- </td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLHeadingElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_-_כותרות_בכל_הגדלים">דוגמא - כותרות בכל הגדלים</h2>
-
- <pre>&lt;h1&gt;Heading level 1&lt;/h1&gt;
-&lt;h2&gt;Heading level 2&lt;/h2&gt;
-&lt;h3&gt;Heading level 3&lt;/h3&gt;
-&lt;h4&gt;Heading level 4&lt;/h4&gt;
-&lt;h5&gt;Heading level 5&lt;/h5&gt;
-&lt;h6&gt;Heading level 6&lt;/h6&gt;</pre>
-
- <h2 dir="rtl" id="דוגמא_-_כותרות_ופסקה">דוגמא - כותרות ופסקה</h2>
-
- <pre>&lt;h1&gt;Heading elements&lt;/h1&gt;
-&lt;h2&gt;Summary&lt;/h2&gt;
-&lt;p&gt;Some text here...&lt;/p&gt;
-
-&lt;h2&gt;Examples&lt;/h2&gt;
-&lt;h3&gt;Example 1&lt;/h3&gt;
-&lt;p&gt;Some text here...&lt;/p&gt;
-
-&lt;h3&gt;Example 2&lt;/h3&gt;
-&lt;p&gt;Some text here...&lt;/p&gt;
-
-&lt;h2&gt;See also&lt;/h2&gt;
-&lt;p&gt;Some text here...&lt;/p&gt;</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("section")}}</li>
- <li>{{HTMLElement("p")}}</li>
- <li>{{HTMLElement("div")}}</li>
-</ul>
diff --git a/files/he/web/html/element/hgroup/index.html b/files/he/web/html/element/hgroup/index.html
deleted file mode 100644
index bd21a55ff9..0000000000
--- a/files/he/web/html/element/hgroup/index.html
+++ /dev/null
@@ -1,69 +0,0 @@
----
-title: '<hgroup>: תגית לאיגוד כותרות'
-slug: Web/HTML/Element/hgroup
-translation_of: Web/HTML/Element/hgroup
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;hgroup&gt;</code></strong> מאגדת בתוכה מספר כותרות <strong><code>&lt;h1&gt;</code></strong> עד <strong><code>&lt;h6&gt;</code></strong> ונועדה כדי ליצור כותרות משנה.</p>
-
-<div>{{EmbedInteractiveExample("pages/tabbed/hgroup.html", "tabbed-standard")}}</div>
-
-
-
-<p> </p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות לארגון תוכן.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>{{HTMLElement("h1")}}<br>
- {{HTMLElement("h2")}}<br>
- {{HTMLElement("h3")}}<br>
- {{HTMLElement("h4")}}<br>
- {{HTMLElement("h5")}}<br>
- {{HTMLElement("h6")}}</td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>תגית זו מורשת להופיע בגוף המסמך אך אינה חייבת להיות כפופה בצורה ישירה אל תגית {{HTMLElement("body")}}.</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <pre>&lt;hgroup id="document-title"&gt;
-  &lt;h1&gt;HTML&lt;/h1&gt;
-  &lt;h2&gt;Living Standard — Last Updated 12 August 2016&lt;/h2&gt;
-&lt;/hgroup&gt;</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("h1")}}</li>
- <li>{{HTMLElement("h2")}}</li>
- <li>{{HTMLElement("h3")}}</li>
- <li>{{HTMLElement("h4")}}</li>
- <li>{{HTMLElement("h5")}}</li>
- <li>{{HTMLElement("h6")}}</li>
- <li>{{HTMLElement("p")}}</li>
-</ul>
-
-<p> </p>
diff --git a/files/he/web/html/element/hr/index.html b/files/he/web/html/element/hr/index.html
deleted file mode 100644
index 357a5c36c2..0000000000
--- a/files/he/web/html/element/hr/index.html
+++ /dev/null
@@ -1,74 +0,0 @@
----
-title: '<hr>: תגית קו אופקי'
-slug: Web/HTML/Element/hr
-translation_of: Web/HTML/Element/hr
----
-<p>{{HTMLRef}}</p>
-
-<p dir="rtl">תגית <strong><code>&lt;hr&gt;</code></strong> מוסיפה קו אופקי המפריד בין פסקאות טקסט במסמך ה-HTML. זוהי תגית בלוק החוסמת את כל השורה.</p>
-
-<p> </p>
-
-<p>{{EmbedInteractiveExample("pages/tabbed/hr.html", "tabbed-standard")}}</p>
-
-<p> </p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות בלוק.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>תגית זו מוסיפה קו בלבד.</p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>תגית זו מורשית להופיע בגוף המסמך אך אינה חייבת להיות כפופה בצורה ישירה אל תגית {{HTMLElement("body")}}.</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLHRElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <pre>&lt;p&gt;
-  This is the first paragraph of text.
-  This is the first paragraph of text.
-  This is the first paragraph of text.
-  This is the first paragraph of text.
-&lt;/p&gt;
-
-&lt;hr&gt;
-
-&lt;p&gt;
-  This is the second paragraph.
-  This is the second paragraph.
-  This is the second paragraph.
-  This is the second paragraph.
-&lt;/p&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("p")}}</li>
- <li>{{HTMLElement("br")}}</li>
- <li>{{HTMLElement("a")}}</li>
-</ul>
-
-<p> </p>
diff --git a/files/he/web/html/element/html/index.html b/files/he/web/html/element/html/index.html
deleted file mode 100644
index 73afff129c..0000000000
--- a/files/he/web/html/element/html/index.html
+++ /dev/null
@@ -1,59 +0,0 @@
----
-title: '<html>: תגית ראשית'
-slug: Web/HTML/Element/html
-tags:
- - Element
- - HTML
- - תג עליון
- - תגיות
-translation_of: Web/HTML/Element/html
----
-<p>{{HTMLRef}}</p>
-
-<p dir="rtl">תגית <strong><code>&lt;html&gt;</code></strong> נחשבת לתגית העליונה ביותר של מסמך ה-HTML ולכן היא מכונה לעיתים תגית השורש (Root). כל שאר התגיות יהיו כפופות לתגית זו.</p>
-
-<table class="properties">
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>ללא.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>תגית {{HTMLElement("head")}}, ולאחר מכן תגית {{HTMLElement("body")}}.</td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>זוהי תגית השורש ולכן אין מעליה תגיות הורים.</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLHtmlElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt>{{htmlattrdef("manifest")}} {{obsolete_inline}}</dt>
- <dd dir="rtl">מציין את ה-URI, נתיב בו נמצאים משאבים לשמירה במטמון באופן מקומי.</dd>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <pre>&lt;!DOCTYPE html&gt;
-&lt;html lang="en"&gt;
- &lt;head&gt;...&lt;/head&gt;
- &lt;body&gt;...&lt;/body&gt;
-&lt;/html&gt;</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{MathMLElement("math")}}</li>
- <li>{{SVGElement("svg")}}</li>
-</ul>
diff --git a/files/he/web/html/element/index.html b/files/he/web/html/element/index.html
deleted file mode 100644
index 90dbee4532..0000000000
--- a/files/he/web/html/element/index.html
+++ /dev/null
@@ -1,105 +0,0 @@
----
-title: תגיות בשפת HTML
-slug: Web/HTML/Element
-tags:
- - Element
- - Elements
- - HTML
- - HTML5
- - 'HTML:Element Reference'
- - inline
- - אינליין
- - אלמנטים
- - בלוק
- - טבלאות
- - טפסים
- - פיתוח אתרים
- - רכיבי אינטרנט
- - תגיות
- - תגיות שורש
- - תוכן
- - תפריט צד
-translation_of: Web/HTML/Element
----
-<p>{{HTMLSidebar("Elements")}}</p>
-
-<p dir="rtl">כדי להפוך ידע זה לשימושי ככל האפשר, אנו מעמידים לרשות המשתמש רשימה של <a href="https://developer.mozilla.org/he/docs/Glossary/Element">אלמנטים</a> בשפת HTML, רשימת <a href="https://developer.mozilla.org/he/docs/Glossary/Tag">התגיות</a> מסודרת לפי נושאים כדי לסייע למשתמש למצוא את דרכו בקלות ולאתר את המידע  לו הוא זקוק. למידע נוסף והיכרות ראשונה עם שפת HTML למשתמשים מתחילים, בקר ב<a href="https://developer.mozilla.org/he/docs/Learn/HTML/%D7%9E%D7%91%D7%95%D7%90_%D7%9C%D7%A9%D7%A4%D7%AA_HTML">מבוא לשפת HTML</a>.</p>
-
-<h2 dir="rtl" id="תגיות_שורש">תגיות שורש</h2>
-
-<p dir="rtl">{{HTMLRefTable("HTML Root Element")}}</p>
-
-<h2 dir="rtl" id="מטא-דאטה_ונתונים_אודות_המסמך">מטא-דאטה ונתונים אודות המסמך</h2>
-
-<p dir="rtl">מטא-דאטה מכילים מידע על הדף: גיליונות סגנון מדורגים, סקריפטים ומידע המסייע <a href="https://developer.mozilla.org/he/docs/Glossary/Search_engine">למנועי החיפוש</a>, דפדפנים ועוד. ניתן להגדיר עיצובים וסקריפטים בדף עצמו או בקישור לקובץ נפרד המכיל את המידע.</p>
-
-<p dir="rtl">{{HTMLRefTable("HTML Document Metadata")}}</p>
-
-<h2 dir="rtl" id="תגיות_לסימון_גוף_המסמך">תגיות לסימון גוף המסמך</h2>
-
-<p dir="rtl">{{HTMLRefTable("Sectioning Root Element")}}</p>
-
-<h2 dir="rtl" id="תגיות_לארגון_תוכן">תגיות לארגון תוכן</h2>
-
-<p dir="rtl">תגיות המאפשרות לארגן ולחלק את המסמך בצורה נוחה והגיונית: כותרת עליונה ותחתונה, תוכן, מאמרים, תפריט ועוד.</p>
-
-<p dir="rtl">{{HTMLRefTable("HTML Sections")}}</p>
-
-<h2 dir="rtl" id="תגיות_להזנת_תוכן">תגיות להזנת תוכן</h2>
-
-<p dir="rtl">תגיות להזנת תוכן ימוקמו תחת התגית &lt;body&gt; ויסייעו בקידום האתר (SEO) ובבניית אתר מותאם, כמו כן מסייעות בסידור וארגון של מקטעי תוכן הנמצאים בגוף המסמך.</p>
-
-<p dir="rtl">{{HTMLRefTable("HTML Grouping Content")}}</p>
-
-<h2 dir="rtl" id="תגיות_מסוג_Inline">תגיות מסוג Inline</h2>
-
-<p dir="rtl">אלמנטים מסוג Inline מאפשרים למקם אותם באותה השורה עם אלמנטים נוספים, מכיוון שהם לא תופסים 100% מרוחב השורה, אלא רק את הרוחב המדויק.</p>
-
-<p dir="rtl">{{HTMLRefTable("HTML Text-Level Semantics")}}</p>
-
-<h2 dir="rtl" id="תמונות_ומולטימדיה">תמונות ומולטימדיה</h2>
-
-<p dir="rtl">שילוב קובצי מולטימדיה כגון: תמונות, סירטונים, מוסיקה ועוד.</p>
-
-<p dir="rtl">{{HTMLRefTable("multimedia")}}</p>
-
-<h2 dir="rtl" id="הטמעת_תכנים">הטמעת תכנים</h2>
-
-<p dir="rtl">שפת HTML מאפשרת הטמעה של אובייקטים חיצוניים בתוך המסמך.</p>
-
-<p dir="rtl">{{HTMLRefTable({"include":["HTML embedded content"], "exclude":["multimedia"]})}}</p>
-
-<h2 dir="rtl" id="סקריפטים">סקריפטים</h2>
-
-<p>In order to create dynamic content and Web applications, HTML supports the use of scripting languages, most prominently JavaScript</p>
-
-<p>Certain elements support this capability</p>
-
-<p dir="rtl">{{HTMLRefTable("HTML Scripting")}}</p>
-
-<h2 dir="rtl" id="תגיות_לסימון_שינויים">תגיות לסימון שינויים</h2>
-
-<p dir="rtl">תגיות אלה מאפשרות להציג שינויי טקסט.</p>
-
-<p>{{HTMLRefTable("HTML Edits")}}</p>
-
-<h2 dir="rtl" id="טבלאות">טבלאות</h2>
-
-<p dir="rtl">בניה והצגת נתונים באמצעות טבלאות.<br>
- {{HTMLRefTable("HTML tabular data")}}</p>
-
-<h2 dir="rtl" id="טפסים">טפסים</h2>
-
-<p dir="rtl">אלמנטים אלה הם דרך לקבלת קלט מהמשתמש.<br>
- לדוגמא: המשתמש ממלא טופס צור קשר ושולח אותו לאתר האינטרנט או היישום.<br>
- למידע נוסף בקר <a href="https://developer.mozilla.org/he/docs/Learn/HTML/%D7%98%D7%A4%D7%A1%D7%99%D7%9D">במדריך הטפסים</a>.</p>
-
-<p>{{HTMLRefTable({"include": ["HTML forms"], "exclude":["Deprecated"]})}}</p>
-
-<h2 dir="rtl" id="תגיות_אינטראקטיביות">תגיות אינטראקטיביות</h2>
-
-<p dir="rtl">{{HTMLRefTable("HTML interactive elements")}}</p>
-
-<h2 dir="rtl" id="רכיבי_אינטרנט">רכיבי אינטרנט</h2>
-
-<p dir="rtl">{{HTMLRefTable({"include":["Web Components"],"elements":["shadow"]})}}</p>
diff --git a/files/he/web/html/element/ins/index.html b/files/he/web/html/element/ins/index.html
deleted file mode 100644
index b59cc0ce4d..0000000000
--- a/files/he/web/html/element/ins/index.html
+++ /dev/null
@@ -1,58 +0,0 @@
----
-title: <ins>
-slug: Web/HTML/Element/ins
-translation_of: Web/HTML/Element/ins
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;ins&gt;</code></strong> מציגה פסקה / קטע טקסט חדש שהוכנס למסמך. </p>
-
-<div>{{EmbedInteractiveExample("pages/tabbed/ins.html", "tabbed-standard")}}</div>
-
-<p class="hidden">The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples </a> and send us a pull request.</p>
-
-<p> </p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות לסימון שינויים</td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>&lt;abbr&gt;, &lt;audio&gt;, &lt;b&gt;, &lt;bdo&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;dfn&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;meter&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;output&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt;</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLParagraphElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<p dir="rtl">{{htmlattrdef("cite")}} - תכונה זו מציגה את המקור או הסיבה לביצוע השינוי.</p>
-
-<p dir="rtl">datetime - תכונה זו מציגה את התאריך והשעה וחייבת להיות לפי הפורמטים הבאים:<br>
- * שעון 24 שעות.<br>
- * תאריך מדוייק על פי הלוח השנה הגרגוריאני.<br>
- * פרק זמן חוקי.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <pre>&lt;ins&gt;This text has been inserted&lt;/ins&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("del")}}</li>
- <li>{{HTMLElement("time")}}</li>
-</ul>
diff --git a/files/he/web/html/element/main/index.html b/files/he/web/html/element/main/index.html
deleted file mode 100644
index f21bf19e29..0000000000
--- a/files/he/web/html/element/main/index.html
+++ /dev/null
@@ -1,77 +0,0 @@
----
-title: '<main>: תגית לציון תוכן המאמר'
-slug: Web/HTML/Element/main
-translation_of: Web/HTML/Element/main
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;main&gt;</code></strong> מייצגת את התוכן הראשי במסמך ה-HTML. </p>
-
-<div>{{EmbedInteractiveExample("pages/tabbed/main.html", "tabbed-standard")}}</div>
-
-<p class="hidden">The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples </a> and send us a pull request.</p>
-
-<p> </p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות לארגון תוכן</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>&lt;a&gt;, &lt;abbr&gt;, &lt;address&gt;, &lt;article&gt;, &lt;aside&gt;, &lt;audio&gt;, &lt;b&gt;,&lt;bdo&gt;, &lt;bdi&gt;, &lt;blockquote&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;del&gt;, &lt;details&gt;, &lt;dfn&gt;, &lt;div&gt;, &lt;dl&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;fieldset&gt;, &lt;figure&gt;, &lt;footer&gt;, &lt;form&gt;, &lt;h1&gt;, &lt;h2&gt;, &lt;h3&gt;, &lt;h4&gt;, &lt;h5&gt;, &lt;h6&gt;, &lt;header&gt;, &lt;hgroup&gt;, &lt;hr&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;ins&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;main&gt;, &lt;map&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;menu&gt;, &lt;meter&gt;, &lt;nav&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;ol&gt;, &lt;output&gt;, &lt;p&gt;, &lt;pre&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;s&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;section&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;table&gt;, &lt;template&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;ul&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt;</p>
- </td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <pre>&lt;!-- other content --&gt;
-
-&lt;main&gt;
-  &lt;h1&gt;Apples&lt;/h1&gt;
-  &lt;p&gt;The apple is the pomaceous fruit of the apple tree.&lt;/p&gt;
-
-  &lt;article&gt;
-    &lt;h2&gt;Red Delicious&lt;/h2&gt;
-    &lt;p&gt;These bright red apples are the most common found in many
-    supermarkets.&lt;/p&gt;
-    &lt;p&gt;... &lt;/p&gt;
-    &lt;p&gt;... &lt;/p&gt;
-  &lt;/article&gt;
-
-  &lt;article&gt;
-    &lt;h2&gt;Granny Smith&lt;/h2&gt;
-    &lt;p&gt;These juicy, green apples make a great filling for
-    apple pies.&lt;/p&gt;
-    &lt;p&gt;... &lt;/p&gt;
-    &lt;p&gt;... &lt;/p&gt;
-  &lt;/article&gt;
-&lt;/main&gt;
-
-&lt;!-- other content --&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("header")}}</li>
- <li>{{HTMLElement("aside")}}</li>
- <li>{{HTMLElement("footer")}}</li>
-</ul>
diff --git a/files/he/web/html/element/mark/index.html b/files/he/web/html/element/mark/index.html
deleted file mode 100644
index bc770a767a..0000000000
--- a/files/he/web/html/element/mark/index.html
+++ /dev/null
@@ -1,86 +0,0 @@
----
-title: '<mark>: תגית לסימון טקסט'
-slug: Web/HTML/Element/mark
-tags:
- - HTML
- - אלמנט
- - הדגשה
- - טקסט
- - מרקר
- - סימון
-translation_of: Web/HTML/Element/mark
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;mark&gt;</code></strong> משמשת לסימון קטע בתוך טקסט אותו אנו מעוניינים להדגיש.</p>
-
-<div>{{EmbedInteractiveExample("pages/tabbed/mark.html", "tabbed-standard")}}</div>
-
-<p class="hidden">The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples </a> and send us a pull request.</p>
-
-<p> </p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות מסוג Inline</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>טקסט, סקריפטים, מספרים, נוסחאות, כותרות, טבלאות, טפסים.</p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>&lt;abbr&gt;, &lt;audio&gt;, &lt;b&gt;, &lt;bdo&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;dfn&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;meter&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;output&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt; </td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_-_סימון_טקסט_חשוב">דוגמא - סימון טקסט חשוב</h2>
-
- <pre>&lt;blockquote&gt;
-  It is a period of civil war. Rebel spaceships, striking from a
-  hidden base, have won their first victory against the evil
-  Galactic Empire. During the battle, &lt;mark&gt;Rebel spies managed
-  to steal secret plans&lt;/mark&gt; to the Empire’s ultimate weapon,
-  the DEATH STAR, an armored space station with enough power to
-  destroy an entire planet.
-&lt;/blockquote&gt;
-</pre>
- </dt>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_-_סימון_תוצאת_חיפוש_בתוך_טקסט">דוגמא - סימון תוצאת חיפוש בתוך טקסט</h2>
-
- <pre>&lt;p&gt;It is a dark time for the Rebellion. Although the Death
-Star has been destroyed, &lt;mark class="match"&gt;Imperial&lt;/mark&gt;
-troops have driven the Rebel forces from their hidden base and
-pursued them across the galaxy.&lt;/p&gt;
-
-&lt;p&gt;Evading the dreaded &lt;mark class="match"&gt;Imperial&lt;/mark&gt;
-Starfleet, a group of freedom fighters led by Luke Skywalker
-has established a new secret base on the remote ice world of
-Hoth.&lt;/p&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("blockquote")}}</li>
- <li>{{HTMLElement("b")}}</li>
- <li>{{HTMLElement("hr")}}</li>
-</ul>
diff --git a/files/he/web/html/element/nav/index.html b/files/he/web/html/element/nav/index.html
deleted file mode 100644
index 0c0be9d414..0000000000
--- a/files/he/web/html/element/nav/index.html
+++ /dev/null
@@ -1,70 +0,0 @@
----
-title: '<nav>: תגית לסימון תפריט קישורים'
-slug: Web/HTML/Element/nav
-translation_of: Web/HTML/Element/nav
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;nav&gt;</code></strong> משמשת להגדרת התפריט במסמך ה-HTML.<br>
- תחת אלמנט זה ניתן להציג קישורים לדפי אחרים או קישורים פנימיים בתוך הדף.</p>
-
-<div>{{EmbedInteractiveExample("pages/tabbed/nav.html", "tabbed-standard")}}</div>
-
-<p class="hidden">The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples </a> and send us a pull request.</p>
-
-<p> </p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות לארגון תוכן</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>&lt;a&gt;, &lt;abbr&gt;, &lt;address&gt;, &lt;article&gt;, &lt;aside&gt;, &lt;audio&gt;, &lt;b&gt;,&lt;bdo&gt;, &lt;bdi&gt;, &lt;blockquote&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;del&gt;, &lt;details&gt;, &lt;dfn&gt;, &lt;div&gt;, &lt;dl&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;fieldset&gt;, &lt;figure&gt;, &lt;footer&gt;, &lt;form&gt;, &lt;h1&gt;, &lt;h2&gt;, &lt;h3&gt;, &lt;h4&gt;, &lt;h5&gt;, &lt;h6&gt;, &lt;header&gt;, &lt;hgroup&gt;, &lt;hr&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;ins&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;main&gt;, &lt;map&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;menu&gt;, &lt;meter&gt;, &lt;nav&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;ol&gt;, &lt;output&gt;, &lt;p&gt;, &lt;pre&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;s&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;section&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;table&gt;, &lt;template&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;ul&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt;</p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>תגית זו מורשת להופיע בגוף המסמך אך אינה חייבת להיות כפופה בצורה ישירה אל תגית {{HTMLElement("body")}}.<br>
-  </td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <p dir="rtl">בדוגמה שלהלן מוצגת רשימה של קישורים.<br>
- באמצעות CSS ניתן להציגה כסרגל צד, סרגל ניווט או תפריט נפתח.</p>
-
- <pre>&lt;nav class="menu"&gt;
-  &lt;ul&gt;
-    &lt;li&gt;&lt;a href="#"&gt;Home&lt;/a&gt;&lt;/li&gt;
-    &lt;li&gt;&lt;a href="#"&gt;About&lt;/a&gt;&lt;/li&gt;
-    &lt;li&gt;&lt;a href="#"&gt;Contact&lt;/a&gt;&lt;/li&gt;
-  &lt;/ul&gt;
-&lt;/nav&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("header")}}</li>
- <li>{{HTMLElement("aside")}}</li>
- <li>{{HTMLElement("div")}}</li>
- <li>{{HTMLElement("footer")}}</li>
-</ul>
diff --git a/files/he/web/html/element/p/index.html b/files/he/web/html/element/p/index.html
deleted file mode 100644
index 6f694e9c8e..0000000000
--- a/files/he/web/html/element/p/index.html
+++ /dev/null
@@ -1,74 +0,0 @@
----
-title: '<p>: תגית פסקה'
-slug: Web/HTML/Element/p
-tags:
- - Element
- - HTML
- - Tags
- - פסקה
- - תגיות
-translation_of: Web/HTML/Element/p
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;p&gt;</code></strong> מציגה פסקת טקסט במסמך ה-HTML. זוהי תגית בלוק החוסמת את כל השורה.</p>
-
-<div>{{EmbedInteractiveExample("pages/tabbed/p.html", "tabbed-standard")}}</div>
-
-<p class="hidden">The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples </a> and send us a pull request.</p>
-
-<p> </p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות בלוק.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>טקסט, סקריפטים, קנבס, קובצי שמע וסרטונים, מספרים, נוסחאות, כותרות, טבלאות, טפסים.</p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>תגית זו מורשת להופיע בגוף המסמך אך אינה חייבת להיות כפופה בצורה ישירה אל תגית {{HTMLElement("body")}}.</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLParagraphElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <pre>&lt;p&gt;
-  This is the first paragraph of text.
-  This is the first paragraph of text.
-  This is the first paragraph of text.
-  This is the first paragraph of text.
-&lt;/p&gt;
-&lt;p&gt;
-  This is the second paragraph.
-  This is the second paragraph.
-  This is the second paragraph.
-  This is the second paragraph.
-&lt;/p&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("hr")}}</li>
- <li>{{HTMLElement("br")}}</li>
-</ul>
diff --git a/files/he/web/html/element/section/index.html b/files/he/web/html/element/section/index.html
deleted file mode 100644
index 592b45e0dd..0000000000
--- a/files/he/web/html/element/section/index.html
+++ /dev/null
@@ -1,67 +0,0 @@
----
-title: '<section>: תגית לסימון איזור כללי'
-slug: Web/HTML/Element/section
-translation_of: Web/HTML/Element/section
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;section&gt;</code></strong> מייצגת חלק כללי במסמך ה-HTML. <br>
- אזור זה מורכב מכותרת ותוכן ומשמשת להגדרת פרק בספר, אזור חדשות וכו'.</p>
-
-<div>{{EmbedInteractiveExample("pages/tabbed/section.html", "tabbed-standard")}}</div>
-
-<p class="hidden">The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples </a> and send us a pull request.</p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות לארגון תוכן</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>&lt;a&gt;, &lt;abbr&gt;, &lt;address&gt;, &lt;article&gt;, &lt;aside&gt;, &lt;audio&gt;, &lt;b&gt;,&lt;bdo&gt;, &lt;bdi&gt;, &lt;blockquote&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;del&gt;, &lt;details&gt;, &lt;dfn&gt;, &lt;div&gt;, &lt;dl&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;fieldset&gt;, &lt;figure&gt;, &lt;footer&gt;, &lt;form&gt;, &lt;h1&gt;, &lt;h2&gt;, &lt;h3&gt;, &lt;h4&gt;, &lt;h5&gt;, &lt;h6&gt;, &lt;header&gt;, &lt;hgroup&gt;, &lt;hr&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;ins&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;main&gt;, &lt;map&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;menu&gt;, &lt;meter&gt;, &lt;nav&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;ol&gt;, &lt;output&gt;, &lt;p&gt;, &lt;pre&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;s&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;section&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;table&gt;, &lt;template&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;ul&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt;</p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>&lt;a&gt;, &lt;abbr&gt;, &lt;address&gt;, &lt;article&gt;, &lt;aside&gt;, &lt;audio&gt;, &lt;b&gt;,&lt;bdo&gt;, &lt;bdi&gt;, &lt;blockquote&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;del&gt;, &lt;details&gt;, &lt;dfn&gt;, &lt;div&gt;, &lt;dl&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;fieldset&gt;, &lt;figure&gt;, &lt;footer&gt;, &lt;form&gt;, &lt;h1&gt;, &lt;h2&gt;, &lt;h3&gt;, &lt;h4&gt;, &lt;h5&gt;, &lt;h6&gt;, &lt;header&gt;, &lt;hgroup&gt;, &lt;hr&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;ins&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;main&gt;, &lt;map&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;menu&gt;, &lt;meter&gt;, &lt;nav&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;ol&gt;, &lt;output&gt;, &lt;p&gt;, &lt;pre&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;s&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;section&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;table&gt;, &lt;template&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;ul&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt;<br>
-  </td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_-_כותרת_ופסקה">דוגמא - כותרת ופסקה</h2>
-
- <pre>&lt;section&gt;
-  &lt;h1&gt;Heading&lt;/h1&gt;
-  &lt;p&gt;Bunch of awesome content&lt;/p&gt;
-&lt;/section&gt;</pre>
-
- <h2 dir="rtl" id="דוגמא_-_כותרת_ותמונה">דוגמא - כותרת ותמונה</h2>
-
- <pre>&lt;section&gt;
-  &lt;h2&gt;Heading&lt;/h2&gt;
-  &lt;img src="bird.jpg" alt="bird"&gt;
-&lt;/section&gt;</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("header")}}</li>
- <li>{{HTMLElement("aside")}}</li>
- <li>{{HTMLElement("div")}}</li>
-</ul>
diff --git a/files/he/web/html/element/strong/index.html b/files/he/web/html/element/strong/index.html
deleted file mode 100644
index f64389d290..0000000000
--- a/files/he/web/html/element/strong/index.html
+++ /dev/null
@@ -1,69 +0,0 @@
----
-title: '<strong>: תגית להדגשת טקסט'
-slug: Web/HTML/Element/strong
-tags:
- - HTML
- - הדגשה
- - טקסט מודגש
- - מודגש
-translation_of: Web/HTML/Element/strong
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;strong&gt;</code></strong> מציגה פסקת טקסט באופן מודגש.</p>
-
-<p>{{EmbedInteractiveExample("pages/tabbed/strong.html", "tabbed-standard")}}</p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות מסוג Inline.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p><code>&lt;abbr&gt;</code>, <code>&lt;audio&gt;</code>, <code>&lt;b&gt;</code>, <code>&lt;bdo&gt;</code>, <code>&lt;br&gt;</code>, <code>&lt;button&gt;</code>, <code>&lt;canvas&gt;</code>, <code>&lt;cite&gt;</code>, <code>&lt;code&gt;</code>, <code>&lt;command&gt;</code>, <code>&lt;data&gt;</code>, <code>&lt;datalist&gt;</code>, <code>&lt;dfn&gt;</code>, <code>&lt;em&gt;</code>, <code>&lt;embed&gt;</code>, <code>&lt;i&gt;</code>, <code>&lt;iframe&gt;</code>, <code>&lt;img&gt;</code>, <code>&lt;input&gt;</code>, <code>&lt;kbd&gt;</code>, <code>&lt;keygen&gt;</code>, <code>&lt;label&gt;</code>, <code>&lt;mark&gt;</code>, <code>&lt;math&gt;</code>, <code>&lt;meter&gt;</code>, <code>&lt;noscript&gt;</code>, <code>&lt;object&gt;</code>, <code>&lt;output&gt;</code>, <code>&lt;progress&gt;</code>, <code>&lt;q&gt;</code>, <code>&lt;ruby&gt;</code>, <code>&lt;samp&gt;</code>, <code>&lt;script&gt;</code>, <code>&lt;select&gt;</code>, <code>&lt;small&gt;</code>, <code>&lt;span&gt;</code>, <code>&lt;strong&gt;</code>, <code>&lt;sub&gt;</code>, <code>&lt;sup&gt;</code>, <code>&lt;svg&gt;</code>, <code>&lt;textarea&gt;</code>, <code>&lt;time&gt;</code>, <code>&lt;var&gt;</code>, <code>&lt;video&gt;</code>, <code>&lt;wbr&gt;</code></p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>תגית זו מורשת להופיע בגוף המסמך אך אינה חייבת להיות כפופה בצורה ישירה אל תגית {{HTMLElement("body")}}.</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_-_שימוש_בסיסי_בתגית">דוגמא - שימוש בסיסי בתגית</h2>
-
- <pre>&lt;p&gt;Before proceeding, &lt;strong&gt;make sure you put on your safety goggles&lt;/strong&gt;.&lt;/p&gt;
-</pre>
-
- <h2 dir="rtl" id="דוגמא_-_שימוש_בתגית_לצורך_תוית_אזהרה">דוגמא - שימוש בתגית לצורך תוית אזהרה</h2>
-
- <pre>&lt;p&gt;&lt;strong&gt;Important:&lt;/strong&gt; Before proceeding, make sure you add plenty of butter.&lt;/p&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="הערות">הערות</h2>
-
-<p><u>מה ההבדל בין תגית <strong><code>&lt;strong&gt;</code></strong> לתגית <strong><code>&lt;b&gt;</code></strong>?</u><br>
- שתיהן מדגישות את הטקסט בתוך התגית, אך משמעותה של תגית &lt;b&gt; היא השפעה על העיצוב בלבד.  מאידך, כאשר גולשים אל אתר מותאם ולוחצים על הקראה, הדפדפן רואה את תגית &lt;strong&gt; ויודע שיש צורך לקרוא את הטקסט ולהדגיש את הנמצא תחתיה.</p>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("em")}}</li>
- <li>{{HTMLElement("b")}}</li>
- <li>{{cssxref("font-weight")}}</li>
-</ul>
diff --git a/files/he/web/html/element/table/index.html b/files/he/web/html/element/table/index.html
deleted file mode 100644
index 2c4ee267a3..0000000000
--- a/files/he/web/html/element/table/index.html
+++ /dev/null
@@ -1,162 +0,0 @@
----
-title: '<table>: תגית ליצירת טבלה'
-slug: Web/HTML/Element/table
-translation_of: Web/HTML/Element/table
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;table&gt;</code></strong> מציגה נתונים טבלאיים - כלומר, מידע המוצג בטבלה דו-מימדית המורכבת משורות ועמודות של תאים המכילים נתונים שונים.</p>
-
-<p>{{EmbedInteractiveExample("pages/tabbed/table.html", "tabbed-taller")}}</p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>טבלאות</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>{{HTMLElement("caption")}}<br>
- {{HTMLElement("colgroup")}}<br>
- {{HTMLElement("thead")}}<br>
- {{HTMLElement("tbody")}}<br>
- {{HTMLElement("tr")}}<br>
- {{HTMLElement("tfoot")}}</p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>תגית זו מורשת להופיע בגוף המסמך אך אינה חייבת להיות כפופה בצורה ישירה אל תגית {{HTMLElement("body")}}.</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLTableElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_-_טבלה_בסיסית">דוגמא - טבלה בסיסית</h2>
-
- <pre>&lt;table&gt;
-  &lt;tr&gt;
-    &lt;td&gt;John&lt;/td&gt;
-    &lt;td&gt;Doe&lt;/td&gt;
-  &lt;/tr&gt;
-  &lt;tr&gt;
-    &lt;td&gt;Jane&lt;/td&gt;
-    &lt;td&gt;Doe&lt;/td&gt;
-  &lt;/tr&gt;
-&lt;/table&gt;</pre>
-
- <h2 dir="rtl" id="דוגמא_-_טבלה_מורחבת">דוגמא - טבלה מורחבת</h2>
-
- <pre>&lt;p&gt;Simple table with header&lt;/p&gt;
-&lt;table&gt;
-  &lt;tr&gt;
-    &lt;th&gt;First name&lt;/th&gt;
-    &lt;th&gt;Last name&lt;/th&gt;
-  &lt;/tr&gt;
-  &lt;tr&gt;
-    &lt;td&gt;John&lt;/td&gt;
-    &lt;td&gt;Doe&lt;/td&gt;
-  &lt;/tr&gt;
-  &lt;tr&gt;
-    &lt;td&gt;Jane&lt;/td&gt;
-    &lt;td&gt;Doe&lt;/td&gt;
-  &lt;/tr&gt;
-&lt;/table&gt;
-
-&lt;p&gt;Table with thead, tfoot, and tbody&lt;/p&gt;
-&lt;table&gt;
-  &lt;thead&gt;
-    &lt;tr&gt;
-      &lt;th&gt;Header content 1&lt;/th&gt;
-      &lt;th&gt;Header content 2&lt;/th&gt;
-    &lt;/tr&gt;
-  &lt;/thead&gt;
-  &lt;tbody&gt;
-    &lt;tr&gt;
-      &lt;td&gt;Body content 1&lt;/td&gt;
-      &lt;td&gt;Body content 2&lt;/td&gt;
-    &lt;/tr&gt;
-  &lt;/tbody&gt;
-  &lt;tfoot&gt;
-    &lt;tr&gt;
-      &lt;td&gt;Footer content 1&lt;/td&gt;
-      &lt;td&gt;Footer content 2&lt;/td&gt;
-    &lt;/tr&gt;
-  &lt;/tfoot&gt;
-&lt;/table&gt;
-
-&lt;p&gt;Table with colgroup&lt;/p&gt;
-&lt;table&gt;
-  &lt;colgroup span="4"&gt;&lt;/colgroup&gt;
-  &lt;tr&gt;
-    &lt;th&gt;Countries&lt;/th&gt;
-    &lt;th&gt;Capitals&lt;/th&gt;
-    &lt;th&gt;Population&lt;/th&gt;
-    &lt;th&gt;Language&lt;/th&gt;
-  &lt;/tr&gt;
-  &lt;tr&gt;
-    &lt;td&gt;USA&lt;/td&gt;
-    &lt;td&gt;Washington, D.C.&lt;/td&gt;
-    &lt;td&gt;309 million&lt;/td&gt;
-    &lt;td&gt;English&lt;/td&gt;
-  &lt;/tr&gt;
-  &lt;tr&gt;
-    &lt;td&gt;Sweden&lt;/td&gt;
-    &lt;td&gt;Stockholm&lt;/td&gt;
-    &lt;td&gt;9 million&lt;/td&gt;
-    &lt;td&gt;Swedish&lt;/td&gt;
-  &lt;/tr&gt;
-&lt;/table&gt;
-
-&lt;p&gt;Table with colgroup and col&lt;/p&gt;
-&lt;table&gt;
-  &lt;colgroup&gt;
-    &lt;col style="background-color: #0f0"&gt;
-    &lt;col span="2"&gt;
-  &lt;/colgroup&gt;
-  &lt;tr&gt;
-    &lt;th&gt;Lime&lt;/th&gt;
-    &lt;th&gt;Lemon&lt;/th&gt;
-    &lt;th&gt;Orange&lt;/th&gt;
-  &lt;/tr&gt;
-  &lt;tr&gt;
-    &lt;td&gt;Green&lt;/td&gt;
-    &lt;td&gt;Yellow&lt;/td&gt;
-    &lt;td&gt;Orange&lt;/td&gt;
-  &lt;/tr&gt;
-&lt;/table&gt;
-
-&lt;p&gt;Simple table with caption&lt;/p&gt;
-&lt;table&gt;
-  &lt;caption&gt;Awesome caption&lt;/caption&gt;
-  &lt;tr&gt;
-    &lt;td&gt;Awesome data&lt;/td&gt;
-  &lt;/tr&gt;
-&lt;/table&gt;
-</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="הערות">הערות</h2>
-
-<p><u>מה ההבדל בין תגית <strong><code>&lt;strong&gt;</code></strong> לתגית <strong><code>&lt;b&gt;</code></strong>?</u><br>
- שתיהן מדגישות את הטקסט בתוך התגית, אך משמעותה של תגית &lt;b&gt; היא השפעה על העיצוב בלבד.  מאידך, כאשר גולשים אל אתר מותאם ולוחצים על הקראה, הדפדפן רואה את תגית &lt;strong&gt; ויודע שיש צורך לקרוא את הטקסט ולהדגיש את הנמצא תחתיה.</p>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("thead")}}</li>
- <li>{{HTMLElement("tbody")}}</li>
- <li>{{cssxref("tfoot")}}</li>
-</ul>
diff --git a/files/he/web/html/element/time/index.html b/files/he/web/html/element/time/index.html
deleted file mode 100644
index 8e00e97810..0000000000
--- a/files/he/web/html/element/time/index.html
+++ /dev/null
@@ -1,93 +0,0 @@
----
-title: '<time>: תגית להגדרת תאריך לתוכן שנכתב'
-slug: Web/HTML/Element/time
-translation_of: Web/HTML/Element/time
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;time&gt;</code></strong> משמשת להגדרת תאריך / שעה לתוכן שנכתב.</p>
-
-<p>{{EmbedInteractiveExample("pages/tabbed/time.html", "tabbed-standard")}}</p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>תגיות מסוג Inline.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>
- <p>&lt;abbr&gt;, &lt;audio&gt;, &lt;b&gt;, &lt;bdo&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;dfn&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;meter&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;output&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt; </p>
- </td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>&lt;abbr&gt;, &lt;audio&gt;, &lt;b&gt;, &lt;bdo&gt;, &lt;br&gt;, &lt;button&gt;, &lt;canvas&gt;, &lt;cite&gt;, &lt;code&gt;, &lt;command&gt;, &lt;data&gt;, &lt;datalist&gt;, &lt;dfn&gt;, &lt;em&gt;, &lt;embed&gt;, &lt;i&gt;, &lt;iframe&gt;, &lt;img&gt;, &lt;input&gt;, &lt;kbd&gt;, &lt;keygen&gt;, &lt;label&gt;, &lt;mark&gt;, &lt;math&gt;, &lt;meter&gt;, &lt;noscript&gt;, &lt;object&gt;, &lt;output&gt;, &lt;progress&gt;, &lt;q&gt;, &lt;ruby&gt;, &lt;samp&gt;, &lt;script&gt;, &lt;select&gt;, &lt;small&gt;, &lt;span&gt;, &lt;strong&gt;, &lt;sub&gt;, &lt;sup&gt;, &lt;svg&gt;, &lt;textarea&gt;, &lt;time&gt;, &lt;var&gt;, &lt;video&gt;, &lt;wbr&gt; </td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<p dir="rtl">{{htmlattrdef("datetime")}} - תכונה זו מציגה את התאריך והשעה וחייבת להיות לפי הפורמטים הבאים:<br>
- * שעון 24 שעות.<br>
- * תאריך מדוייק על פי הלוח השנה הגרגוריאני.<br>
- * פרק זמן חוקי.</p>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <td><strong>כתיבת תאריך מלא:</strong><br>
- 2011-11-18</td>
- <td><strong>כתיבת חודש:</strong><br>
- 2011-11</td>
- <td><strong>כתיבת שנה:</strong><br>
- 2011</td>
- </tr>
- <tr>
- <td><strong>כתיבת שעה:</strong><br>
- 14:54<br>
- 14:54:39<br>
- 14:54:39.929</td>
- <td><strong>כתיבת שבועות ושנה:</strong><br>
- 2011-W47</td>
- <td><strong>כתיבת חודש ויום בלבד:</strong><br>
- 11-18</td>
- </tr>
- <tr>
- <td><strong>תאריך ושעה גלובלים:</strong><br>
- 2011-11-18 14:54:39.929-0400</td>
- <td><strong>תאריך ושעה מקומיים:</strong><br>
- 2011-11-18 14:54:39.929<br>
-  </td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא_-_שימוש_בתגית_עם_פרק_זמן_פשוט">דוגמא - שימוש בתגית עם פרק זמן פשוט</h2>
-
- <pre>&lt;p&gt;The concert starts at &lt;time&gt;20:00&lt;/time&gt;.&lt;/p&gt;
-</pre>
-
- <h2 dir="rtl" id="דוגמא_-_שימוש_בתגית_עם_datatime">דוגמא - שימוש בתגית עם datatime</h2>
-
- <pre>&lt;p&gt;The concert took place on &lt;time
-  datetime="2001-05-15T19:00"&gt;May 15&lt;/time&gt;.&lt;/p&gt;</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("data")}}</li>
-</ul>
diff --git a/files/he/web/html/element/title/index.html b/files/he/web/html/element/title/index.html
deleted file mode 100644
index 0a7eac882f..0000000000
--- a/files/he/web/html/element/title/index.html
+++ /dev/null
@@ -1,61 +0,0 @@
----
-title: '<title>: תגית כותרת'
-slug: Web/HTML/Element/title
-tags:
- - HTML
- - כותרת
- - ראש המסמך
- - תגיות
-translation_of: Web/HTML/Element/title
----
-<div>{{HTMLRef}}</div>
-
-<p dir="rtl">תגית <strong><code>&lt;title&gt;</code></strong> מגדירה את כותרת מסמך ה-HTML. הכותרת מופיעה בשורת הכותרת של הדפדפן או בשם הכרטיסיה. תג זה מכיל טקסט ומספרים בלבד.</p>
-
-<table>
- <tbody>
- <tr>
- <th>קטגוריה</th>
- <td>מטא-דאטה ונתונים אודות המסמך.</td>
- </tr>
- <tr>
- <th>תוכן מורשה</th>
- <td>טקסט ומספרים בלבד.</td>
- </tr>
- <tr>
- <th>תגיות הורים מורשות</th>
- <td>כפיפות לתגית {{HTMLElement("head")}}.</td>
- </tr>
- <tr>
- <th scope="row">ממשק DOM</th>
- <td>{{domxref("HTMLTitleElement")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תארים">תארים</h2>
-
-<p dir="rtl">תגית זו נכללת ברשימת <a href="https://developer.mozilla.org/he/docs/Web/HTML/%D7%AA%D7%90%D7%A8%D7%99%D7%9D_%D7%92%D7%9C%D7%95%D7%91%D7%9C%D7%99%D7%99%D7%9D">התארים הגלובליים</a>.</p>
-
-<dl>
- <dt dir="rtl">
- <h2 dir="rtl" id="דוגמא">דוגמא</h2>
-
- <pre>&lt;html&gt;
-  &lt;head&gt;
-    &lt;title&gt;Document title&lt;/title&gt;
-  &lt;/head&gt;
-&lt;/html&gt;</pre>
- </dt>
-</dl>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{HTMLElement("meta")}}</li>
- <li>{{HTMLElement("style")}}</li>
- <li>{{HTMLElement("script")}}</li>
-</ul>
-
-
-<p> </p>
diff --git a/files/he/web/html/index.html b/files/he/web/html/index.html
deleted file mode 100644
index 4b91892492..0000000000
--- a/files/he/web/html/index.html
+++ /dev/null
@@ -1,108 +0,0 @@
----
-title: HTML
-slug: Web/HTML
-tags:
- - HTML
- - Landing
-translation_of: Web/HTML
----
-<div dir="rtl">{{HTMLSidebar}}</div>
-
-<p class="summary" dir="rtl"><span class="seoSummary"><strong>HTML</strong> (שפת תגיות לתמליל-על / HyperText Markup Language)</span> הינה אבן הבניין הבסיסית ביותר של האינטרנט. היא מגדירה את המשמעות והמבנה של תוכן האתר. מלבד HTML קיימות טכנולוגיות אחרות המשמשות לתאר את התצוגה / המראה (<a href="/he/docs/Web/CSS">CSS</a>) או את הפונקציונליות / ההתנהגות (<a href="/he/docs/Web/JavaScript">JavaScript</a>) של האתר.</p>
-
-<div class="callout-box" dir="rtl" style="float: left;">
-<p><a href="/he/docs/HTML/HTML5" title="html5"><img alt="HTML5_Logo_128.png" class="default internal" src="/@api/deki/files/6020/=HTML5_Logo_128.png"></a></p>
-</div>
-
-<p dir="rtl"><strong>HyperText Markup Language‏ (HTML)</strong> הינה שפה המשמשת ליצירת דפי אינטרנט ומסמכים אחרים הניתנים לצפייה בדפדפן אינטרנט.<br>
- HTML הוא תקן בינלאומי המוגדר על ידי ה־<a class="external" href="http://www.w3.org/" title="http://www.w3.org/">World Wide Web Consortium</a>. הגרסה הנוכחית של התקן היא <a class="external" href="http://www.whatwg.org/specs/web-apps/current-work/" title="http://www.whatwg.org/specs/web-apps/current-work/">גרסה 5</a> שהושקה בחודש אוקטובר 2014.</p>
-
-<p dir="rtl">ניתן להעשיר את דפי ה-HTML באמצעות <strong>גיליונות סגנון מדורגים</strong> <strong>(CSS)</strong> איתם ניתן לעצב את דפי האינטרנט והמסמכים שנבנו.<br>
- בנוסף, ניתן להטמיע תסריטים בדף באמצעות שפת <strong>ג'אווה</strong> <strong>סקריפט (JavasScript)</strong> הנחשבת לשפת תכנות דינמית מונחית־עצמים.</p>
-
-<section class="cleared" id="sect1">
-<ul class="card-grid" dir="rtl">
- <li><span>מבוא ל- HTML</span>
-
- <p>אם פיתוח אתרים חדש לך, חשוב לקרוא את <a href="/he/docs/Learn/Getting_started_with_the_web/HTML_basics">HTML למתחילים</a> כדי ללמוד מהי HTML וכיצד להשתמש בה.</p>
- </li>
- <li><span>הדרכות HTML</span>
- <p>מאמרים לגבי אופן השימוש ב- HTML, בנוסף להדרכות ודוגמאות מלאות, אפשר למצוא ב<a href="/he/docs/Learn/HTML">אזור הלמידה של HTML</a>.</p>
- </li>
- <li><span>מקורות HTML</span>
- <p>באזור ה<a href="/he/docs/Web/HTML/Reference">מקורות HTML</a> הנרחב ניתן למצוא פרטים לגבי כל אלמנט ותכונה ב- HTML.</p>
- </li>
-</ul>
-
-<div class="row topicpage-table" dir="rtl">
-<div class="section">
-<h2 class="Tools" id="הדרכות_למתחילים">הדרכות למתחילים</h2>
-
-<p>ב<a href="/he/docs/Learn/HTML">אזור הלמידה של HTML</a> קיימים מודולים רבים שמלמדים HTML מהבסיס — ללא צורך בידע קודם.</p>
-
-<dl>
- <dt><a href="/he/docs/Learn/HTML/Introduction_to_HTML">מבוא ל- HTML</a></dt>
- <dd>מודול זה מכין את הקרקע, ומרגיל אותך למושגים ותחביר חשובים, כמו מבט על החלת HTML על טקסט, כיצד ליצור היפר-קישורים, וכיצד להשתמש ב- HTML כדי לבנות עמוד אינטרנט.</dd>
- <dt><a href="/he/docs/Learn/HTML/Multimedia_and_embedding">מולטימדיה והטמעה</a></dt>
- <dd>מודול זה חוקר כיצד להשתמש ב- HTML כך שיכלול מולטימדיה בעמודי האינטרנט, כולל הדרכים השונות להצגת תמונות, וכיצד להטמיע וידאו, שמע ואפילו אתרים אחרים.</dd>
- <dt><a href="/he/docs/Learn/HTML/Tables">טבלאות HTML</a></dt>
- <dd>הצגת מידע טבלאי באינטרנט בצורה מובנת, קריאה ונגישה יכולה להיות אתגר רציני. מודול זה עובר על הבסיס של סימון טבלאות, בנוסף למאפיינים נוספים כמו כיתובים וסיכומים.</dd>
- <dt><a href="/he/docs/Learn/HTML/Forms">טפסים ב- HTML</a></dt>
- <dd>טפסים הינם חלק חשוב מאוד ברשת — הם מספקים את מרבית הפונקציונליות הדרושה לעבודה אינטראקטיבית, למשל רישום וכניסה, שליחת משוב, קניית מוצרים ועוד. מודול זה עובר על הבסיס ליצירת חלקי צד-לקוח / משתמש-קצה של טפסים.</dd>
- <dt><a href="/he/docs/Learn/HTML/Howto">שימוש ב- HTML לפתרון בעיות נפוצות</a></dt>
- <dd>מספק קישורים לאזורים בתוכן, המסבירים כיצד להשתמש ב- HTML כדי לפתור בעיות נפוצות בעת יצירת עמוד אינטרנט: עבודה עם כותרות, הוספת תמונות או וידאו, הדגשת תוכן, יצירת טופס בסיסי, וכו'.</dd>
-</dl>
-
-<h2 id="נושאים_מתקדמים">נושאים מתקדמים</h2>
-
-<dl>
- <dt class="landingPageList"><a href="/he/docs/Web/HTML/CORS_enabled_image">תמונה תומכת CORS</a></dt>
- <dd class="landingPageList">תכונת {{htmlattrxref("crossorigin", "img")}}, בשילוב עם {{glossary("CORS")}} header מתאים, מאפשר לאחזר תמונות המוגדרות עם אלמנט {{HTMLElement("img")}} ממקורות זרים ולשמש באלמנט {{HTMLElement("canvas")}} כאילו הן שייכות למקור הנוכחי.</dd>
- <dt class="landingPageList"><a href="/he/docs/Web/HTML/CORS_settings_attributes">תכונות להגדרת CORS</a></dt>
- <dd class="landingPageList">לאלמנטים מסוימים של HTML המספקים תמיכה ל- <a href="/he/docs/HTTP/Access_control_CORS">CORS</a>, כמו {{HTMLElement("img")}} או {{HTMLElement("video")}}, יש תכונת <code>crossorigin</code> (שדה <code>crossOrigin</code>), המאפשר להגדיר בקשות CORS למידע המאוחזר על-ידי האלמנט.</dd>
- <dt class="landingPageList"><a href="/he/docs/Web/HTML/Focus_management_in_HTML">ניהול פוקוס ב- HTML</a></dt>
- <dd class="landingPageList">תכונת <code><a href="/he/docs/Web/API/Document/activeElement">activeElement</a></code> ומתודת <code><a dir="ltr" href="/he/docs/Web/API/Document/hasFocus">hasFocus()</a></code> של ה- DOM עוזרות לעקוב ולנהל את האינטראקציות של המשתמשים עם האלמנטים בעמוד.</dd>
- <dt class="landingPageList"><a href="/he/docs/Web/HTML/Using_the_application_cache">שימוש במטמון (cache) של האפליקציה</a></dt>
- <dd class="landingPageList">הטמנה (caching) של האפליקציה מאפשר לאפליקציות מבוססות רשת לרוץ באופן לא מקוון. ניתן להשתמש בממשק ה- <strong>Application Cache</strong> (או <em>AppCache</em>) כדי לציין משאבים שהדפדפן צריך להטמין כדי שיהיו זמינים למשתמש באופן לא מקוון. אפליקציות מוטמנות נטענות ועובדות בצורה נכונה, אפילו אם משתמשים לוחצים על רענון כשהם במצב לא מקוון.</dd>
- <dt class="landingPageList"><a href="https://developer.mozilla.org/he/docs/Web/HTML/Preloading_content">טעינה מראש של תוכן באמצעות rel="preload"</a></dt>
- <dd class="landingPageList">ערך ה- <code>preload</code> של תכונת {{htmlattrxref("rel", "link")}} באלמנט {{htmlelement("link")}} מאפשרת לכתוב בקשות אחזור הצהרתיות באלמנט {{htmlelement("head")}}, ובכך לציין משאבים שהעמוד יזדקק להם זמן קצר לאחר הטעינה, ואותם נרצה להתחיל לטעון מראש בשלב מוקדם של טעינת העמוד - זאת לפני שתהליך הרנדור העיקרי יתחיל לעבוד. דבר זה יבטיח שהם יהיו זמינים מוקדם יותר, ולא סביר שיתקעו את הרנדור הראשוני, ובכך ישפר את הביצועים. מאמר זה מספק מדריך בסיסי לאופן הפעולה של <code>preload</code>.</dd>
-</dl>
-</div>
-
-<div class="section">
-<h2 class="Documentation" id="הפניות_חיצוניות">הפניות חיצוניות</h2>
-
-<dl>
- <dt class="landingPageList"><a href="/he/docs/Web/HTML/Reference">הפניות לגבי HTML</a></dt>
- <dd class="landingPageList">HTML מורכב מ<strong>אלמנטים</strong>, אותם ניתן לשנות באמצעות מספר <strong>תכונות (attributes)</strong>. מסמכי HTML מחוברים אחד לשני על-ידי <a href="/he/docs/Web/HTML/Link_types">קישורים / לינקים</a>.</dd>
- <dt class="landingPageList"><a href="/he/docs/Web/HTML/Element">הפניות לגבי אלמנטים של HTML</a></dt>
- <dd class="landingPageList">ניתן לעיין ברשימת ה{{glossary("Element", "אלמנטים")}} המלאה של {{glossary("HTML")}}.</dd>
- <dt class="landingPageList"><a href="/he/docs/Web/HTML/Attributes">הפניות לגבי תכונות HTML</a></dt>
- <dd class="landingPageList">לאלמנטים ב- HTML יש <strong>תכונות (attributes)</strong>. אלו הן ערכים נוספים שמגדירים את האלמנטים או מכווננים את ההתנהגות שלהם במגוון דרכים.</dd>
- <dt class="landingPageList"><a href="/he/docs/Web/HTML/Global_attributes">תכונות גלובליות</a></dt>
- <dd class="landingPageList">ניתן לציין תכונות גלובליות בכל ה<a href="/he/docs/Web/HTML/Element">אלמנטים של HTML</a>, <em>אפילו כאלה שלא כלולים בסטנדרט</em>. משמעות הדבר שכל אלמנט לא סטנדרטי עדיין חייב לתמוך בתכונות אלו, אפילו שאלמנטים אלה הופכים את המסמך לחסר תאימות ל- HTML5.</dd>
- <dt class="landingPageList"><a href="/he/docs/Web/HTML/Inline_elements">אלמנטי שורה(Inline)</a> ו<a href="/he/docs/Web/HTML/Block-level_elements">אלמנטי בלוק (Block-Level)</a></dt>
- <dd class="landingPageList">אלמנטים של HTML הם בדרך-כלל שורה (inline) או בלוק (block-level). אלמנט שורה תופס רק המקום התחום בין התגיות המגדירות אותו. אלמנט בלוק תופס את כל המקום של ההורה שלו (container), ובכך יוצר "בלוק".</dd>
- <dt class="landingPageList"><a href="/he/docs/Web/HTML/Link_types">סוגי קישורים</a></dt>
- <dd class="landingPageList">ניתן להשתמש במגוון סוגי קישורים כדי לבסס ולהגדיר יחסים בין שני מסמכים. אלמנטים של ק סוגי הקישורים אותם ניתן לקבוע כוללים את {{HTMLElement("a")}}, {{HTMLElement("area")}} ו- {{HTMLElement("link")}}.</dd>
- <dt class="landingPageList"><a href="/he/docs/Web/HTML/Supported_media_formats">תצורות מדיה הנתמכות על-ידי אלמנטי שמע ווידאו ב- HTML</a></dt>
- <dd class="landingPageList">אלמנטי {{HTMLElement("audio")}} ו- {{HTMLElement("video")}} מאפשרים לך להפעיל מדיית שמע ווידאו. אלמנטים אלה מספקים חלופה ברמת דפדפן ליכולות דומות המצויות ב- Adobe Flash ותוספים אחרים.</dd>
- <dt class="landingPageList"><a href="/he/docs/Web/HTML/Kinds_of_HTML_content">סוגי תוכן של HTML</a></dt>
- <dd class="landingPageList">HTML מורכב ממספר סוגים של תוכן, וניתן להשתמש בכל אחד בהקשרים מסוימים וחסומים לשימוש באחרים. באופן דומה לכל אחד יש אוסף קטגוריות תוכן אחרות שהם יכולים להכיל ואלמנטים בהם ניתן להשתמש או לא. זהו מדריך לקטגוריות אלו.</dd>
- <dt class="landingPageList"><a href="/he/docs/Web/HTML/Quirks_Mode_and_Standards_Mode">מצב Quirks ומצב Standards</a></dt>
- <dd class="landingPageList">מידע הסטורי על מצב quirks ומצב standards.</dd>
-</dl>
-
-<h2 class="landingPageList" id="נושאים_קשורים">נושאים קשורים</h2>
-
-<dl>
- <dt><a href="/he/docs/Web/HTML/Applying_color">הוספת צבע לאלמנטים של HTML ב- CSS</a></dt>
- <dd>מאמר זה סוקר את רוב הדרכים להוספת צבע לתוכן HTML על-ידי CSS. כמו כן הוא מפרט אילו חלקים ניתן לצבוע במסמך HTML, ובאילו מאפייני CSS להשתמש לשם כך. הוא כולל דוגמאות, קישורים לכלי בניית פלטה ועוד.</dd>
-</dl>
-</div>
-</div>
-</section>
-
-<p dir="rtl"><span class="alllinks"><a href="/he/docs/tag/HTML">כל הקישורים...</a></span></p>
-
-<p dir="rtl"></p>
diff --git a/files/he/web/http/index.html b/files/he/web/http/index.html
deleted file mode 100644
index f1bd5752c5..0000000000
--- a/files/he/web/http/index.html
+++ /dev/null
@@ -1,91 +0,0 @@
----
-title: HTTP
-slug: Web/HTTP
-tags:
- - CORS
- - HTTP
- - Hypertext
- - NeedsTranslation
- - Reference
- - TCP/IP
- - TopicStub
- - Web
- - Web Development
- - 'l10n:priority'
-translation_of: Web/HTTP
----
-<div>{{HTTPSidebar}}</div>
-
-<p class="summary"><strong><dfn>Hypertext Transfer Protocol (HTTP)</dfn></strong> is an <a href="https://en.wikipedia.org/wiki/Application_Layer">application-layer</a> protocol for transmitting hypermedia documents, such as HTML. It was designed for communication between web browsers and web servers, but it can also be used for other purposes. HTTP follows a classical <a href="https://en.wikipedia.org/wiki/Client%E2%80%93server_model">client-server model</a>, with a client opening a connection to make a request, then waiting until it receives a response. HTTP is a <a href="https://en.wikipedia.org/wiki/Stateless_protocol">stateless protocol</a>, meaning that the server does not keep any data (state) between two requests. Though often based on a TCP/IP layer, it can be used on any reliable <a href="https://en.wikipedia.org/wiki/Transport_Layer">transport layer</a>, that is, a protocol that doesn't lose messages silently like UDP does. <a href="https://en.wikipedia.org/wiki/Reliable_User_Datagram_Protocol">RUDP</a> — the reliable update of UDP — is a suitable alternative.</p>
-
-<div class="column-container">
-<div class="column-half">
-<h2 id="Tutorials">Tutorials</h2>
-
-<p>Learn how to use HTTP with guides and tutorials.</p>
-
-<dl>
- <dt><a href="/en-US/docs/Web/HTTP/Overview">Overview of HTTP</a></dt>
- <dd>The basic features of the client-server protocol: what it can do and its intended uses.</dd>
- <dt><a href="/en-US/docs/Web/HTTP/Caching">HTTP Cache</a></dt>
- <dd>Caching is very important for fast Web sites. This article describes different methods of caching and how to use HTTP Headers to control them.</dd>
- <dt><a href="/en-US/docs/Web/HTTP/Cookies">HTTP Cookies</a></dt>
- <dd>How cookies work is defined by <a href="https://tools.ietf.org/html/rfc6265">RFC 6265</a>. When serving an HTTP request, a server can send a <code>Set-Cookie</code> HTTP header with the response. The client then returns the cookie's value with every request to the same server in the form of a <code>Cookie</code> request header. The cookie can also be set to expire on a certain date, or restricted to a specific domain and path.</dd>
- <dt><a href="/en-US/docs/Web/HTTP/CORS">Cross-Origin Resource Sharing (CORS)</a></dt>
- <dd><strong>Cross-site HTTP requests</strong> are HTTP requests for resources from a <strong>different domain</strong> than the domain of the resource making the request. For instance, an HTML page from Domain A (<code>http://domaina.example/</code>) makes a request for an image on Domain B (<code>http://domainb.foo/image.jpg</code>) via the <code>img</code> element. Web pages today very commonly load cross-site resources, including CSS stylesheets, images, scripts, and other resources. CORS allows web developers to control how their site reacts to cross-site requests.</dd>
-</dl>
-
-<dl>
- <dt><a href="/en-US/docs/Web/HTTP/Basics_of_HTTP/Evolution_of_HTTP">Evolution of HTTP</a></dt>
- <dd>A brief description of the changes between the early versions of HTTP, to the modern HTTP/2, the emergent HTTP/3 and beyond.</dd>
- <dt><a href="https://wiki.mozilla.org/Security/Guidelines/Web_Security">Mozilla web security guidelines</a></dt>
- <dd>A collection of tips to help operational teams with creating secure web applications.</dd>
-</dl>
-
-<dl>
- <dt><a href="/en-US/docs/Web/HTTP/Messages">HTTP Messages</a></dt>
- <dd>Describes the type and structure of the different kind of messages of HTTP/1.x and HTTP/2.</dd>
- <dt><a href="/en-US/docs/Web/HTTP/Session">A typical HTTP session</a></dt>
- <dd>Shows and explains the flow of a usual HTTP session.</dd>
- <dt><a href="/en-US/docs/Web/HTTP/Connection_management_in_HTTP_1.x">Connection management in HTTP/1.x</a></dt>
- <dd>Describes the three connection management models available in HTTP/1.x, their strengths, and their weaknesses.</dd>
-</dl>
-</div>
-
-<div class="column-half">
-<h2 id="Reference">Reference</h2>
-
-<p>Browse through detailed HTTP reference documentation.</p>
-
-<dl>
- <dt><a href="/en-US/docs/Web/HTTP/Headers">HTTP Headers</a></dt>
- <dd>HTTP message headers are used to describe a resource, or the behavior of the server or the client. Custom proprietary headers can be added using the <code>X-</code> prefix; others in an <a href="https://www.iana.org/assignments/message-headers/message-headers.xhtml#perm-headers">IANA registry</a>, whose original content was defined in <a href="https://tools.ietf.org/html/rfc4229">RFC 4229</a>. IANA also maintains a <a href="https://www.iana.org/assignments/message-headers/message-headers.xhtml#prov-headers">registry of proposed new HTTP message headers</a>.</dd>
- <dt><a href="/en-US/docs/Web/HTTP/Methods">HTTP Request Methods</a></dt>
- <dd>The different operations that can be done with HTTP: {{HTTPMethod("GET")}}, {{HTTPMethod("POST")}}, and also less common requests like {{HTTPMethod("OPTIONS")}}, {{HTTPMethod("DELETE")}}, or {{HTTPMethod("TRACE")}}.</dd>
- <dt><a href="/en-US/docs/Web/HTTP/Response_codes">HTTP Status Response Codes</a></dt>
- <dd>HTTP response codes indicate whether a specific HTTP request has been successfully completed. Responses are grouped in five classes: informational responses, successful responses, redirections, client errors, and servers errors.</dd>
-</dl>
-
-<dl>
- <dt><a href="/en-US/docs/Web/HTTP/Headers/Content-Security-Policy">CSP directives</a></dt>
- <dd>The {{HTTPHeader("Content-Security-Policy")}} response header fields allows web site administrators to control resources the user agent is allowed to load for a given page. With a few exceptions, policies mostly involve specifying server origins and script endpoints.</dd>
-</dl>
-
-<h2 id="Tools_resources">Tools &amp; resources</h2>
-
-<p>Helpful tools and resources for understanding and debugging HTTP.</p>
-
-<dl>
- <dt><a href="/en-US/docs/Tools">Firefox Developer Tools</a></dt>
- <dd><a href="/en-US/docs/Tools/Network_Monitor">Network monitor</a></dd>
- <dt><a href="https://observatory.mozilla.org/">Mozilla Observatory</a></dt>
- <dd>
- <p>A project designed to help developers, system administrators, and security professionals configure their sites safely and securely.</p>
- </dd>
- <dt><a class="external" href="https://redbot.org/">RedBot</a></dt>
- <dd>Tools to check your cache-related headers</dd>
- <dt><a href="https://www.html5rocks.com/en/tutorials/internals/howbrowserswork/">How Browsers Work</a></dt>
- <dd>A very comprehensive article on browser internals and request flow through HTTP protocol. A MUST-READ for any web developer.</dd>
-</dl>
-</div>
-</div>
diff --git a/files/he/web/http/status/403/index.html b/files/he/web/http/status/403/index.html
deleted file mode 100644
index a927dfe905..0000000000
--- a/files/he/web/http/status/403/index.html
+++ /dev/null
@@ -1,55 +0,0 @@
----
-title: 403 Forbidden
-slug: Web/HTTP/Status/403
-tags:
- - סטטוס HTTP
- - סטטוס תגובה
- - קוד סטטוס
- - תקלות צד לקוח
-translation_of: Web/HTTP/Status/403
----
-<div>{{HTTPSidebar}}</div>
-
-<p>קוד סטטוס שגיאה בתגובת HTTP  <strong><code>403 Forbidden</code></strong> מציין שהשרת הבין את הבקשה אך מסרב לאשר אותה. (403 - נדחה. או "נאסר")</p>
-
-<p>סטטוס תגובה זה דומה לסטטוס {{HTTPStatus("401")}}, אך במקרה זה, אימות מחדש לא ישפיע. הגישה אסורה לצמיתות וקשורה ללוגיקת היישום, כגון אין מספיק זכויות למשאב.</p>
-
-<h2 id="סטטוס">סטטוס</h2>
-
-<pre class="syntaxbox notranslate">403 Forbidden</pre>
-
-<h2 id="תגובה_לדוגמא">תגובה לדוגמא</h2>
-
-<pre class="notranslate">HTTP/1.1 403 Forbidden
-Date: Wed, 21 Oct 2015 07:28:00 GMT
-</pre>
-
-<h2 id="פרטים_טכניים">פרטים טכניים</h2>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Title</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>{{RFC("7231", "403 Forbidden" , "6.5.3")}}</td>
- <td>HTTP/1.1: Semantics and Content</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תאימות_דפדפנים">תאימות דפדפנים</h2>
-
-<p class="hidden">The compatibility table in this page is generated from structured data. If you'd like to contribute to the data, please check out <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> and send us a pull request.</p>
-
-<p>{{Compat("http.status.403")}}</p>
-
-<h2 id="ראה_עוד">ראה עוד</h2>
-
-<ul>
- <li>{{HTTPStatus("401")}}</li>
- <li><a href="https://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html" rel="noopener">HTTP/1.1: Status Code Definitions</a> - רשימת כל הסטטוסים של תגובות HTTP התקניים</li>
-</ul>
diff --git a/files/he/web/http/status/index.html b/files/he/web/http/status/index.html
deleted file mode 100644
index f11dea5fcb..0000000000
--- a/files/he/web/http/status/index.html
+++ /dev/null
@@ -1,197 +0,0 @@
----
-title: HTTP response status codes
-slug: Web/HTTP/Status
-translation_of: Web/HTTP/Status
----
-<div>{{HTTPSidebar}}</div>
-
-<p class="summary"><span class="seoSummary">HTTP response status codes indicate whether a specific <a href="/en-US/docs/Web/HTTP">HTTP</a> request has been successfully completed. Responses are grouped in five classes: </span></p>
-
-<ol>
- <li class="summary"><span class="tlid-translation translation" lang="iw"><span title="">תגובות מידע</span></span><span class="seoSummary"> (<code>100</code>–<code>199</code>),</span></li>
- <li class="summary"><span class="seoSummary">תגובות הצלחה(<code>200</code>–<code>299</code>),</span></li>
- <li class="summary"><span class="tlid-translation translation" lang="iw"><span title="">הפניות</span></span><span class="seoSummary"> (<code>300</code>–<code>399</code>),</span></li>
- <li class="summary"><span class="tlid-translation translation" lang="iw"><span title="">שגיאות לקוח</span></span><span class="seoSummary"> (<code>400</code>–<code>499</code>),</span></li>
- <li class="summary"><span class="tlid-translation translation" lang="iw"><span title="">שגיאות שרת </span></span><span class="seoSummary">(<code>500</code>–<code>599</code>).</span></li>
-</ol>
-
-<p class="summary"><span class="tlid-translation translation" lang="iw"><span title="">קודי הסטטוס שלהלן מוגדרים על ידי</span></span> <a href="https://tools.ietf.org/html/rfc2616#section-10">section 10 of RFC 2616</a>. <span class="tlid-translation translation" lang="iw"><span title="">אתה יכול למצוא מפרט מעודכן ב-</span></span> <a href="https://tools.ietf.org/html/rfc7231#section-6.5.1">RFC 7231</a>. </p>
-
-<div class="blockIndicator note">
-<p class="summary"><span class="tlid-translation translation" lang="iw"><span title="">אם אתה מקבל תגובה שאינה מופיעה ברשימה זו, אז התגובה לא סטנדרטית, ויתכן שהיא מותאמת אישית לתוכנת השרת.</span></span></p>
-</div>
-
-<h2 id="תגובות_מידע"><span class="tlid-translation translation" lang="iw"><span title="">תגובות מידע</span></span></h2>
-
-<dl>
- <dt>{{HTTPStatus(100, "100 Continue")}}</dt>
- <dd>קוד זה נשלח לאחר שהשרת קיבל את החלק הראשוני של הבקשה מהלקוח, והוא נועד ליידע את הלקוח שהשרת מוכן לקבל את המשך ההודעה. קוד 100 משמש בעיקר במצב של חיבור קבוע שדרכו עוברות מספר בקשות.</dd>
- <dt>{{HTTPStatus(101, "101 Switching Protocol")}}</dt>
- <dd><span class="tlid-translation translation" lang="iw"><span title="">קוד זה נשלח בתגובה לכותרת בקשת {{HTTPHeader ("שדרוג")}} מהלקוח, ומציין את הפרוטוקול שאליו עובר השרת.</span></span></dd>
- <dt>{{HTTPStatus(102, "102 Processing")}} ({{Glossary("WebDAV")}})</dt>
- <dd><span class="tlid-translation translation" lang="iw"><span title="">קוד זה מציין כי השרת קיבל את הבקשה ומעבד אותה, אך טרם התקבלה תגובה.</span></span></dd>
- <dt>{{HTTPStatus(103, "103 Early Hints")}}</dt>
- <dd><span class="tlid-translation translation" lang="iw"><span title="">קוד מצב זה מיועד בעיקר לשימוש בכותרת {{HTTPHeader ("קישור")}}, ומאפשר לסוכן המשתמש להתחיל לטעון מראש משאבים בזמן שהשרת מכין תגובה.</span></span></dd>
-</dl>
-
-<h2 id="Successful_responses">Successful responses</h2>
-
-<dl>
- <dt>{{HTTPStatus(200, "200 OK")}}</dt>
- <dd><span class="tlid-translation translation" lang="iw"><span title="">הבקשה הצליחה.</span> <span title="">משמעות ההצלחה תלויה בשיטת HTTP:</span></span></dd>
-</dl>
-
-<ul>
- <li><code>GET</code>: <span class="tlid-translation translation" lang="iw"><span title="">המשאב הובא ומועבר בגוף ההודעות.</span></span></li>
- <li><code>HEAD</code>: <span class="tlid-translation translation" lang="iw"><span title="">כותרות הישות נמצאות בגוף ההודעות.</span></span></li>
- <li><code>PUT</code> or <code>POST</code>: <span class="tlid-translation translation" lang="iw"><span title="">המשאב המתאר את תוצאת הפעולה מועבר בגוף ההודעות.</span></span></li>
- <li><code>TRACE</code>: <span class="tlid-translation translation" lang="iw"><span title="">גוף ההודעה מכיל את הודעת הבקשה כפי שהתקבלה על ידי השרת</span></span></li>
-</ul>
-
-<dl>
- <dt>{{HTTPStatus(201, "201 Created")}}</dt>
- <dd><span class="tlid-translation translation" lang="iw"><span title="">הבקשה הצליחה ונוצר משאב חדש כתוצאה מכך.</span> <span title="">זו בדרך כלל התגובה שנשלחה לאחר בקשות POST, או כמה בקשות PUT.</span></span></dd>
- <dt>{{HTTPStatus(202, "202 Accepted")}}</dt>
- <dd><span class="tlid-translation translation" lang="iw"><span title="">הבקשה התקבלה אך טרם נענתה.</span> <span title="">זה לא מחויב, מכיוון שאין דרך ב- HTTP לשלוח מאוחר יותר תגובה אסינכרונית המציינת את תוצאות הבקשה.</span> <span title="">זה מיועד למקרים בהם תהליך או שרת אחר מטפל בבקשה, או לעיבוד אצווה.</span></span></dd>
- <dt>{{HTTPStatus(203, "203 Non-Authoritative Information")}}</dt>
- <dd><span class="tlid-translation translation" lang="iw"><span title="">פירושו של קוד תגובה זה הוא שמטא-המידע המוחזר אינו זהה בדיוק לזמין בשרת המקור, אלא נאסף מעותק מקומי או מעותק של צד שלישי.</span> <span title="">זה משמש בעיקר למראות או לגיבויים של משאב אחר.</span> <span title="">פרט למקרה הספציפי, עדיפה התגובה "200 אישור" על פני סטטוס זה.</span></span></dd>
- <dt>{{HTTPStatus(204, "204 No Content")}}</dt>
- <dd><span class="tlid-translation translation" lang="iw"><span title="">אין תוכן לשלוח לבקשה זו, אך הכותרות עשויות להיות מועילות.</span> <span title="">המשתמש-סוכן עשוי לעדכן את הכותרות המטמון שלו עבור משאב זה באמצעות החדשות.</span></span></dd>
- <dt>{{HTTPStatus(205, "205 Reset Content")}}</dt>
- <dd><span class="tlid-translation translation" lang="iw"><span title="">מאפשר לסוכן המשתמש לאפס את המסמך ששלח בקשה זו.</span></span></dd>
- <dt>{{HTTPStatus(206, "206 Partial Content")}}</dt>
- <dd>This response code is used when the {{HTTPHeader("Range")}} header is sent from the client to request only part of a resource.</dd>
- <dt>{{HTTPStatus(207, "207 Multi-Status")}} ({{Glossary("WebDAV")}})</dt>
- <dd>Conveys information about multiple resources, for situations where multiple status codes might be appropriate.</dd>
- <dt>{{HTTPStatus(208, "208 Already Reported")}} ({{Glossary("WebDAV")}})</dt>
- <dd>Used inside a <code>&lt;dav:propstat&gt;</code> response element to avoid repeatedly enumerating the internal members of multiple bindings to the same collection.</dd>
- <dt>{{HTTPStatus(226, "226 IM Used")}} (<a href="https://tools.ietf.org/html/rfc3229">HTTP Delta encoding</a>)</dt>
- <dd>The server has fulfilled a <code>GET</code> request for the resource, and the response is a representation of the result of one or more instance-manipulations applied to the current instance.</dd>
-</dl>
-
-<h2 id="Redirection_messages">Redirection messages</h2>
-
-<dl>
- <dt>{{HTTPStatus(300, "300 Multiple Choice")}}</dt>
- <dd>The request has more than one possible response. The user-agent or user should choose one of them. (There is no standardized way of choosing one of the responses, but HTML links to the possibilities are recommended so the user can pick.)</dd>
- <dt>{{HTTPStatus(301, "301 Moved Permanently")}}</dt>
- <dd>The URL of the requested resource has been changed permanently. The new URL is given in the response.</dd>
- <dt>{{HTTPStatus(302, "302 Found")}}</dt>
- <dd>This response code means that the URI of requested resource has been changed <em>temporarily</em>. Further changes in the URI might be made in the future. Therefore, this same URI should be used by the client in future requests.</dd>
- <dt>{{HTTPStatus(303, "303 See Other")}}</dt>
- <dd>The server sent this response to direct the client to get the requested resource at another URI with a GET request.</dd>
- <dt>{{HTTPStatus(304, "304 Not Modified")}}</dt>
- <dd>This is used for caching purposes. It tells the client that the response has not been modified, so the client can continue to use the same cached version of the response.</dd>
- <dt><code>305 Use Proxy</code> {{deprecated_inline}}</dt>
- <dd>Defined in a previous version of the HTTP specification to indicate that a requested response must be accessed by a proxy. It has been deprecated due to security concerns regarding in-band configuration of a proxy.</dd>
- <dt><code>306 unused</code></dt>
- <dd>This response code is no longer used; it is just reserved. It was used in a previous version of the HTTP/1.1 specification.</dd>
- <dt>{{HTTPStatus(307, "307 Temporary Redirect")}}</dt>
- <dd>The server sends this response to direct the client to get the requested resource at another URI with same method that was used in the prior request. This has the same semantics as the <code>302 Found</code> HTTP response code, with the exception that the user agent <em>must not</em> change the HTTP method used: If a <code>POST</code> was used in the first request, a <code>POST</code> must be used in the second request.</dd>
- <dt>{{HTTPStatus(308, "308 Permanent Redirect")}}</dt>
- <dd>This means that the resource is now permanently located at another URI, specified by the <code>Location:</code> HTTP Response header. This has the same semantics as the <code>301 Moved Permanently</code> HTTP response code, with the exception that the user agent <em>must not</em> change the HTTP method used: If a <code>POST</code> was used in the first request, a <code>POST</code> must be used in the second request.</dd>
-</dl>
-
-<h2 id="Client_error_responses">Client error responses</h2>
-
-<dl>
- <dt>{{HTTPStatus(400, "400 Bad Request")}}</dt>
- <dd>The server could not understand the request due to invalid syntax.</dd>
- <dt>{{HTTPStatus(401, "401 Unauthorized")}}</dt>
- <dd>Although the HTTP standard specifies "unauthorized", semantically this response means "unauthenticated". That is, the client must authenticate itself to get the requested response.</dd>
- <dt>{{HTTPStatus(402, "402 Payment Required")}} {{experimental_inline}}</dt>
- <dd>This response code is reserved for future use. The initial aim for creating this code was using it for digital payment systems, however this status code is used very rarely and no standard convention exists.</dd>
- <dt>{{HTTPStatus(403, "403 Forbidden")}}</dt>
- <dd>The client does not have access rights to the content; that is, it is unauthorized, so the server is refusing to give the requested resource. Unlike 401, the client's identity is known to the server.</dd>
- <dt>{{HTTPStatus(404, "404 Not Found")}}</dt>
- <dd>The server can not find requested resource. In the browser, this means the URL is not recognized. In an API, this can also mean that the endpoint is valid but the resource itself does not exist. Servers may also send this response instead of 403 to hide the existence of a resource from an unauthorized client. This response code is probably the most famous one due to its frequent occurrence on the web.</dd>
- <dt>{{HTTPStatus(405, "405 Method Not Allowed")}}</dt>
- <dd>The request method is known by the server but has been disabled and cannot be used. For example, an API may forbid DELETE-ing a resource. The two mandatory methods, <code>GET</code> and <code>HEAD</code>, must never be disabled and should not return this error code.</dd>
- <dt>{{HTTPStatus(406, "406 Not Acceptable")}}</dt>
- <dd>This response is sent when the web server, after performing <a href="/en-US/docs/HTTP/Content_negotiation#Server-driven_negotiation">server-driven content negotiation</a>, doesn't find any content that conforms to the criteria given by the user agent.</dd>
- <dt>{{HTTPStatus(407, "407 Proxy Authentication Required")}}</dt>
- <dd>This is similar to 401 but authentication is needed to be done by a proxy.</dd>
- <dt>{{HTTPStatus(408, "408 Request Timeout")}}</dt>
- <dd>This response is sent on an idle connection by some servers, even without any previous request by the client. It means that the server would like to shut down this unused connection. This response is used much more since some browsers, like Chrome, Firefox 27+, or IE9, use HTTP pre-connection mechanisms to speed up surfing. Also note that some servers merely shut down the connection without sending this message.</dd>
- <dt>{{HTTPStatus(409, "409 Conflict")}}</dt>
- <dd>This response is sent when a request conflicts with the current state of the server.</dd>
- <dt>{{HTTPStatus(410, "410 Gone")}}</dt>
- <dd>This response is sent when the requested content has been permanently deleted from server, with no forwarding address. Clients are expected to remove their caches and links to the resource. The HTTP specification intends this status code to be used for "limited-time, promotional services". APIs should not feel compelled to indicate resources that have been deleted with this status code.</dd>
- <dt>{{HTTPStatus(411, "411 Length Required")}}</dt>
- <dd>Server rejected the request because the <code>Content-Length</code> header field is not defined and the server requires it.</dd>
- <dt>{{HTTPStatus(412, "412 Precondition Failed")}}</dt>
- <dd>The client has indicated preconditions in its headers which the server does not meet.</dd>
- <dt>{{HTTPStatus(413, "413 Payload Too Large")}}</dt>
- <dd>Request entity is larger than limits defined by server; the server might close the connection or return an <code>Retry-After</code> header field.</dd>
- <dt>{{HTTPStatus(414, "414 URI Too Long")}}</dt>
- <dd>The URI requested by the client is longer than the server is willing to interpret.</dd>
- <dt>{{HTTPStatus(415, "415 Unsupported Media Type")}}</dt>
- <dd>The media format of the requested data is not supported by the server, so the server is rejecting the request.</dd>
- <dt>{{HTTPStatus(416, "416 Range Not Satisfiable")}}</dt>
- <dd>The range specified by the <code>Range</code> header field in the request can't be fulfilled; it's possible that the range is outside the size of the target URI's data.</dd>
- <dt>{{HTTPStatus(417, "417 Expectation Failed")}}</dt>
- <dd>This response code means the expectation indicated by the <code>Expect</code> request header field can't be met by the server.</dd>
- <dt>{{HTTPStatus(418, "418 I'm a teapot")}}</dt>
- <dd>The server refuses the attempt to brew coffee with a teapot.</dd>
- <dt>{{HTTPStatus(421, "421 Misdirected Request")}}</dt>
- <dd>The request was directed at a server that is not able to produce a response. This can be sent by a server that is not configured to produce responses for the combination of scheme and authority that are included in the request URI.</dd>
- <dt>{{HTTPStatus(422, "422 Unprocessable Entity")}} ({{Glossary("WebDAV")}})</dt>
- <dd>The request was well-formed but was unable to be followed due to semantic errors.</dd>
- <dt>{{HTTPStatus(423, "423 Locked")}} ({{Glossary("WebDAV")}})</dt>
- <dd>The resource that is being accessed is locked.</dd>
- <dt>{{HTTPStatus(424, "424 Failed Dependency")}} ({{Glossary("WebDAV")}})</dt>
- <dd>The request failed due to failure of a previous request.</dd>
- <dt>{{HTTPStatus(425, "425 Too Early")}}</dt>
- <dd>Indicates that the server is unwilling to risk processing a request that might be replayed.</dd>
- <dt>{{HTTPStatus(426, "426 Upgrade Required")}}</dt>
- <dd>The server refuses to perform the request using the current protocol but might be willing to do so after the client upgrades to a different protocol. The server sends an {{HTTPHeader("Upgrade")}} header in a 426 response to indicate the required protocol(s).</dd>
- <dt>{{HTTPStatus(428, "428 Precondition Required")}}</dt>
- <dd>The origin server requires the request to be conditional. This response is intended to prevent the 'lost update' problem, where a client GETs a resource's state, modifies it, and PUTs it back to the server, when meanwhile a third party has modified the state on the server, leading to a conflict.</dd>
- <dt>{{HTTPStatus(429, "429 Too Many Requests")}}</dt>
- <dd>The user has sent too many requests in a given amount of time ("rate limiting").</dd>
- <dt>{{HTTPStatus(431, "431 Request Header Fields Too Large")}}</dt>
- <dd>The server is unwilling to process the request because its header fields are too large. The request may be resubmitted after reducing the size of the request header fields.</dd>
- <dt>{{HTTPStatus(451, "451 Unavailable For Legal Reasons")}}</dt>
- <dd>The user-agent requested a resource that cannot legally be provided, such as a web page censored by a government.</dd>
-</dl>
-
-<h2 id="Server_error_responses">Server error responses</h2>
-
-<dl>
- <dt>{{HTTPStatus(500, "500 Internal Server Error")}}</dt>
- <dd>The server has encountered a situation it doesn't know how to handle.</dd>
- <dt>{{HTTPStatus(501, "501 Not Implemented")}}</dt>
- <dd>The request method is not supported by the server and cannot be handled. The only methods that servers are required to support (and therefore that must not return this code) are <code>GET</code> and <code>HEAD</code>.</dd>
- <dt>{{HTTPStatus(502, "502 Bad Gateway")}}</dt>
- <dd>This error response means that the server, while working as a gateway to get a response needed to handle the request, got an invalid response.</dd>
- <dt>{{HTTPStatus(503, "503 Service Unavailable")}}</dt>
- <dd>The server is not ready to handle the request. Common causes are a server that is down for maintenance or that is overloaded. Note that together with this response, a user-friendly page explaining the problem should be sent. This responses should be used for temporary conditions and the <code>Retry-After:</code> HTTP header should, if possible, contain the estimated time before the recovery of the service. The webmaster must also take care about the caching-related headers that are sent along with this response, as these temporary condition responses should usually not be cached.</dd>
- <dt>{{HTTPStatus(504, "504 Gateway Timeout")}}</dt>
- <dd>This error response is given when the server is acting as a gateway and cannot get a response in time.</dd>
- <dt>{{HTTPStatus(505, "505 HTTP Version Not Supported")}}</dt>
- <dd>The HTTP version used in the request is not supported by the server.</dd>
- <dt>{{HTTPStatus(506, "506 Variant Also Negotiates")}}</dt>
- <dd>The server has an internal configuration error: the chosen variant resource is configured to engage in transparent content negotiation itself, and is therefore not a proper end point in the negotiation process.</dd>
- <dt>{{HTTPStatus(507, "507 Insufficient Storage")}} ({{Glossary("WebDAV")}})</dt>
- <dd>The method could not be performed on the resource because the server is unable to store the representation needed to successfully complete the request.</dd>
- <dt>{{HTTPStatus(508, "508 Loop Detected")}} ({{Glossary("WebDAV")}})</dt>
- <dd>The server detected an infinite loop while processing the request.</dd>
- <dt>{{HTTPStatus(510, "510 Not Extended")}}</dt>
- <dd>Further extensions to the request are required for the server to fulfil it.</dd>
- <dt>{{HTTPStatus(511, "511 Network Authentication Required")}}</dt>
- <dd>The 511 status code indicates that the client needs to authenticate to gain network access.</dd>
-</dl>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-
-
-<p>{{Compat("http.status")}}</p>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li><a href="https://en.wikipedia.org/wiki/List_of_HTTP_status_codes">List of HTTP status codes on Wikipedia</a></li>
- <li><a href="https://kinsta.com/blog/http-status-codes/">A Complete Guide and List of HTTP Status Codes</a></li>
- <li><a href="http://www.iana.org/assignments/http-status-codes/http-status-codes.xhtml">IANA official registry of HTTP status codes</a></li>
-</ul>
diff --git a/files/he/web/index.html b/files/he/web/index.html
deleted file mode 100644
index d09e56dbf4..0000000000
--- a/files/he/web/index.html
+++ /dev/null
@@ -1,121 +0,0 @@
----
-title: טכנולוגיות אינטרנט
-slug: Web
-tags:
- - אינטרנט
- - היסטוריה
- - עמוד נחיתה
- - פיתוח אינטרנט
-translation_of: Web
----
-<p dir="rtl">האופי הפתוח של הרשת העולמית חושף אפשרויות מדהימות לאנשים שרוצים ליצור אתרים או אפליקציות מקוונות. כדי לנצל את יכולות הרשת באופן מרבי, עליך לדעת כיצד להשתמש בהם. חקור את הקישורים למטה כדי ללמוד עוד אודות טכנולוגיות רשת שונות.</p>
-
-<div class="row topicpage-table">
-<div class="section">
-<h2 class="Documentation" dir="rtl" id="טכנולוגיות_לפיתוח_אינטרנטי">טכנולוגיות לפיתוח אינטרנטי</h2>
-
-<h3 dir="rtl" id="מידע_בסיסי">מידע בסיסי</h3>
-
-<dl dir="rtl">
- <dt><a href="/he/docs/Web/HTML">HTML</a></dt>
- <dd><strong>שפת סימני עריכה לתמליל-על (HyperText Markup Language)</strong> הינה שפה המשמשת לתאר וליצור <em>תוכן</em> של דפי אינטרנט ומסמכים אחרים הניתנים לצפייה בדפדפן אינטרנט.</dd>
- <dt><a href="/he/docs/Web/CSS">CSS</a></dt>
- <dd><strong><strong>גיליונות סגנון מדורגים (Cascading Style Sheets)</strong></strong> משמשים לתאר את <em>מראה</em> או <em>תצוגת</em> התוכן בדף האינטרנט.</dd>
- <dt><strong><a href="/he/docs/Web/HTTP">HTTP</a></strong></dt>
- <dd><strong><strong>פרוטוקול תעבורת </strong>תמליל-על<strong> (HyperText Transfer Protocol)</strong></strong> משמש להעביר HTML ומסמכי היפר-מדיה ברשת.</dd>
-</dl>
-
-<h3 dir="rtl" id="סקריפטים"><strong>סקריפטים</strong></h3>
-
-<dl dir="rtl">
- <dt><strong><a href="/he/docs/Web/JavaScript">JavaScript</a></strong></dt>
- <dd><strong>JavaScript</strong> הינה שפת תכנות שרצה בדפדפן שלך. ניתן להשתמש בה להוספת אינטראקטיביות ודינמיות לאתר או אפליקציה שלך.</dd>
- <dd>לאור כניסתו של <a href="/he/docs/Glossary/Node.js">Node.js</a>, ניתן להריץ על השרת.</dd>
- <dt><strong><a href="/he/docs/Web/Reference/API">Web APIs</a></strong></dt>
- <dd><strong>ממשקי תכנות אפליקציות רשת (Web Application Programming Interfaces)</strong> משמשים לבצע משימות, כמו שינוי ה- DOM, הפעלת שמע או וידאו,או יצירת גרפיקה בתלת-מימד.
- <ul dir="rtl">
- <li><a href="/he/docs/Web/API">אינדקס ממשקי ה- API ברשת</a> מפרט את טיפוסי האובייקטים בהם ניתן להשתמש בפיתוח בסביבת הרשת.</li>
- <li><a href="/he/docs/WebAPI">עמוד ה- WebAPI</a> מפרט ממשקי תקשורת, חומרה ואחרים בהם ניתן להשתמש באפליקציות רשת.</li>
- <li><a href="/he/docs/Web/Events">אינדקס ה- Events</a> מפרט את האירועים בהם ניתן להשתמש כדי לעקוב ולהגיב לדברים מעניינים שקרו בעמוד או באפליקציה.</li>
- </ul>
- </dd>
- <dt><a href="/he/docs/Web/Web_components">Web Components (רכיבי Web)</a></dt>
- <dd>רכיבי Web הינם אוסף טכנולוגיות המאפשר ליצור אלמנטים בהתאמה אישית הניתנים לשימוש חוזר — כאשר הפונקציונליות שלהם מבודדת משאר הקוד — ולהשמיש אותם באפליקציות הרשת שלך.</dd>
-</dl>
-
-<h3 dir="rtl" id="גרפיקה"><strong>גרפיקה</strong></h3>
-
-<dl dir="rtl">
- <dt><a href="/he/docs/Web/HTML/Canvas">קנבס (Canvas)</a></dt>
- <dd>אלמנט {{HTMLElement("canvas")}} מספק API ליצירת גרפיקות תלת-מימד באמצעות שימוש ב- TextScript.</dd>
- <dt><a href="/he/docs/Web/SVG">SVG</a></dt>
- <dd><strong>Scalable Vector Graphics (גרפיקה וקטורית ברת-מידות SVG)</strong> מאפשרת להשתמש בקווים, עקובומות וצורות גאומטריות אחרות ליצירת גרפיקה. באמצעות וקטורים, ניתן ליצור תמונות שמותאמות באופן נקי לכל גודל.</dd>
- <dt><a href="/he/docs/Web/API/WebGL_API">WebGL</a></dt>
- <dd><strong>WebGL</strong> הינו JavaScript API המאפשר לצייר גרפיקות דו-מימד או תלת-מימד, באמצעות אלמנט {{HTMLElement("canvas")}}. טכנולוגיה זו מאפשר להשתמש ב- OpenGL ES בתשתית רשת.</dd>
-</dl>
-
-<h3 dir="rtl" id="שמע_ומולטימדיה"><strong>שמע ומולטימדיה</strong></h3>
-
-<dl dir="rtl">
- <dt><a href="/he/docs/Web/Media">טכנולוגיות מדיה ברשת</a></dt>
- <dd>רשימה של API הקשורים למדיה, עם קישורים לתיעוד הדרוש לכל אחד.</dd>
- <dt><a class="new" href="/he/docs/Web/Media/Overview" rel="nofollow">סקירה של טכנולוגית מדיה ברשת</a></dt>
- <dd>מבט כללי על טכנולוגיות רשת פתוחות ו- API המספקים תמיכה לשמע ווידאו. אם אינך בטוח באיזה API להשתמש, זה המקום להתחיל ממנו.</dd>
- <dt><a href="/he/docs/Web/API/Media_Streams_API">API ללכידת מדיה וזרמים (streams)</a></dt>
- <dd>אינדקס ל- API שמאפשר להזרים (סטרימינג), להקליט ולתמרן מדיה באופן מקומי וברשת. כולל שימוש במצלמות ומיקרופונים מקומיים ללכידת וידאו, שמע וסטילס.</dd>
- <dt><a href="/he/docs/Learn/HTML/Multimedia_and_embedding/Video_and_audio_content">שימוש בשמע ווידאו עם HTML</a></dt>
- <dd>הטמעת וידאו ו/או שמע בעמוד רשת ושליטה בפלייבק שלו.</dd>
- <dt><a href="/he/docs/Web/API/WebRTC_API">WebRTC</a></dt>
- <dd>RTC הוא קיצור ל- Real-Time Communications (תקשורת בזמן-אמת), טכנולוגיה שמאפשרת להזרים שמע / וידאו ולשתף מידע בין משתמשי דפדפנים (עמיתים - peers).</dd>
-</dl>
-
-<h3 dir="rtl" id="אחר"><strong>אחר</strong></h3>
-
-<dl dir="rtl">
- <dt><a href="/he/docs/Web/MathML">MathML</a></dt>
- <dd><strong>Mathematical Markup Language (שפת סימני עריכה מתמטית - MathML)</strong> מאפשרת להציג משוואות ותחביר מתמטיות.</dd>
- <dt><a href="/he/docs/Web/XSLT">XSLT</a></dt>
- <dd><strong>Extensible Stylesheet Language Transformations (טרנספורמציית שפת עיצוב ברת-הרחבה - XSLT)</strong> מאפשרת להמיר מסמכי XML לתוכן HTML קריא יותר.</dd>
- <dt><a href="/he/docs/Web/EXSLT">EXSLT</a></dt>
- <dd>פונקציות נוספות המספקות אפשרויות נוספות ל- XSLT.</dd>
- <dt><a href="/he/docs/Web/XPath">XPath</a></dt>
- <dd><strong>XPath</strong> מאפשר לבחור צמתים במסמך, על-ידי שימוש בתחביר חזק יותר מזה של <a href="/he/docs/Web/CSS/CSS_Selectors">CSS selectors</a>.</dd>
-</dl>
-</div>
-
-<div class="section">
-<h2 class="Documentation" dir="rtl" id="אזור_הלמידה"><strong>אזור הלמידה</strong></h2>
-
-<dl dir="rtl">
- <dt><a href="/he/docs/Learn">לימוד פיתוח ברשת</a></dt>
- <dd>אוסף מאמרים המספק למתחילים כל מה שצריך כדי להתחיל לתכנת אתרים פשוטים.</dd>
- <dt><a href="/he/docs/Web/Apps/Progressive">אפליקציות רשת מתקדמות (Progressive web apps)</a></dt>
- <dd>אפליקציות רשת מתקדמות (PWA - Progressive Web Apps) משתמשות ב- Web API מודרניים ביחד עם אסטרטגיית שיפור מתקדמת ליצירת אפליקציות רשת מרובות-פלטפורמות. אפליקציות אלו עובדות בכל מקום, ומספקות מספר אפשרויות עם אותם יתרונות של חווית משתמש כמו אפליקציות native. אוסף מסמכים ומדריכים זה יראו את כל מה שיש לדעת לגבי PWA.</dd>
-</dl>
-
-<h2 dir="rtl" id="נושאים_נוספים"><strong>נושאים נוספים</strong></h2>
-
-<dl dir="rtl">
- <dt><strong><a href="/he/docs/Web/Apps">פיתוח אפליקציות רשת</a></strong></dt>
- <dd>אוסף מאמרים זה מסביר את הטכניקות המשמשות בפיתוח אפליקציות רשת לסביבת מכשירים ניידים (מובייל) ונייחים (מחשבים).</dd>
- <dt><strong><a href="/he/docs/Web/Accessibility">נגישות</a></strong></dt>
- <dd>אתרים נגישים מאפשרים לאנשים רבים ככל האפשר להשתמש ברשת, לרבות בעל מוגבלויות ראייה, שמיעה ואחרות. אוסף מאמרים זה מספק מידע לגבי פיתוח רשת נגיש.</dd>
-</dl>
-
-<dl dir="rtl">
- <dt><a href="/he/docs/Web/Performance">ביצועים ברשת</a></dt>
- <dd>ביצועים ברשת הינה אמנות הווידוא שאפליקציות רשת ייטענו מהר ויגיבו לפעולות משתמש, בלי קשר לרוחב הפס, גודל המסך, רשת, או יכולות המכשיר.</dd>
-</dl>
-
-<dl dir="rtl">
- <dt><a href="/he/docs/Web/Localization">לוקליזציה (L10n) וגלובליזציה / אינטרנשיונליזציה (I18n)</a></dt>
- <dd>הרשת היא קהילה גלובלית. חשוב לוודא שהאתר שלך יהיה חלק ממנה, באמצעות הקפדה על מתן תוכן האתר בשפה ופריסה המצופים על-ידי משתמשי היעד שלך.</dd>
- <dt><a href="/he/docs/Web/Security">אבטחה</a></dt>
- <dd>אל תיתן לאתר או לאפליקציה שלך להדליף מידע פרטי לחבר'ה הרעים. תוכל להשתמש באוסף מאמרים זה כדי לוודא שהפרוייקטים שלך מאובטחים.</dd>
- <dt><a href="/he/docs/WebAssembly">WebAssembly</a></dt>
- <dd>WebAssembly הינה שפה חדשה שניתן להריץ בדפדפנים חדישים — זוהי שפת-סף דמוית-אסמפלי עם פורמט בינארי קומפקטי בעל ביצועים כמעט ברמת native, ומספק לשפות כמו <span dir="ltr">C / C++</span> קומפילצית-יעד, כך שהן יכולות לרוץ ברשת.</dd>
-</dl>
-</div>
-</div>
-
-<p dir="rtl"><strong><span class="alllinks"><a href="/he/docs/tag/Web">כל הנושאים...</a></span></strong></p>
diff --git a/files/he/web/javascript/guide/index.html b/files/he/web/javascript/guide/index.html
deleted file mode 100644
index eb87ff0421..0000000000
--- a/files/he/web/javascript/guide/index.html
+++ /dev/null
@@ -1,125 +0,0 @@
----
-title: JavaScript Guide
-slug: Web/JavaScript/Guide
-tags:
- - Guide
- - JavaScript
- - NeedsTranslation
- - TopicStub
- - 'l10n:priority'
-translation_of: Web/JavaScript/Guide
----
-<div>{{jsSidebar("JavaScript Guide")}}</div>
-
-<p class="summary">The JavaScript Guide shows you how to use <a href="/en-US/docs/Web/JavaScript">JavaScript</a> and gives an overview of the language. If you want to get started with JavaScript or programming in general, consult the articles in the <a href="/en-US/Learn">learning area</a>. If you need exhaustive information about a language feature, have a look at the <a href="/en-US/docs/Web/JavaScript/Reference">JavaScript reference</a>.</p>
-
-<h2 id="Chapters">Chapters</h2>
-
-<p>This Guide is divided into several chapters:</p>
-
-<ul class="card-grid">
- <li><span><a href="/en-US/docs/Web/JavaScript/Guide/Introduction">Introduction</a></span>
-
- <p><a href="/en-US/docs/Web/JavaScript/Guide/Introduction#Where_to_find_JavaScript_information">About this guide</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Introduction#What_is_JavaScript">About JavaScript</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Introduction#JavaScript_and_Java">JavaScript and Java</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Introduction#JavaScript_and_the_ECMAScript_Specification">ECMAScript</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Introduction#Getting_started_with_JavaScript">Tools</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Introduction#Hello_world">Hello World</a></p>
- </li>
- <li><span><a href="/en-US/docs/Web/JavaScript/Guide/Grammar_and_types">Grammar and types</a></span>
- <p><a href="/en-US/docs/Web/JavaScript/Guide/Grammar_and_types#Basics">Basic syntax &amp; comments</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Grammar_and_types#Declarations">Declarations</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Grammar_and_types#Variable_scope">Variable scope</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Grammar_and_types#Variable_hoisting">Variable hoisting</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Grammar_and_types#Data_structures_and_types">Data structures and types</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Grammar_and_types#Literals">Literals</a></p>
- </li>
- <li><span><a href="/en-US/docs/Web/JavaScript/Guide/Control_flow_and_error_handling">Control flow and error handling</a></span>
- <p><code><a href="/en-US/docs/Web/JavaScript/Guide/Control_flow_and_error_handling#if...else_statement">if...else</a></code><br>
- <code><a href="/en-US/docs/Web/JavaScript/Guide/Control_flow_and_error_handling#switch_statement">switch</a></code><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Control_flow_and_error_handling#Exception_handling_statements"><code>try</code>/<code>catch</code>/<code>throw</code></a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Control_flow_and_error_handling#Utilizing_Error_objects">Error objects</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Control_flow_and_error_handling#Promises">Promises</a></p>
- </li>
- <li><span><a href="/en-US/docs/Web/JavaScript/Guide/Loops_and_iteration">Loops and iteration</a></span>
- <p><code><a href="/en-US/docs/Web/JavaScript/Guide/Loops_and_iteration#for_statement">for</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Loops_and_iteration#while_statement">while</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Loops_and_iteration#do...while_statement">do...while</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Loops_and_iteration#break_statement">break</a>/<a href="/en-US/docs/Web/JavaScript/Guide/Loops_and_iteration#continue_statement">continue</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Loops_and_iteration#for...in_statement">for..in</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Loops_and_iteration#for...of_statement">for..of</a></code></p>
- </li>
-</ul>
-
-<ul class="card-grid">
- <li><span><a href="/en-US/docs/Web/JavaScript/Guide/Functions">Functions</a></span>
-
- <p><a href="/en-US/docs/Web/JavaScript/Guide/Functions#Defining_functions">Defining functions</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Functions#Calling_functions">Calling functions</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Functions#Function_scope">Function scope</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Functions#Closures">Closures</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Functions#Using_the_arguments_object">Arguments</a> &amp; <a href="/en-US/docs/Web/JavaScript/Guide/Functions#Function_parameters">parameters</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Functions#Arrow_functions">Arrow functions</a></p>
- </li>
- <li><span><a href="/en-US/docs/Web/JavaScript/Guide/Expressions_and_Operators">Expressions and operators</a></span>
- <p><a href="/en-US/docs/Web/JavaScript/Guide/Expressions_and_Operators#Assignment_operators">Assignment</a> &amp; <a href="/en-US/docs/Web/JavaScript/Guide/Expressions_and_Operators#Comparison_operators">Comparisons</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Expressions_and_Operators#Arithmetic_operators">Arithmetic operators</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Expressions_and_Operators#Bitwise_operators">Bitwise</a> &amp; <a href="/en-US/docs/Web/JavaScript/Guide/Expressions_and_Operators#Logical_operators">logical operators</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Expressions_and_Operators#Conditional_(ternary)_operator">Conditional (ternary) operator</a></p>
- </li>
- <li><span><a href="/en-US/docs/Web/JavaScript/Guide/Numbers_and_dates">Numbers and dates</a></span><a href="/en-US/docs/Web/JavaScript/Guide/Numbers_and_dates#Numbers"> Number literals</a>
- <p><a href="/en-US/docs/Web/JavaScript/Guide/Numbers_and_dates#Number_object"><code>Number</code> object</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Numbers_and_dates#Math_object"><code>Math</code> object</a><br>
- <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Numbers_and_dates#Date_object"><code>Date</code> object</a></p>
- </li>
- <li><span><a href="/en-US/docs/Web/JavaScript/Guide/Text_formatting">Text formatting</a></span>
- <p><a href="/en-US/docs/Web/JavaScript/Guide/Text_formatting#String_literals">String literals</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Text_formatting#String_objects"><code>String</code> object</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Text_formatting#Multi-line_template_strings">Template strings</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Text_formatting#Internationalization">Internationalization</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Regular_Expressions">Regular Expressions</a></p>
- </li>
-</ul>
-
-<ul class="card-grid">
- <li><span><a href="/en-US/docs/Web/JavaScript/Guide/Indexed_collections">Indexed collections</a></span>
-
- <p><a href="/en-US/docs/Web/JavaScript/Guide/Indexed_collections#Array_object">Arrays</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Indexed_collections#Typed_Arrays">Typed arrays</a></p>
- </li>
- <li><span><a href="/en-US/docs/Web/JavaScript/Guide/Keyed_collections">Keyed collections</a></span>
- <p><code><a href="/en-US/docs/Web/JavaScript/Guide/Keyed_collections#Map_object">Map</a></code><br>
- <code><a href="/en-US/docs/Web/JavaScript/Guide/Keyed_collections#WeakMap_object">WeakMap</a></code><br>
- <code><a href="/en-US/docs/Web/JavaScript/Guide/Keyed_collections#Set_object">Set</a></code><br>
- <code><a href="/en-US/docs/Web/JavaScript/Guide/Keyed_collections#WeakSet_object">WeakSet</a></code></p>
- </li>
- <li><span><a href="/en-US/docs/Web/JavaScript/Guide/Working_with_Objects">Working with objects</a></span>
- <p><a href="/en-US/docs/Web/JavaScript/Guide/Working_with_Objects#Objects_and_properties">Objects and properties</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Working_with_Objects#Creating_new_objects">Creating objects</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Working_with_Objects#Defining_methods">Defining methods</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Working_with_Objects#Defining_getters_and_setters">Getter and setter</a></p>
- </li>
- <li><span><a href="/en-US/docs/Web/JavaScript/Guide/Details_of_the_Object_Model">Details of the object model</a></span>
- <p><a href="/en-US/docs/Web/JavaScript/Guide/Details_of_the_Object_Model#Class-based_vs._prototype-based_languages">Prototype-based OOP</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Details_of_the_Object_Model#Creating_the_hierarchy">Creating object hierarchies</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Details_of_the_Object_Model#Property_inheritance_revisited">Inheritance</a></p>
- </li>
-</ul>
-
-<ul class="card-grid">
- <li><span><a href="/en-US/docs/Web/JavaScript/Guide/Iterators_and_Generators">Iterators and generators</a></span>
-
- <p><a href="/en-US/docs/Web/JavaScript/Guide/Iterators_and_Generators#Iterators">Iterators</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Iterators_and_Generators#Iterables">Iterables</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Iterators_and_Generators#Generators">Generators</a><br>
- </p></li>
- <li><span><a href="/en-US/docs/Web/JavaScript/Guide/Meta_programming">Meta programming</a></span>
- <p><code><a href="/en-US/docs/Web/JavaScript/Guide/Meta_programming#Proxies">Proxy</a></code><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Meta_programming#Handlers_and_traps">Handlers and traps</a><br>
- <a href="/en-US/docs/Web/JavaScript/Guide/Meta_programming#Revocable_Proxy">Revocable Proxy</a><br>
- <code><a href="/en-US/docs/Web/JavaScript/Guide/Meta_programming#Reflection">Reflect</a></code></p>
- </li>
-</ul>
-
-<p>{{Next("Web/JavaScript/Guide/Introduction")}}</p>
diff --git a/files/he/web/javascript/index.html b/files/he/web/javascript/index.html
deleted file mode 100644
index 039763f2e9..0000000000
--- a/files/he/web/javascript/index.html
+++ /dev/null
@@ -1,97 +0,0 @@
----
-title: JavaScript
-slug: Web/JavaScript
-translation_of: Web/JavaScript
----
-<div>{{JsSidebar}}</div>
-
-<p class="summary" dir="rtl"><strong>JavaScript</strong> היא שפת תכנות מונחית עצמים, קלת משקל ומבוססת-מפרש (ולעתים עוברת הידור-בו-ברגע (JIT)), המיועדת לשימוש באתרים ואפליקציות אינטרנט, כמו כן ניתן להשתמש בה גם בסביבות רבות שאינן דפדפן האינטרנט (<a href="/he/JavaScript/אודות_JavaScript" title="he/JavaScript/אודות JavaScript">אודות JavaScript</a>). למרות שהיא ידועה בעיקר בשל היותה שפת-תסריט ליצירת אינטראקציה עם דפי אינטרנט, נעשה בה שימוש רב גם בסביבות הרצה רבות שאינן תלויות-דפדפן. כך למשל היא משמשת כשפת-תסריט בסביבת Node.js, בממשק בסיסי הנתונים CouchDB של אפאצ'י, וכן בתוכנת אקרובט של חברת Adobe. ג'אווה סקריפט היא שפה מבוססת-אבטיפוס, מרובת פרדיגמות, בעלת טיפוסיות דינמית, תומכת בסגנונות תכנות מונחה-עצמים, תכנות אימפרטיבי ותכנות דקלרטיבי (כגון תכנות פונקציונאלי, למשל). קרא עוד על ג'אווה סקריפט.</p>
-
-<p class="summary" dir="rtl">מאמר זה מוקדש לתיאור שפת ג'אווה סקריפט עצמה, ולא לחלקיה השונים הייחודיים לתכנות דפי אינטרנט, או לשאר הסביבות המשתמשות בשפה זו. עבור מידע עבור ממשקי התכנות (APIs) השונים המיועדים עבור דפי אינטרנט, עיין בחלק Web API ובחלק DOM.</p>
-
-<p class="summary" dir="rtl">התקן עבור ג'אווה סקריפט נקרא ECMAScript. נכון ל2012, כל הדפדפנים המודרניים מספקים תמיכה מלאה בתקן ECMAScript 5.1. דפדפנים ישנים יותר, תומכים לכל הפחות בתקן  ECMAScript 3. ב17 ביוני 2015, ארגון ECMA International פרסם את הגרסה השישית של  ECMAScript, הנקראת באופן רשמי  ECMAScript 2015, וקודם לכן נקראה בשם  ECMAScript 6 או ES6. מאז, תקני ECMAScript מתעדכנים במחזורי עדכון שנתיים. המסמכים הבאים המתארים את השפה, מתארים את גרסת הטיוטה האחרונה, שהיא כרגע  ECMAScript 2019.</p>
-
-<p class="summary" dir="rtl">אין לבלבל בין JavaScript לבין שפת התכנות Java. שתיהן "Java" וגם "JavaScript" הן סימני מסחר, או סימני מסחר רשומים על שם חברת Oracle בארצות הברית או במדינות אחרות. בכל מקרה, לשתי שפות התכנות הללו יש תחביר, סמנטיקה ושימושים שונים מאוד.</p>
-
-<p dir="rtl">שפת התכנות Javascript פותחה בשנת 1995 והיא אינה קשורה כלל אל שפת התכנות Java. לשפה קיימת גרסה תקנית של השפה הקרויה ECMAScript ונכון לשנת 2012, רוב הדפדפנים תומכים בגרסת ECMAScript 5.1.</p>
-
-<div class="column-container">
-<div class="column-half">
-<h2 dir="rtl" id="מדריכים">מדריכים</h2>
-
-<p dir="rtl">למד כיצד לתכנת באמצעות Javascript.</p>
-
-<h3 dir="rtl" id="היכרות_ראשונית">היכרות ראשונית</h3>
-
-<dl>
- <dt dir="rtl"><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide">מדריך Javascript</a></dt>
- <dd dir="rtl">היכרות ראשונה עם שפת Javascript למשתמשים מתחילים.</dd>
- <dt dir="rtl"><a href="/en-US/docs/Web/JavaScript/JavaScript_technologies_overview">סקירה כללית של מאפייני השפה </a></dt>
- <dd dir="rtl">שפת Javascript בדפדפן האינטרנט</dd>
- <dt dir="rtl"><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Introduction_to_Object-Oriented_JavaScript">מבוא לתכנות מונחה עצמים </a></dt>
- <dd dir="rtl">מבוא והכרת מושגים של תכנות מונחה עצמים בשפת Javascript.</dd>
-</dl>
-
-<h3 dir="rtl" id="מתחילים">מתחילים</h3>
-
-<dl>
- <dt dir="rtl"><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/A_re-introduction_to_JavaScript">מבוא לשפת Javascript </a></dt>
- <dd dir="rtl">סקירה עבור משתמשים בעלי היכרות עם JavaScript.</dd>
- <dt dir="rtl"><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures">מבנה נתונים </a></dt>
- <dd dir="rtl">סקירה כללית של מבני נתונים הזמינים ב- JavaScript.</dd>
- <dt dir="rtl"><a href="/en-US/docs/Web/JavaScript/Equality_comparisons_and_sameness">השוואות בין משתנים </a></dt>
- <dd dir="rtl">Javascript מספקת 2 אפשרויות להשוואת נתונים: השוואה רופפת באמצעות ==. והשוואה קפדנית באמצעות ===.</dd>
-</dl>
-
-<h3 dir="rtl" id="מתקדמים">מתקדמים</h3>
-
-<dl>
- <dt dir="rtl"><a href="/en-US/docs/Web/JavaScript/Inheritance_and_the_prototype_chain">ירושות</a></dt>
- <dd dir="rtl">סקירה על ירושות בשפת Javascript.</dd>
- <dt dir="rtl"><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Typed_arrays">מערכים</a></dt>
- <dd dir="rtl">מערכים מודפסים וגישה לנתונים.</dd>
- <dt dir="rtl"><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Memory_Management">ניהול זיכרון</a></dt>
- <dd dir="rtl">מחזור זכרון בשפת Javascript.</dd>
-</dl>
-</div>
-
-<div class="column-half">
-<dl>
- <dt dir="rtl">
- <h2 id="אזכורים">אזכורים</h2>
- </dt>
- <dt dir="rtl"><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects">אובייקטים סטנדרטים</a></dt>
- <dd dir="rtl">הכר את האובייקטים המובנים: <code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array" title="The JavaScript Array global object is a constructor for arrays, which are high-level, list-like objects."><code>Array</code></a></code>, <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Boolean" title="The Boolean object is an object wrapper for a boolean value."><code>Boolean</code></a>, <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date" title="Creates a JavaScript Date instance that represents a single moment in time. Date objects are based on a time value that is the number of milliseconds since 1 January, 1970 UTC."><code>Date</code></a>, <code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Error" title="The Error constructor creates an error object. Instances of Error objects are thrown when runtime errors occur. The Error object can also be used as a base objects for user-defined exceptions. See below for standard built-in error types.">Error</a>,</code> <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function" title="The Function constructor creates a new Function object. In JavaScript every function is actually a Function object."><code>Function</code></a>, <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/JSON" title="The JSON object contains methods for parsing JavaScript Object Notation (JSON) and converting values to JSON. It can't be called or constructed, and aside from its two method properties it has no interesting functionality of its own."><code>JSON</code></a>, <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Math" title="Math is a built-in object that has properties and methods for mathematical constants and functions. Not a function object."><code>Math</code></a>, <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Number" title="The Number JavaScript object is a wrapper object allowing you to work with numerical values. A Number object is created using the Number() constructor."><code>Number</code></a>, <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object"><code>Object</code></a>, <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/RegExp" title="The RegExp constructor creates a regular expression object for matching text with a pattern."><code>RegExp</code></a>, <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String" title="The String global object is a constructor for strings, or a sequence of characters."><code>String</code></a>, <a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map" title="The Map object is a simple key/value map. Any value (both objects and primitive values) may be used as either a key or a value."><code>Map</code></a>, <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Set">Set</a></code>, <code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/WeakMap" title="The WeakMap object is a collection of key/value pairs in which the keys are objects and the values can be arbitrary values."><code>WeakMap</code></a></code>, <code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/WeakSet" title="The WeakSet object lets you store weakly held objects in a collection.">WeakSet</a>.</code></dd>
- <dt dir="rtl"><a href="/en-US/docs/Web/JavaScript/Reference/Operators">ביטויים ואופרטורים </a></dt>
- <dd dir="rtl">למד אודות האופרטורים:<code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/instanceof">instanceof</a></code>, <code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/typeof">typeof</a></code>, <code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/new">new</a></code>, <code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/this">this</a></code>.</dd>
- <dt dir="rtl"><a href="/en-US/docs/Web/JavaScript/Reference/Statements">הצהרות</a> <a href="/en-US/docs/Web/JavaScript/Reference/Statements">ולולאות</a></dt>
- <dd dir="rtl">למד אודות משתנים ולולאות: <code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/do...while">do-while</a></code>, <code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/for...in">for-in</a></code>, <code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/for...of">for-of</a></code>, <code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/try...catch">try-catch</a></code> <code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/let">let</a></code>, <code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/var">var</a></code>, <code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/const">const</a></code>, <code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/if...else">if-else</a></code>, <code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/switch">switch</a>.</code></dd>
- <dt dir="rtl"><a href="/en-US/docs/Web/JavaScript/Reference/Functions">פונקציות</a></dt>
- <dd dir="rtl">למד כיצד לעבוד עם פונקציות כדי לפתח יישומים.</dd>
-</dl>
-
-<h2 dir="rtl" id="כלים_ועזרים">כלים ועזרים</h2>
-
-<p dir="rtl">כלים שימושיים לבדיקה ואיתור שגיאות בקוד ה-JavaScript שלך.</p>
-
-<dl>
- <dt dir="rtl"><a href="/en-US/docs/Tools">כלי Firefox למפתחים</a></dt>
- <dd dir="rtl">Scratchpad, Web Console, JavaScript Profiler, Debugger ועוד.</dd>
- <dt dir="rtl"><a class="external" href="http://www.getfirebug.com/">Firebug</a></dt>
- <dd dir="rtl">עריכה, בדיקת שגיאות ומעקב אחר CSS, HTML ו-JavaScript בזמן אמת ובכל עמוד אינטרנט.</dd>
- <dt dir="rtl"><a href="/en-US/docs/Web/JavaScript/Shells">JavaScript Shells</a></dt>
- <dd dir="rtl">כלי זה בודק קטעי קוד במהירות וללא צורך בטעינת העמוד מחדש.</dd>
- <dt dir="rtl"><a href="https://togetherjs.com/">TogetherJS</a></dt>
- <dd dir="rtl">הוספת TogetherJS לאתר מאפשרת למשתמשים לעזור זה לזה בזמן אמת וכך שיתוף הפעולה נעשה קל. </dd>
-</dl>
-
-<dl>
- <dt dir="rtl"><a href="http://stackoverflow.com/questions/tagged/javascript">Stack Overflow</a></dt>
- <dd dir="rtl">אתר שיתופי המאפשר למשתמשים בו להיעזר באחרים ולקבל תשובות אודות בעיות קוד שונות.  </dd>
- <dt dir="rtl"><a href="/en-US/docs/Web/JavaScript/New_in_JavaScript">גרסאות Javascript, עדכונים והערות </a><br>
- https://esdiscuss.org<br>
- https://wiki.mozilla.org/JavaScript<br>
- https://twitter.com/SpiderMonkeyJS</dt>
-</dl>
-</div>
-</div>
diff --git a/files/he/web/javascript/reference/errors/index.html b/files/he/web/javascript/reference/errors/index.html
deleted file mode 100644
index c295fccea6..0000000000
--- a/files/he/web/javascript/reference/errors/index.html
+++ /dev/null
@@ -1,31 +0,0 @@
----
-title: JavaScript error reference
-slug: Web/JavaScript/Reference/Errors
-tags:
- - Debugging
- - Error
- - Errors
- - Exception
- - JavaScript
- - NeedsTranslation
- - TopicStub
- - exceptions
-translation_of: Web/JavaScript/Reference/Errors
----
-<p>{{jsSidebar("Errors")}}</p>
-
-<p>Below, you'll find a list of errors which are thrown by JavaScript. These errors can be a helpful debugging aid, but the reported problem isn't always immediately clear. The pages below will provide additional details about these errors. Each error is an object based upon the {{jsxref("Error")}} object, and has a <code>name</code> and a <code>message</code>.</p>
-
-<p>Errors displayed in the Web console may include a link to the corresponding page below to help you quickly comprehend the problem in your code.</p>
-
-<h2 id="List_of_errors">List of errors</h2>
-
-<p>In this list, each page is listed by name (the type of error) and message (a more detailed human-readable error message). Together, these two properties provide a starting point toward understanding and resolving the error. For more information, follow the links below!</p>
-
-<p>{{ListSubPages("/en-US/docs/Web/JavaScript/Reference/Errors")}}</p>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li><a href="/en-US/docs/Learn/JavaScript/First_steps/What_went_wrong">What went wrong? Troubleshooting JavaScript</a>: Beginner's introductory tutorial on fixing JavaScript errors.</li>
-</ul>
diff --git a/files/he/web/javascript/reference/functions/default_parameters/index.html b/files/he/web/javascript/reference/functions/default_parameters/index.html
deleted file mode 100644
index 2d4215bcad..0000000000
--- a/files/he/web/javascript/reference/functions/default_parameters/index.html
+++ /dev/null
@@ -1,216 +0,0 @@
----
-title: Default parameters
-slug: Web/JavaScript/Reference/Functions/Default_parameters
-translation_of: Web/JavaScript/Reference/Functions/Default_parameters
----
-<div>{{jsSidebar("Functions")}}</div>
-
-<div dir="rtl"><strong>הצבת פרמטר ברירת מחדל לפונקציה </strong>מאפשר רישום של ערך ראשוני בזמן הגדרת הפונקציה, כך שאם לא מועבר ערך בקריאה (הפעלה) של הפונקציה, או שמעבירים <code>undefined</code> כערך, הערך הראשוני שהוגדר כברירת מחדל ישמש בתור הפרמטר של הפונקציה.</div>
-
-<p> </p>
-
-<h2 dir="rtl" id="שימוש_בשפה"><strong>שימוש בשפה</strong></h2>
-
-<pre class="syntaxbox">function [<em>name</em>]([<em>param1</em>[ = defaultValue1 ][, ..., <em>paramN</em>[ = defaultValueN ]]]) {
- <em>statements</em>
-}
-</pre>
-
-<h2 dir="rtl" id="תיאור_שימושיות"><strong>תיאור שימושיות</strong></h2>
-
-<p dir="rtl">הערך ראשוני של פרמטר בפונקציה ב JavaScript שווה ל <code>undefined</code>. אומנם ישנם מקרים בהם זה יכול להיות נוח להציב ערך שונה כערך ראשוני לפרמטר של הפונקציה, כך שהערך יוגדר מראש ביצירת הפונקציה. ופה אנחנו נעזרים בהצבת פרמטר ברירת מחדל לפונקציה.</p>
-
-<p dir="rtl">האסטרטגיה הכללית שהשתמשו בה לפני פרמטר ברירת המחדל, היתה בדיקה שנכללה בתוך גוף הפונקציה ובדקה אם הפרמטר מכיל ערך או שהוא אינו מוגדר, ולא נעשה בו שימוש בקריאה לפונקציה. בדוגמא שלפנינו אם לא נעביר ערך ל <code>b</code> בקריאה לפונקציה (בהפעלה שלה, בכל  הפעלה לש פונקציה אנחנו קוראים לה מהזיכרון), היא תקבל ערך לא מוגדר (<code>undefined</code>) וכאשר תיקראו לפונקציה <code>multiply</code> כדי לחשב את <code>a*b</code> התוצאה תהיה <code>NaN</code>. לשם כך השורה השניה בפונקציה בודקת אם קיים בפרמטר <code>b</code> ערך השונה מ <code>undefined</code> ואם לא נעשה שימוש בפרמטר <code>b</code> בקריאה לפונקציה אז מציבים בו ערך ראשוני של 1:</p>
-
-<pre class="brush: js">function multiply(a, b) {
- b = (typeof b !== 'undefined') ? b : 1;
- return a * b;
-}
-
-multiply(5, 2); // 10
-multiply(5, 1); // 5
-multiply(5); // 5
-</pre>
-
-<p dir="rtl">בעזרת הצבה של פרמטר ברירת מחדל לפונקציה הניתן לשימוש מגרסה ES2015 הבדיקה בגוף הפונקציה כבר לא נחוצה. עכשיו אפשר פשוט להציב ערך ראשוני כערך ברירת מחדל בהגדרה של הפונקציה והפרמטרים שלה:</p>
-
-<pre class="brush: js">function multiply(a, b = 1) {
- return a * b;
-}
-
-multiply(5, 2); // 10
-multiply(5, 1); // 5
-multiply(5); // 5
-</pre>
-
-<h2 dir="rtl" id="דוגמאות"><strong>דוגמאות</strong></h2>
-
-<h3 dir="rtl" id="קריאה_לפונקציה_עם_ערך_של_undefined_מול_ערכים_שליליים_שונים.">קריאה לפונקציה עם ערך של <code>undefined</code> מול ערכים שליליים שונים.</h3>
-
-<p dir="rtl">בהפעלה השניה של הפונקציה בדוגמה <code>test</code> אנחנו מעבירים באופן מכוון ערך של <code>undefined</code> והפרמטר <code>num</code> עדיין מקבל את ערך ברירת המחדל שהגדרנו בעת יצירת הפונקציה <code>(num = 1)</code>. ניתן לראות בקריאות הבאות לפונקציה, כי אך ורק <code>undefined</code> זוכה להחלפה בערך ברירת המחדל ולא שום סוג של ערך שלילי אחר ( <code>num === fale!!</code> ).</p>
-
-<pre class="brush: js">function test(num = 1) {
- console.log(typeof num);
-}
-
-test(); // 'number' (num is set to 1)
-test(undefined); // 'number' (num is set to 1 too)
-
-// test with other falsy values:
-test(''); // 'string' (num is set to '')
-test(null); // 'object' (num is set to null)
-</pre>
-
-<h3 id="Evaluated_at_call_time">Evaluated at call time</h3>
-
-<p>The default argument gets evaluated at call time, so unlike e.g. in Python, a new object is created each time the function is called.</p>
-
-<pre class="brush: js">function append(value, array = []) {
- array.push(value);
- return array;
-}
-
-append(1); //[1]
-append(2); //[2], not [1, 2]
-
-</pre>
-
-<p>This even applies to functions and variables:</p>
-
-<pre class="brush: js">function callSomething(thing = something()) {
- return thing;
-}
-
-function something() {
- return 'sth';
-}
-
-callSomething(); //sth</pre>
-
-<h3 id="Default_parameters_are_available_to_later_default_parameters">Default parameters are available to later default parameters</h3>
-
-<p>Parameters already encountered are available to later default parameters:</p>
-
-<pre class="brush: js">function singularAutoPlural(singular, plural = singular + 's',
- rallyingCry = plural + ' ATTACK!!!') {
- return [singular, plural, rallyingCry];
-}
-
-//["Gecko","Geckos", "Geckos ATTACK!!!"]
-singularAutoPlural('Gecko');
-
-//["Fox","Foxes", "Foxes ATTACK!!!"]
-singularAutoPlural('Fox', 'Foxes');
-
-//["Deer", "Deer", "Deer ... change."]
-singularAutoPlural('Deer', 'Deer', 'Deer peaceably and respectfully \
- petition the government for positive change.')
-</pre>
-
-<p>This functionality is approximated in a straight forward fashion and demonstrates how many edge cases are handled.</p>
-
-<pre class="brush: js">function go() {
- return ':P';
-}
-
-function withDefaults(a, b = 5, c = b, d = go(), e = this,
- f = arguments, g = this.value) {
- return [a, b, c, d, e, f, g];
-}
-
-function withoutDefaults(a, b, c, d, e, f, g) {
- switch (arguments.length) {
- case 0:
- a;
- case 1:
- b = 5;
- case 2:
- c = b;
- case 3:
- d = go();
- case 4:
- e = this;
- case 5:
- f = arguments;
- case 6:
- g = this.value;
- default:
- }
- return [a, b, c, d, e, f, g];
-}
-
-withDefaults.call({value: '=^_^='});
-// [undefined, 5, 5, ":P", {value:"=^_^="}, arguments, "=^_^="]
-
-
-withoutDefaults.call({value: '=^_^='});
-// [undefined, 5, 5, ":P", {value:"=^_^="}, arguments, "=^_^="]
-</pre>
-
-<h3 id="Functions_defined_inside_function_body">Functions defined inside function body</h3>
-
-<p>Introduced in Gecko 33 {{geckoRelease(33)}}. Functions declared in the function body cannot be referred inside default parameters and throw a {{jsxref("ReferenceError")}} (currently a {{jsxref("TypeError")}} in SpiderMonkey, see {{bug(1022967)}}). Default parameters are always executed first, function declarations inside the function body evaluate afterwards.</p>
-
-<pre class="brush: js">// Doesn't work! Throws ReferenceError.
-function f(a = go()) {
- function go() { return ':P'; }
-}
-</pre>
-
-<h3 id="Parameters_without_defaults_after_default_parameters">Parameters without defaults after default parameters</h3>
-
-<p>Prior to Gecko 26 {{geckoRelease(26)}}, the following code resulted in a {{jsxref("SyntaxError")}}. This has been fixed in {{bug(777060)}} and works as expected in later versions. Parameters are still set left-to-right, overwriting default parameters even if there are later parameters without defaults.</p>
-
-<pre class="brush: js">function f(x = 1, y) {
- return [x, y];
-}
-
-f(); // [1, undefined]
-f(2); // [2, undefined]
-</pre>
-
-<h3 id="Destructured_parameter_with_default_value_assignment">Destructured parameter with default value assignment</h3>
-
-<p>You can use default value assignment with the <a href="/en-US/docs/Web/JavaScript/Reference/Operators/Destructuring_assignment">destructuring assignment</a> notation:</p>
-
-<pre class="brush: js">function f([x, y] = [1, 2], {z: z} = {z: 3}) {
- return x + y + z;
-}
-
-f(); // 6</pre>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('ES2015', '#sec-function-definitions', 'Function Definitions')}}</td>
- <td>{{Spec2('ES2015')}}</td>
- <td>Initial definition.</td>
- </tr>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-function-definitions', 'Function Definitions')}}</td>
- <td>{{Spec2('ESDraft')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-<div>
-
-
-<p>{{Compat("javascript.functions.default_parameters")}}</p>
-</div>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li><a class="external" href="http://wiki.ecmascript.org/doku.php?id=harmony:parameter_default_values" rel="external" title="http://wiki.ecmascript.org/doku.php?id=harmony:parameter_default_values">Original proposal at ecmascript.org</a></li>
-</ul>
diff --git a/files/he/web/javascript/reference/functions/index.html b/files/he/web/javascript/reference/functions/index.html
deleted file mode 100644
index a58e629441..0000000000
--- a/files/he/web/javascript/reference/functions/index.html
+++ /dev/null
@@ -1,596 +0,0 @@
----
-title: Functions
-slug: Web/JavaScript/Reference/Functions
-tags:
- - Constructor
- - Function
- - Functions
- - JavaScript
- - NeedsTranslation
- - Parameter
- - TopicStub
- - parameters
-translation_of: Web/JavaScript/Reference/Functions
----
-<div>{{jsSidebar("Functions")}}</div>
-
-<p>Generally speaking, a function is a "subprogram" that can be <em>called</em> by code external (or internal in the case of recursion) to the function. Like the program itself, a function is composed of a sequence of statements called the <em>function body</em>. Values can be <em>passed</em> to a function, and the function will <em>return</em> a value.</p>
-
-<p>In JavaScript, functions are first-class objects, because they can have properties and methods just like any other object. What distinguishes them from other objects is that functions can be called. In brief, they are <code><a href="/en-US/docs/JavaScript/Reference/Global_Objects/Function">Function</a></code> objects.</p>
-
-<p>For more examples and explanations, see also the <a href="/en-US/docs/Web/JavaScript/Guide/Functions">JavaScript guide about functions</a>.</p>
-
-<h2 id="Description">Description</h2>
-
-<p>Every function in JavaScript is a <code>Function</code> object. See {{jsxref("Function")}} for information on properties and methods of <code>Function</code> objects.</p>
-
-<p>To return a value other than the default, a function must have a <code><a href="/en-US/docs/Web/JavaScript/Reference/Statements/return">return</a></code> statement that specifies the value to return. A function without a return statement will return a default value. In the case of a <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/constructor">constructor</a> called with the <code><a href="/en-US/docs/Web/JavaScript/Reference/Operators/new">new</a></code> keyword, the default value is the value of its <code>this</code> parameter. For all other functions, the default return value is {{jsxref("undefined")}}.</p>
-
-<p>The parameters of a function call are the function's <em>arguments</em>. Arguments are passed to functions <em>by value</em>. If the function changes the value of an argument, this change is not reflected globally or in the calling function. However, object references are values, too, and they are special: if the function changes the referred object's properties, that change is visible outside the function, as shown in the following example</p>
-
-<pre class="brush: js">/* Declare the function 'myFunc' */
-function myFunc(theObject) {
- theObject.brand = "Toyota";
- }
-
- /*
- * Declare variable 'mycar';
- * create and initialize a new Object;
- * assign reference to it to 'mycar'
- */
- var mycar = {
- brand: "Honda",
- model: "Accord",
- year: 1998
- };
-
- /* Logs 'Honda' */
- console.log(mycar.brand);
-
- /* Pass object reference to the function */
- myFunc(mycar);
-
- /*
- * Logs 'Toyota' as the value of the 'brand' property
- * of the object, as changed to by the function.
- */
- console.log(mycar.brand);
-</pre>
-
-<p>The <a href="/en-US/docs/Web/JavaScript/Reference/Operators/this"><code>this</code> keyword</a> does not refer to the currently executing function, so you must refer to <code>Function</code> objects by name, even within the function body.</p>
-
-<h2 id="Defining_functions">Defining functions</h2>
-
-<p>There are several ways to define functions:</p>
-
-<h3 id="The_function_declaration_(function_statement)">The function declaration (<code>function</code> statement)</h3>
-
-<p>There is a special syntax for declaring functions (see <a href="/en-US/docs/Web/JavaScript/Reference/Statements/function">function statement</a> for details):</p>
-
-<pre class="syntaxbox">function <em>name</em>([<em>param</em>[, <em>param</em>[, ... <em>param</em>]]]) {
- <em>statements</em>
-}
-</pre>
-
-<dl>
- <dt><code>name</code></dt>
- <dd>The function name.</dd>
-</dl>
-
-<dl>
- <dt><code>param</code></dt>
- <dd>The name of an argument to be passed to the function. A function can have up to 255 arguments.</dd>
-</dl>
-
-<dl>
- <dt><code>statements</code></dt>
- <dd>The statements comprising the body of the function.</dd>
-</dl>
-
-<h3 id="The_function_expression_(function_expression)">The function expression (<code>function</code> expression)</h3>
-
-<p>A function expression is similar to and has the same syntax as a function declaration (see <a href="/en-US/docs/Web/JavaScript/Reference/Operators/function">function expression</a> for details). A function expression may be a part of a larger expression. One can define "named" function expressions (where the name of the expression might be used in the call stack for example) or "anonymous" function expressions. Function expressions are not <em>hoisted</em> onto the beginning of the scope, therefore they cannot be used before they appear in the code.</p>
-
-<pre class="syntaxbox">function [<em>name</em>]([<em>param</em>[, <em>param</em>[, ... <em>param</em>]]]) {
- <em>statements</em>
-}
-</pre>
-
-<dl>
- <dt><code>name</code></dt>
- <dd>The function name. Can be omitted, in which case the function becomes known as an anonymous function.</dd>
-</dl>
-
-<dl>
- <dt><code>param</code></dt>
- <dd>The name of an argument to be passed to the function. A function can have up to 255 arguments.</dd>
- <dt><code>statements</code></dt>
- <dd>The statements comprising the body of the function.</dd>
-</dl>
-
-<p>Here is an example of an <strong>anonymous</strong> function expression (the <code>name</code> is not used):</p>
-
-<pre class="brush: js">var myFunction = function() {
- statements
-}</pre>
-
-<p>It is also possible to provide a name inside the definition in order to create a <strong>named</strong> function expression:</p>
-
-<pre class="brush: js">var myFunction = function namedFunction(){
-  statements
-}
-</pre>
-
-<p>One of the benefit of creating a named function expression is that in case we encounted an error, the stack trace will contain the name of the function, making it easier to find the origin of the error.</p>
-
-<p>As we can see, both examples do not start with the <code>function</code> keyword. Statements involving functions which do not start with <code>function</code> are function expressions.</p>
-
-<p>When functions are used only once, a common pattern is an <strong>IIFE (<em>Immediately Invokable Function Expression</em>)</strong>.</p>
-
-<pre class="brush: js">(function() {
- statements
-})();</pre>
-
-<p>IIFE are function expressions that are invoked as soon as the function is declared.</p>
-
-<h3 id="The_generator_function_declaration_(function*_statement)">The generator function declaration (<code>function*</code> statement)</h3>
-
-<p>There is a special syntax for generator function declarations (see {{jsxref('Statements/function*', 'function* statement')}} for details):</p>
-
-<pre class="syntaxbox">function* <em>name</em>([<em>param</em>[, <em>param</em>[, ... <em>param</em>]]]) {
- <em>statements</em>
-}
-</pre>
-
-<dl>
- <dt><code>name</code></dt>
- <dd>The function name.</dd>
-</dl>
-
-<dl>
- <dt><code>param</code></dt>
- <dd>The name of an argument to be passed to the function. A function can have up to 255 arguments.</dd>
-</dl>
-
-<dl>
- <dt><code>statements</code></dt>
- <dd>The statements comprising the body of the function.</dd>
-</dl>
-
-<h3 id="The_generator_function_expression_(function*_expression)">The generator function expression (<code>function*</code> expression)</h3>
-
-<p>A generator function expression is similar to and has the same syntax as a generator function declaration (see {{jsxref('Operators/function*', 'function* expression')}} for details):</p>
-
-<pre class="syntaxbox">function* [<em>name</em>]([<em>param</em>[, <em>param</em>[, ... <em>param</em>]]]) {
- <em>statements</em>
-}
-</pre>
-
-<dl>
- <dt><code>name</code></dt>
- <dd>The function name. Can be omitted, in which case the function becomes known as an anonymous function.</dd>
-</dl>
-
-<dl>
- <dt><code>param</code></dt>
- <dd>The name of an argument to be passed to the function. A function can have up to 255 arguments.</dd>
- <dt><code>statements</code></dt>
- <dd>The statements comprising the body of the function.</dd>
-</dl>
-
-<h3 id="The_arrow_function_expression_(>)">The arrow function expression (=&gt;)</h3>
-
-<p>An arrow function expression has a shorter syntax and lexically binds its <code>this</code> value (see <a href="/en-US/docs/Web/JavaScript/Reference/Functions/Arrow_functions">arrow functions</a> for details):</p>
-
-<pre class="syntaxbox">([param[, param]]) =&gt; {
- statements
-}
-
-param =&gt; expression
-</pre>
-
-<dl>
- <dt><code>param</code></dt>
- <dd>The name of an argument. Zero arguments need to be indicated with <code>()</code>.  For only one argument, the parentheses are not required. (like <code>foo =&gt; 1</code>)</dd>
- <dt><code>statements or expression</code></dt>
- <dd>Multiple statements need to be enclosed in brackets. A single expression requires no brackets. The expression is also the implicit return value of the function.</dd>
-</dl>
-
-<h3 id="The_Function_constructor">The <code>Function</code> constructor</h3>
-
-<div class="note">
-<p><strong>Note:</strong> Using the <code>Function</code> constructor to create functions is not recommended since it needs the function body as a string which may prevent some JS engine optimizations and can also cause other problems.</p>
-</div>
-
-<p>As all other objects, {{jsxref("Function")}} objects can be created using the <code>new</code> operator:</p>
-
-<pre class="syntaxbox">new Function (<em>arg1</em>, <em>arg2</em>, ... <em>argN</em>, <em>functionBody</em>)
-</pre>
-
-<dl>
- <dt><code>arg1, arg2, ... arg<em>N</em></code></dt>
- <dd>Zero or more names to be used by the function as formal parameters. Each must be a proper JavaScript identifier.</dd>
-</dl>
-
-<dl>
- <dt><code>functionBody</code></dt>
- <dd>A string containing the JavaScript statements comprising the function body.</dd>
-</dl>
-
-<p>Invoking the <code>Function</code> constructor as a function (without using the <code>new</code> operator) has the same effect as invoking it as a constructor.</p>
-
-<h3 id="The_GeneratorFunction_constructor">The <code>GeneratorFunction</code> constructor</h3>
-
-<div class="note">
-<p><strong>Note:</strong> <code>GeneratorFunction</code> is not a global object, but could be obtained from generator function instance (see {{jsxref("GeneratorFunction")}} for more detail).</p>
-</div>
-
-<div class="note">
-<p><strong>Note:</strong> Using the <code>GeneratorFunction</code> constructor to create functions is not recommended since it needs the function body as a string which may prevent some JS engine optimizations and can also cause other problems.</p>
-</div>
-
-<p>As all other objects, {{jsxref("GeneratorFunction")}} objects can be created using the <code>new</code> operator:</p>
-
-<pre class="syntaxbox">new GeneratorFunction (<em>arg1</em>, <em>arg2</em>, ... <em>argN</em>, <em>functionBody</em>)
-</pre>
-
-<dl>
- <dt><code>arg1, arg2, ... arg<em>N</em></code></dt>
- <dd>Zero or more names to be used by the function as formal argument names. Each must be a string that conforms to the rules for a valid JavaScript identifier or a list of such strings separated with a comma; for example "<code>x</code>", "<code>theValue</code>", or "<code>a,b</code>".</dd>
-</dl>
-
-<dl>
- <dt><code>functionBody</code></dt>
- <dd>A string containing the JavaScript statements comprising the function definition.</dd>
-</dl>
-
-<p>Invoking the <code>Function</code> constructor as a function (without using the <code>new</code> operator) has the same effect as invoking it as a constructor.</p>
-
-<h2 id="Function_parameters">Function parameters</h2>
-
-<h3 id="Default_parameters">Default parameters</h3>
-
-<p>Default function parameters allow formal parameters to be initialized with default values if no value or <code>undefined</code> is passed. For more details, see<a href="/en-US/docs/Web/JavaScript/Reference/Functions/Default_parameters"> default parameters</a>.</p>
-
-<h3 id="Rest_parameters">Rest parameters</h3>
-
-<p>The rest parameter syntax allows to represent an indefinite number of arguments as an array. For more details, see <a href="/en-US/docs/Web/JavaScript/Reference/Functions/rest_parameters">rest parameters</a>.</p>
-
-<h2 id="The_arguments_object">The <code>arguments</code> object</h2>
-
-<p>You can refer to a function's arguments within the function by using the <code>arguments</code> object. See <a href="/en-US/docs/Web/JavaScript/Reference/Functions/arguments">arguments</a>.</p>
-
-<ul>
- <li><code><a href="/en-US/docs/JavaScript/Reference/Functions_and_function_scope/arguments">arguments</a></code>: An array-like object containing the arguments passed to the currently executing function.</li>
- <li><code><a href="/en-US/docs/JavaScript/Reference/Functions_and_function_scope/arguments/callee">arguments.callee</a></code> {{Deprecated_inline}}: The currently executing function.</li>
- <li><code><a href="/en-US/docs/JavaScript/Reference/Functions_and_function_scope/arguments/caller">arguments.caller</a></code> {{Obsolete_inline}} : The function that invoked the currently executing function.</li>
- <li><code><a href="/en-US/docs/JavaScript/Reference/Functions_and_function_scope/arguments/length">arguments.length</a></code>: The number of arguments passed to the function.</li>
-</ul>
-
-<h2 id="Defining_method_functions">Defining method functions</h2>
-
-<h3 id="Getter_and_setter_functions">Getter and setter functions</h3>
-
-<p>You can define getters (accessor methods) and setters (mutator methods) on any standard built-in object or user-defined object that supports the addition of new properties. The syntax for defining getters and setters uses the object literal syntax.</p>
-
-<dl>
- <dt><a href="/en-US/docs/Web/JavaScript/Reference/Functions/get">get</a></dt>
- <dd>
- <p>Binds an object property to a function that will be called when that property is looked up.</p>
- </dd>
- <dt><a href="/en-US/docs/Web/JavaScript/Reference/Functions/set">set</a></dt>
- <dd>Binds an object property to a function to be called when there is an attempt to set that property.</dd>
-</dl>
-
-<h3 id="Method_definition_syntax">Method definition syntax</h3>
-
-<p>Starting with ECMAScript 2015, you are able to define own methods in a shorter syntax, similar to the getters and setters. See <a href="/en-US/docs/Web/JavaScript/Reference/Functions/Method_definitions">method definitions</a> for more information.</p>
-
-<pre class="brush: js">var obj = {
- foo() {},
-  bar() {}
-};</pre>
-
-<h2 id="Function_constructor_vs._function_declaration_vs._function_expression"><code>Function</code> constructor vs. function declaration vs. function expression</h2>
-
-<p>Compare the following:</p>
-
-<p>A function defined with the <code>Function</code> constructor assigned to the variable <code>multiply:</code></p>
-
-<pre class="brush: js">var multiply = new Function('x', 'y', 'return x * y');</pre>
-
-<p>A <em>function declaration</em> of a function named <code>multiply</code>:</p>
-
-<pre class="brush: js">function multiply(x, y) {
-  return x * y;
-} // there is no semicolon here
-</pre>
-
-<p>A <em>function expression</em> of an anonymous function assigned to the variable <code>multiply:</code></p>
-
-<pre class="brush: js">var multiply = function(x, y) {
- return x * y;
-};
-</pre>
-
-<p>A <em>function expression</em> of a function named <code>func_name</code> assigned to the variable <code>multiply:</code></p>
-
-<pre class="brush: js">var multiply = function func_name(x, y) {
- return x * y;
-};
-</pre>
-
-<h3 id="Differences">Differences</h3>
-
-<p>All do approximately the same thing, with a few subtle differences:</p>
-
-<p>There is a distinction between the function name and the variable the function is assigned to. The function name cannot be changed, while the variable the function is assigned to can be reassigned. The function name can be used only within the function's body. Attempting to use it outside the function's body results in an error (or <code>undefined</code> if the function name was previously declared via a <code>var</code> statement). For example:</p>
-
-<pre class="brush: js">var y = function x() {};
-alert(x); // throws an error
-</pre>
-
-<p>The function name also appears when the function is serialized via <a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function/toString"><code>Function</code>'s toString method</a>.</p>
-
-<p>On the other hand, the variable the function is assigned to is limited only by its scope, which is guaranteed to include the scope in which the function is declared.</p>
-
-<p>As the 4th example shows, the function name can be different from the variable the function is assigned to. They have no relation to each other. A function declaration also creates a variable with the same name as the function name. Thus, unlike those defined by function expressions, functions defined by function declarations can be accessed by their name in the scope they were defined in:</p>
-
-<p>A function defined by '<code>new Function'</code> does not have a function name. However, in the <a href="/en-US/docs/Mozilla/Projects/SpiderMonkey">SpiderMonkey</a> JavaScript engine, the serialized form of the function shows as if it has the name "anonymous". For example, <code>alert(new Function())</code> outputs:</p>
-
-<pre class="brush: js">function anonymous() {
-}
-</pre>
-
-<p>Since the function actually does not have a name, <code>anonymous</code> is not a variable that can be accessed within the function. For example, the following would result in an error:</p>
-
-<pre class="brush: js">var foo = new Function("alert(anonymous);");
-foo();
-</pre>
-
-<p>Unlike functions defined by function expressions or by the <code>Function</code> constructor, a function defined by a function declaration can be used before the function declaration itself. For example:</p>
-
-<pre class="brush: js">foo(); // alerts FOO!
-function foo() {
- alert('FOO!');
-}
-</pre>
-
-<p>A function defined by a function expression or by a function declaration inherits the current scope. That is, the function forms a closure. On the other hand, a function defined by a <code>Function</code> constructor does not inherit any scope other than the global scope (which all functions inherit).</p>
-
-<pre class="brush: js">/*
- * Declare and initialize a variable 'p' (global)
- * and a function 'myFunc' (to change the scope) inside which
- * declare a varible with same name 'p' (current) and
- * define three functions using three different ways:-
- * 1. function declaration
- * 2. function expression
- * 3. function constructor
- * each of which will log 'p'
- */
-var p = 5;
-function myFunc() {
- var p = 9;
-
- function decl() {
- console.log(p);
- }
- var expr = function() {
- console.log(p);
- };
- var cons = new Function('\tconsole.log(p);');
-
- decl();
- expr();
- cons();
-}
-myFunc();
-
-/*
- * Logs:-
- * 9 - for 'decl' by function declaration (current scope)
- * 9 - for 'expr' by function expression (current scope)
- * 5 - for 'cons' by Function constructor (global scope)
- */
-</pre>
-
-<p>Functions defined by function expressions and function declarations are parsed only once, while those defined by the <code>Function</code> constructor are not. That is, the function body string passed to the <code>Function</code> constructor must be parsed each and every time the constructor is called. Although a function expression creates a closure every time, the function body is not reparsed, so function expressions are still faster than "<code>new Function(...)</code>". Therefore the <code>Function</code> constructor should generally be avoided whenever possible.</p>
-
-<p>It should be noted, however, that function expressions and function declarations nested within the function generated by parsing a <code>Function constructor</code> 's string aren't parsed repeatedly. For example:</p>
-
-<pre class="brush: js">var foo = (new Function("var bar = \'FOO!\';\nreturn(function() {\n\talert(bar);\n});"))();
-foo(); // The segment "function() {\n\talert(bar);\n}" of the function body string is not re-parsed.</pre>
-
-<p>A function declaration is very easily (and often unintentionally) turned into a function expression. A function declaration ceases to be one when it either:</p>
-
-<ul>
- <li>becomes part of an expression</li>
- <li>is no longer a "source element" of a function or the script itself. A "source element" is a non-nested statement in the script or a function body:</li>
-</ul>
-
-<pre class="brush: js">var x = 0; // source element
-if (x === 0) { // source element
- x = 10; // not a source element
- function boo() {} // not a source element
-}
-function foo() { // source element
- var y = 20; // source element
- function bar() {} // source element
- while (y === 10) { // source element
- function blah() {} // not a source element
- y++; // not a source element
- }
-}
-</pre>
-
-<h3 id="Examples">Examples</h3>
-
-<pre class="brush: js">// function declaration
-function foo() {}
-
-// function expression
-(function bar() {})
-
-// function expression
-x = function hello() {}
-
-
-if (x) {
- // function expression
- function world() {}
-}
-
-
-// function declaration
-function a() {
- // function declaration
- function b() {}
- if (0) {
- // function expression
- function c() {}
- }
-}
-</pre>
-
-<h2 id="Block-level_functions">Block-level functions</h2>
-
-<p>In <a href="/en-US/docs/Web/JavaScript/Reference/Strict_mode">strict mode</a>, starting with ES2015, functions inside blocks are now scoped to that block. Prior to ES2015, block-level functions were forbidden in strict mode.</p>
-
-<pre class="brush: js">'use strict';
-
-function f() {
- return 1;
-}
-
-{
- function f() {
- return 2;
- }
-}
-
-f() === 1; // true
-
-// f() === 2 in non-strict mode
-</pre>
-
-<h3 id="Block-level_functions_in_non-strict_code">Block-level functions in non-strict code</h3>
-
-<p>In a word: Don't.</p>
-
-<p>In non-strict code, function declarations inside blocks behave strangely. For example:</p>
-
-<pre class="brush: js">if (shouldDefineZero) {
- function zero() { // DANGER: compatibility risk
- console.log("This is zero.");
- }
-}
-</pre>
-
-<p>ES2015 says that if <code>shouldDefineZero</code> is false, then <code>zero</code> should never be defined, since the block never executes. However, it's a new part of the standard. Historically, this was left unspecified, and some browsers would define <code>zero</code> whether the block executed or not.</p>
-
-<p>In <a href="/en-US/docs/Web/JavaScript/Reference/Strict_mode">strict mode</a>, all browsers that support ES2015 handle this the same way: <code>zero</code> is defined only if <code>shouldDefineZero</code> is true, and only in the scope of the <code>if</code>-block.</p>
-
-<p>A safer way to define functions conditionally is to assign a function expression to a variable:</p>
-
-<pre class="brush: js">var zero;
-if (shouldDefineZero) {
- zero = function() {
- console.log("This is zero.");
- };
-}
-</pre>
-
-<h2 id="Examples_2">Examples</h2>
-
-<h3 id="Returning_a_formatted_number">Returning a formatted number</h3>
-
-<p>The following function returns a string containing the formatted representation of a number padded with leading zeros.</p>
-
-<pre class="brush: js">// This function returns a string padded with leading zeros
-function padZeros(num, totalLen) {
- var numStr = num.toString(); // Initialize return value as string
- var numZeros = totalLen - numStr.length; // Calculate no. of zeros
- for (var i = 1; i &lt;= numZeros; i++) {
- numStr = "0" + numStr;
- }
- return numStr;
-}
-</pre>
-
-<p>The following statements call the padZeros function.</p>
-
-<pre class="brush: js">var result;
-result = padZeros(42,4); // returns "0042"
-result = padZeros(42,2); // returns "42"
-result = padZeros(5,4); // returns "0005"
-</pre>
-
-<h3 id="Determining_whether_a_function_exists">Determining whether a function exists</h3>
-
-<p>You can determine whether a function exists by using the <code>typeof</code> operator. In the following example, a test is performed to determine if the <code>window</code> object has a property called <code>noFunc</code> that is a function. If so, it is used; otherwise some other action is taken.</p>
-
-<pre class="brush: js"> if ('function' === typeof window.noFunc) {
- // use noFunc()
- } else {
- // do something else
- }
-</pre>
-
-<p>Note that in the <code>if</code> test, a reference to <code>noFunc</code> is used—there are no brackets "()" after the function name so the actual function is not called.</p>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('ES1')}}</td>
- <td>{{Spec2('ES1')}}</td>
- <td>Initial definition. Implemented in JavaScript 1.0</td>
- </tr>
- <tr>
- <td>{{SpecName('ES5.1', '#sec-13', 'Function Definition')}}</td>
- <td>{{Spec2('ES5.1')}}</td>
- <td> </td>
- </tr>
- <tr>
- <td>{{SpecName('ES6', '#sec-function-definitions', 'Function definitions')}}</td>
- <td>{{Spec2('ES6')}}</td>
- <td>New: Arrow functions, Generator functions, default parameters, rest parameters.</td>
- </tr>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-function-definitions', 'Function definitions')}}</td>
- <td>{{Spec2('ESDraft')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-
-
-<p>{{Compat("javascript.functions")}}</p>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li>{{jsxref("Statements/function", "function statement")}}</li>
- <li>{{jsxref("Operators/function", "function expression")}}</li>
- <li>{{jsxref("Statements/function*", "function* statement")}}</li>
- <li>{{jsxref("Operators/function*", "function* expression")}}</li>
- <li>{{jsxref("Function")}}</li>
- <li>{{jsxref("GeneratorFunction")}}</li>
- <li>{{jsxref("Functions/Arrow_functions", "Arrow functions")}}</li>
- <li>{{jsxref("Functions/Default_parameters", "Default parameters")}}</li>
- <li>{{jsxref("Functions/rest_parameters", "Rest parameters")}}</li>
- <li>{{jsxref("Functions/arguments", "Arguments object")}}</li>
- <li>{{jsxref("Functions/get", "getter")}}</li>
- <li>{{jsxref("Functions/set", "setter")}}</li>
- <li>{{jsxref("Functions/Method_definitions", "Method definitions")}}</li>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Functions_and_function_scope">Functions and function scope</a></li>
-</ul>
diff --git a/files/he/web/javascript/reference/global_objects/array/from/index.html b/files/he/web/javascript/reference/global_objects/array/from/index.html
deleted file mode 100644
index 1ab52ffa12..0000000000
--- a/files/he/web/javascript/reference/global_objects/array/from/index.html
+++ /dev/null
@@ -1,243 +0,0 @@
----
-title: ()Array.from
-slug: Web/JavaScript/Reference/Global_Objects/Array/from
-translation_of: Web/JavaScript/Reference/Global_Objects/Array/from
----
-<div>מתודת ה-</div>
-
-<div dir="ltr"><code><strong>Array.from()</strong></code><strong> </strong></div>
-
-<div>יוצרת מערך חדש שהוא העתק בעומק אחד (לא יכלול את האובייקטים אליהם יש הפניות מאיברים במערך הנתון) של המערך או אובייקט איטרבילי המועבר כפרמטר.</div>
-
-<div dir="rtl"></div>
-
-<div>{{EmbedInteractiveExample("pages/js/array-from.html")}}</div>
-
-
-
-<h2 id="Syntax">Syntax</h2>
-
-<pre class="brush: js">Array.from(arrayLike[, mapFn[, thisArg]])
-</pre>
-
-<h3 id="Parameters">Parameters</h3>
-
-<dl>
- <dt><code>arrayLike</code></dt>
- <dd>An array-like or iterable object to convert to an array.</dd>
- <dt><code>mapFn</code> {{Optional_inline}}</dt>
- <dd>Map function to call on every element of the array.</dd>
- <dt><code>thisArg</code> {{Optional_inline}}</dt>
- <dd>Value to use as <code>this</code> when executing <code>mapFn</code>.</dd>
-</dl>
-
-<h3 id="Return_value">Return value</h3>
-
-<p>A new {{jsxref("Array")}} instance.</p>
-
-<h2 id="Description">Description</h2>
-
-<p><code>Array.from()</code> lets you create <code>Array</code>s from:</p>
-
-<ul>
- <li>array-like objects (objects with a <code>length</code> property and indexed elements) or</li>
- <li><a href="/en-US/docs/Web/JavaScript/Guide/iterable">iterable objects</a> (objects where you can get its elements, such as {{jsxref("Map")}} and {{jsxref("Set")}}).</li>
-</ul>
-
-<p><code>Array.from()</code> has an optional parameter <code>mapFn</code>, which allows you to execute a {{jsxref("Array.prototype.map", "map")}} function on each element of the array (or subclass object) that is being created. More clearly,<code> Array.from(obj, mapFn, thisArg)</code> has the same result as <code>Array.from(obj).map(mapFn, thisArg)</code>, except that it does not create an intermediate array. This is especially important for certain array subclasses, like <a href="/en-US/docs/Web/JavaScript/Typed_arrays">typed arrays</a>, since the intermediate array would necessarily have values truncated to fit into the appropriate type.</p>
-
-<p>The <code>length</code> property of the <code>from()</code> method is 1.</p>
-
-<p>In ES2015, the class syntax allows for sub-classing of both built-in and user defined classes; as a result, static methods such as <code>Array.from</code> are "inherited" by subclasses of <code>Array</code> and create new instances of the subclass, not <code>Array</code>.</p>
-
-<h2 id="Examples">Examples</h2>
-
-<h3 id="Array_from_a_String">Array from a <code>String</code></h3>
-
-<pre class="brush: js">Array.from('foo');
-// [ "f", "o", "o" ]</pre>
-
-<h3 id="Array_from_a_Set">Array from a <code>Set</code></h3>
-
-<pre class="brush: js">const set = new Set(['foo', 'bar', 'baz', 'foo']);
-Array.from(set);
-// [ "foo", "bar", "baz" ]</pre>
-
-<h3 id="Array_from_a_Map">Array from a <code>Map</code></h3>
-
-<pre class="brush: js">const map = new Map([[1, 2], [2, 4], [4, 8]]);
-Array.from(map);
-// [[1, 2], [2, 4], [4, 8]]
-
-const mapper = new Map([['1', 'a'], ['2', 'b']]);
-Array.from(mapper.values());
-// ['a', 'b'];
-
-Array.from(mapper.keys());
-// ['1', '2'];
-</pre>
-
-<h3 id="Array_from_an_Array-like_object_(arguments)">Array from an Array-like object (arguments)</h3>
-
-<pre class="brush: js">function f() {
- return Array.from(arguments);
-}
-
-f(1, 2, 3);
-
-// [ 1, 2, 3 ]</pre>
-
-<h3 id="Using_arrow_functions_and_Array.from">Using arrow functions and <code>Array.from</code></h3>
-
-<pre class="brush: js">// Using an arrow function as the map function to
-// manipulate the elements
-Array.from([1, 2, 3], x =&gt; x + x);
-// [2, 4, 6]
-
-
-// Generate a sequence of numbers
-// Since the array is initialized with `undefined` on each position,
-// the value of `v` below will be `undefined`
-Array.from({length: 5}, (v, i) =&gt; i);
-// [0, 1, 2, 3, 4]
-</pre>
-
-<h3 id="Sequence_generator_(range)">Sequence generator (range)</h3>
-
-<pre class="brush: js">// Sequence generator function (commonly referred to as "range", e.g. Clojure, PHP etc)
-const range = (start, stop, step) =&gt; Array.from({ length: (stop - start) / step + 1}, (_, i) =&gt; start + (i * step));
-
-// Generate numbers range 0..4
-range(0, 4, 1);
-// [0, 1, 2, 3, 4]
-
-// Generate numbers range 1..10 with step of 2
-range(1, 10, 2);
-// [1, 3, 5, 7, 9]
-
-// Generate the alphabet using Array.from making use of it being ordered as a sequence
-range('A'.charCodeAt(0), 'Z'.charCodeAt(0), 1).map(x =&gt; String.fromCharCode(x));
-// ["A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z"]
-</pre>
-
-<h2 id="Polyfill">Polyfill</h2>
-
-<p><code>Array.from</code> was added to the ECMA-262 standard in the 6th edition (ES2015); as such it may not be present in other implementations of the standard. You can work around this by inserting the following code at the beginning of your scripts, allowing use of <code>Array.from</code> in implementations that don't natively support it. This algorithm is exactly the one specified in ECMA-262, 6th edition, assuming <code>Object</code> and <code>TypeError</code> have their original values and that <code>callback.call</code> evaluates to the original value of {{jsxref("Function.prototype.call")}}. In addition, since true iterables can not be polyfilled, this implementation does not support generic iterables as defined in the 6th edition of ECMA-262.</p>
-
-<pre class="brush: js">// Production steps of ECMA-262, Edition 6, 22.1.2.1
-if (!Array.from) {
- Array.from = (function () {
- var toStr = Object.prototype.toString;
- var isCallable = function (fn) {
- return typeof fn === 'function' || toStr.call(fn) === '[object Function]';
- };
- var toInteger = function (value) {
- var number = Number(value);
- if (isNaN(number)) { return 0; }
- if (number === 0 || !isFinite(number)) { return number; }
- return (number &gt; 0 ? 1 : -1) * Math.floor(Math.abs(number));
- };
- var maxSafeInteger = Math.pow(2, 53) - 1;
- var toLength = function (value) {
- var len = toInteger(value);
- return Math.min(Math.max(len, 0), maxSafeInteger);
- };
-
- // The length property of the from method is 1.
- return function from(arrayLike/*, mapFn, thisArg */) {
- // 1. Let C be the this value.
- var C = this;
-
- // 2. Let items be ToObject(arrayLike).
- var items = Object(arrayLike);
-
- // 3. ReturnIfAbrupt(items).
- if (arrayLike == null) {
- throw new TypeError('Array.from requires an array-like object - not null or undefined');
- }
-
- // 4. If mapfn is undefined, then let mapping be false.
- var mapFn = arguments.length &gt; 1 ? arguments[1] : void undefined;
- var T;
- if (typeof mapFn !== 'undefined') {
- // 5. else
- // 5. a If IsCallable(mapfn) is false, throw a TypeError exception.
- if (!isCallable(mapFn)) {
- throw new TypeError('Array.from: when provided, the second argument must be a function');
- }
-
- // 5. b. If thisArg was supplied, let T be thisArg; else let T be undefined.
- if (arguments.length &gt; 2) {
- T = arguments[2];
- }
- }
-
- // 10. Let lenValue be Get(items, "length").
- // 11. Let len be ToLength(lenValue).
- var len = toLength(items.length);
-
- // 13. If IsConstructor(C) is true, then
- // 13. a. Let A be the result of calling the [[Construct]] internal method
- // of C with an argument list containing the single item len.
- // 14. a. Else, Let A be ArrayCreate(len).
- var A = isCallable(C) ? Object(new C(len)) : new Array(len);
-
- // 16. Let k be 0.
- var k = 0;
- // 17. Repeat, while k &lt; len… (also steps a - h)
- var kValue;
- while (k &lt; len) {
- kValue = items[k];
- if (mapFn) {
- A[k] = typeof T === 'undefined' ? mapFn(kValue, k) : mapFn.call(T, kValue, k);
- } else {
- A[k] = kValue;
- }
- k += 1;
- }
- // 18. Let putStatus be Put(A, "length", len, true).
- A.length = len;
- // 20. Return A.
- return A;
- };
- }());
-}
-</pre>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-array.from', 'Array.from')}}</td>
- <td>{{Spec2('ESDraft')}}</td>
- <td></td>
- </tr>
- <tr>
- <td>{{SpecName('ES2015', '#sec-array.from', 'Array.from')}}</td>
- <td>{{Spec2('ES2015')}}</td>
- <td>Initial definition.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-
-
-<p>{{Compat("javascript.builtins.Array.from")}}</p>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li>{{jsxref("Array")}}</li>
- <li>{{jsxref("Array.prototype.map()")}}</li>
- <li>{{jsxref("TypedArray.from()")}}</li>
-</ul>
diff --git a/files/he/web/javascript/reference/global_objects/array/includes/index.html b/files/he/web/javascript/reference/global_objects/array/includes/index.html
deleted file mode 100644
index 369e5ad018..0000000000
--- a/files/he/web/javascript/reference/global_objects/array/includes/index.html
+++ /dev/null
@@ -1,169 +0,0 @@
----
-title: Array.prototype.includes()
-slug: Web/JavaScript/Reference/Global_Objects/Array/includes
-tags:
- - ג'אווה סקריפט
- - מערך
- - פוליפיל
- - פרוטוטייפ
-translation_of: Web/JavaScript/Reference/Global_Objects/Array/includes
----
-<div dir="rtl">{{JSRef}}</div>
-
-<div dir="rtl">שיטת <code><strong>includes()</strong></code> קובעת אם מערך מכיל אלמנט מסויים, מחזיר true או false בהתאם.</div>
-
-<div dir="rtl"> </div>
-
-<h2 dir="rtl" id="תחביר">תחביר</h2>
-
-<pre class="syntaxbox">var <var>boolean</var> = <var>array</var>.includes(<var>searchElement</var>[, <var>fromIndex</var>])</pre>
-
-<h3 dir="rtl" id="פרמטרים">פרמטרים</h3>
-
-<dl>
- <dt dir="rtl"><code>searchElement</code></dt>
- <dd dir="rtl">האלמנט אותו מחפשים</dd>
- <dt dir="rtl"><code>fromIndex</code></dt>
- <dd dir="rtl">אופציונלי. המיקום במערך בו להתחיל את החיפוש אחר searchElement. ערך שלילי יתחיל את החיפוש מהערך האחרון (array.length) + fromIndex בסדר עולה. ברירת מחדל 0.</dd>
-</dl>
-
-<h3 dir="rtl" id="ערך_מוחזר_(Return)">ערך מוחזר (Return)</h3>
-
-<p dir="rtl">{{jsxref("Boolean")}}.</p>
-
-<h2 dir="rtl" id="דוגמאות">דוגמאות</h2>
-
-<pre class="brush: js">[1, 2, 3].includes(2); // true
-[1, 2, 3].includes(4); // false
-[1, 2, 3].includes(3, 3); // false
-[1, 2, 3].includes(3, -1); // true
-[1, 2, NaN].includes(NaN); // true
-</pre>
-
-<h2 dir="rtl" id="פוליפיל_-_Polyfill">פוליפיל - Polyfill</h2>
-
-<pre class="brush: js">if (!Array.prototype.includes) {
- Array.prototype.includes = function(searchElement /*, fromIndex*/) {
- 'use strict';
- if (this == null) {
- throw new TypeError('Array.prototype.includes called on null or undefined');
- }
-
- var O = Object(this);
- var len = parseInt(O.length, 10) || 0;
- if (len === 0) {
- return false;
- }
- var n = parseInt(arguments[1], 10) || 0;
- var k;
- if (n &gt;= 0) {
- k = n;
- } else {
- k = len + n;
- if (k &lt; 0) {k = 0;}
- }
- var currentElement;
- while (k &lt; len) {
- currentElement = O[k];
- if (searchElement === currentElement ||
- (searchElement !== searchElement &amp;&amp; currentElement !== currentElement)) { // NaN !== NaN
- return true;
- }
- k++;
- }
- return false;
- };
-}
-</pre>
-
-<h2 dir="rtl" id="מפרט">מפרט</h2>
-
-<table class="standard-table" dir="rtl" style="height: 185px; width: 490px;">
- <tbody>
- <tr>
- <th scope="col"><span class="hidden"> </span><span class="hidden"> </span>מפרט</th>
- <th scope="col">סטטוס</th>
- <th scope="col">הערה</th>
- </tr>
- <tr>
- <td>{{SpecName('ES7', '#sec-array.prototype.includes', 'Array.prototype.includes')}}</td>
- <td>{{Spec2('ES7')}}</td>
- <td>הגדרה ראשונית</td>
- </tr>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-array.prototype.includes', 'Array.prototype.includes')}}</td>
- <td>{{Spec2('ESDraft')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="תאימות_דפדפנים">תאימות דפדפנים</h2>
-
-<div>{{CompatibilityTable}}</div>
-
-<div id="compat-desktop">
-<table class="compat-table">
- <tbody>
- <tr>
- <th>מאפיין</th>
- <th>Chrome</th>
- <th>Firefox (Gecko)</th>
- <th>Internet Explorer</th>
- <th>Edge</th>
- <th>Opera</th>
- <th>Safari</th>
- </tr>
- <tr>
- <td>תמיכה בסיסית</td>
- <td>
- <p>{{CompatChrome(47)}}</p>
- </td>
- <td>43</td>
- <td>{{CompatNo}}</td>
- <td>14279+</td>
- <td>34</td>
- <td>9</td>
- </tr>
- </tbody>
-</table>
-</div>
-
-<div id="compat-mobile">
-<table class="compat-table">
- <tbody>
- <tr>
- <th>מאפיין</th>
- <th>Android</th>
- <th>Android Webview</th>
- <th>Firefox Mobile (Gecko)</th>
- <th>IE Mobile</th>
- <th>Opera Mobile</th>
- <th>Safari Mobile</th>
- <th>Chrome for Android</th>
- </tr>
- <tr>
- <td>תמיכה בסיסית</td>
- <td>{{CompatNo}}</td>
- <td>
- <p>{{CompatChrome(47)}}</p>
- </td>
- <td>43</td>
- <td>{{CompatNo}}</td>
- <td>34</td>
- <td>9</td>
- <td>
- <p>{{CompatChrome(47)}}</p>
- </td>
- </tr>
- </tbody>
-</table>
-</div>
-
-<h2 dir="rtl" id="ראה_עוד">ראה עוד</h2>
-
-<ul dir="rtl">
- <li>{{jsxref("TypedArray.prototype.includes()")}}</li>
- <li>{{jsxref("String.prototype.includes()")}}</li>
- <li>{{jsxref("Array.prototype.indexOf()")}}</li>
-</ul>
diff --git a/files/he/web/javascript/reference/global_objects/array/index.html b/files/he/web/javascript/reference/global_objects/array/index.html
deleted file mode 100644
index 4dac733b4a..0000000000
--- a/files/he/web/javascript/reference/global_objects/array/index.html
+++ /dev/null
@@ -1,485 +0,0 @@
----
-title: Array
-slug: Web/JavaScript/Reference/Global_Objects/Array
-tags:
- - Global Objects
- - JavaScript
- - NeedsTranslation
- - Reference
- - TopicStub
- - דוגמא
- - מערך
-translation_of: Web/JavaScript/Reference/Global_Objects/Array
----
-<p dir="rtl">האובייקט <strong>מערך(</strong>Array<strong>)</strong> בג'אווה סקריפט הוא אובייקט גלובלי אשר משמש לבניית מערכים שהם אובייקטים דמויי רשימה .</p>
-
-<p dir="rtl"><strong>צור מערך</strong></p>
-
-<pre class="brush: js notranslate" dir="rtl">var fruits = ["Apple", "Banana"];
-
-console.log(fruits.length);
-// 2
-</pre>
-
-<p dir="rtl"><strong>קבל גישה לאיבר(ע"י האינדקס שלו) במערך</strong></p>
-
-<pre class="brush: js notranslate">var first = fruits[0];
-// Apple
-
-var last = fruits[fruits.length - 1];
-// Banana
-</pre>
-
-<p dir="rtl"><strong>השתמש בלולאה על המערך </strong></p>
-
-<pre class="brush: js notranslate" dir="rtl">fruits.forEach(function (item, index, array) {
-  console.log(item, index);
-});
-// Apple 0
-// Banana 1
-</pre>
-
-<p dir="rtl"><strong>הוסף איבר לסוף המערך</strong></p>
-
-<pre class="brush: js notranslate">var newLength = fruits.push("Orange");
-// ["Apple", "Banana", "Orange"]
-</pre>
-
-<p dir="rtl"><strong>הסר את האיבר האחרון במערך</strong></p>
-
-<pre class="brush: js notranslate">var last = fruits.pop(); // remove Orange (from the end)
-// ["Apple", "Banana"];
-</pre>
-
-<p dir="rtl"><strong>הסר איבר הראשון מערך</strong></p>
-
-<pre class="brush: js notranslate">var first = fruits.shift(); // remove Apple from the front
-// ["Banana"];
-</pre>
-
-<p dir="rtl"><strong>הוסף איבר לראשית המערך</strong></p>
-
-<pre class="brush: js notranslate">var newLength = fruits.unshift("Strawberry") // add to the front
-// ["Strawberry", "Banana"];
-</pre>
-
-<p dir="rtl"><strong>מצא את האינדקס של איבר במערך</strong></p>
-
-<pre class="brush: js notranslate">fruits.push("Mango");
-// ["Strawberry", "Banana", "Mango"]
-
-var pos = fruits.indexOf("Banana");
-// 1
-</pre>
-
-<p dir="rtl"><strong>הסר איבר על ידי האינדקס(מיקום) שלו</strong></p>
-
-<pre class="brush: js notranslate">var removedItem = fruits.splice(pos, 1); // this is how to remove an item
-// ["Strawberry", "Mango"]
-</pre>
-
-<p dir="rtl"><strong>צור עותק של המערך</strong></p>
-
-<pre class="brush: js notranslate">var shallowCopy = fruits.slice(); // this is how to make a copy
-// ["Strawberry", "Mango"]
-</pre>
-
-<h2 id="תחביר">תחביר</h2>
-
-<pre class="syntaxbox notranslate"><code>[<var>element0</var>, <var>element1</var>, ..., <var>elementN</var>]
-new Array(<var>element0</var>, <var>element1</var>[, ...[, <var>elementN</var>]])
-new Array(<var>arrayLength</var>)</code></pre>
-
-<h3 id="פרמטרים">פרמטרים</h3>
-
-<dl>
- <dt><code>element<em>N</em></code></dt>
- <dd>A JavaScript array is initialized with the given elements, except in the case where a single argument is passed to the <code>Array</code> constructor and that argument is a number (see the arrayLength parameter below).Note that this special case only applies to JavaScript arrays created with the <code>Array</code> constructor, not array literals created with the bracket syntax.</dd>
- <dt><code>arrayLength</code></dt>
- <dd>If the only argument passed to the <code>Array</code> constructor is an integer between 0 and 2<sup>32</sup>-1 (inclusive), this returns a new JavaScript array with length set to that number. If the argument is any other number, a {{jsxref("RangeError")}} exception is thrown.</dd>
-</dl>
-
-<h2 id="Description">Description</h2>
-
-<p>Arrays are list-like objects whose prototype has methods to perform traversal and mutation operations. Neither the length of a JavaScript array nor the types of its elements are fixed. Since an array's length can change at any time, and data can be stored at non-contiguous locations in the array, JavaScript arrays are not guaranteed to be dense; this depends on how the programmer chooses to use them. In general, these are convenient characteristics; but if these features are not desirable for your particular use, you might consider using typed arrays.</p>
-
-<p>Some people think that <a class="external" href="http://www.andrewdupont.net/2006/05/18/javascript-associative-arrays-considered-harmful/">you shouldn't use an array as an associative array</a>. In any case, you can use plain {{jsxref("Global_Objects/Object", "objects")}} instead, although doing so comes with its own caveats. See the post <a class="external" href="http://www.less-broken.com/blog/2010/12/lightweight-javascript-dictionaries.html">Lightweight JavaScript dictionaries with arbitrary keys</a> as an example.</p>
-
-<h3 dir="rtl" id="גישה_לאלמנטים_שבמערך">גישה לאלמנטים שבמערך</h3>
-
-<p dir="rtl">מערכים ב - JavaScript מסודרים לפי מספרים מאפס ומעלה: מספרו של האיבר הראשון במערך הוא 0 ומספרו של האיבר האחרון במערך שווה לכמות האיברים במערך (אורכו של המערך - Array.length) פחות 1.</p>
-
-<pre class="brush: js notranslate">var arr = ['this is the first element', 'this is the second element'];
-console.log(arr[0]); // logs 'this is the first element'
-console.log(arr[1]); // logs 'this is the second element'
-console.log(arr[arr.length - 1]); // logs 'this is the second element'
-</pre>
-
-<p>Array elements are object properties in the same way that <code>toString</code> is a property, but trying to access an element of an array as follows throws a syntax error, because the property name is not valid:</p>
-
-<pre class="brush: js notranslate">console.log(arr.0); // a syntax error
-</pre>
-
-<p>There is nothing special about JavaScript arrays and the properties that cause this. JavaScript properties that begin with a digit cannot be referenced with dot notation; and must be accessed using bracket notation. For example, if you had an object with a property named <code>'3d'</code>, it can only be referenced using bracket notation. E.g.:</p>
-
-<pre class="brush: js notranslate">var years = [1950, 1960, 1970, 1980, 1990, 2000, 2010];
-console.log(years.0); // a syntax error
-console.log(years[0]); // works properly
-</pre>
-
-<pre class="brush: js notranslate">renderer.3d.setTexture(model, 'character.png'); // a syntax error
-renderer['3d'].setTexture(model, 'character.png'); // works properly
-</pre>
-
-<p>Note that in the <code>3d</code> example, <code>'3d'</code> had to be quoted. It's possible to quote the JavaScript array indexes as well (e.g., <code>years['2']</code> instead of <code>years[2]</code>), although it's not necessary. The 2 in <code>years[2]</code> is coerced into a string by the JavaScript engine through an implicit <code>toString</code> conversion. It is for this reason that <code>'2'</code> and <code>'02'</code> would refer to two different slots on the <code>years</code> object and the following example could be <code>true</code>:</p>
-
-<pre class="brush: js notranslate">console.log(years['2'] != years['02']);
-</pre>
-
-<p>Similarly, object properties which happen to be reserved words(!) can only be accessed as string literals in bracket notation(but it can be accessed by dot notation in firefox 40.0a2 at least):</p>
-
-<pre class="brush: js notranslate">var promise = {
- 'var' : 'text',
- 'array': [1, 2, 3, 4]
-};
-
-console.log(promise['array']);
-</pre>
-
-<h3 id="Relationship_between_length_and_numerical_properties">Relationship between <code>length</code> and numerical properties</h3>
-
-<p>A JavaScript array's {{jsxref("Array.length", "length")}} property and numerical properties are connected. Several of the built-in array methods (e.g., {{jsxref("Array.join", "join")}}, {{jsxref("Array.slice", "slice")}}, {{jsxref("Array.indexOf", "indexOf")}}, etc.) take into account the value of an array's {{jsxref("Array.length", "length")}} property when they're called. Other methods (e.g., {{jsxref("Array.push", "push")}}, {{jsxref("Array.splice", "splice")}}, etc.) also result in updates to an array's {{jsxref("Array.length", "length")}} property.</p>
-
-<pre class="brush: js notranslate">var fruits = [];
-fruits.push('banana', 'apple', 'peach');
-
-console.log(fruits.length); // 3
-</pre>
-
-<p>When setting a property on a JavaScript array when the property is a valid array index and that index is outside the current bounds of the array, the engine will update the array's {{jsxref("Array.length", "length")}} property accordingly:</p>
-
-<pre class="brush: js notranslate">fruits[5] = 'mango';
-console.log(fruits[5]); // 'mango'
-console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
-console.log(fruits.length); // 6
-</pre>
-
-<p>Increasing the {{jsxref("Array.length", "length")}}.</p>
-
-<pre class="brush: js notranslate">fruits.length = 10;
-console.log(Object.keys(fruits)); // ['0', '1', '2', '5']
-console.log(fruits.length); // 10
-</pre>
-
-<p>Decreasing the {{jsxref("Array.length", "length")}} property does, however, delete elements.</p>
-
-<pre class="brush: js notranslate">fruits.length = 2;
-console.log(Object.keys(fruits)); // ['0', '1']
-console.log(fruits.length); // 2
-</pre>
-
-<p>This is explained further on the {{jsxref("Array.length")}} page.</p>
-
-<h3 id="Creating_an_array_using_the_result_of_a_match">Creating an array using the result of a match</h3>
-
-<p>The result of a match between a regular expression and a string can create a JavaScript array. This array has properties and elements which provide information about the match. Such an array is returned by {{jsxref("RegExp.exec")}}, {{jsxref("String.match")}}, and {{jsxref("String.replace")}}. To help explain these properties and elements, look at the following example and then refer to the table below:</p>
-
-<pre class="brush: js notranslate">// Match one d followed by one or more b's followed by one d
-// Remember matched b's and the following d
-// Ignore case
-
-var myRe = /d(b+)(d)/i;
-var myArray = myRe.exec('cdbBdbsbz');
-</pre>
-
-<p>The properties and elements returned from this match are as follows:</p>
-
-<table class="fullwidth-table">
- <tbody>
- <tr>
- <td class="header">Property/Element</td>
- <td class="header">Description</td>
- <td class="header">Example</td>
- </tr>
- <tr>
- <td><code>input</code></td>
- <td>A read-only property that reflects the original string against which the regular expression was matched.</td>
- <td>cdbBdbsbz</td>
- </tr>
- <tr>
- <td><code>index</code></td>
- <td>A read-only property that is the zero-based index of the match in the string.</td>
- <td>1</td>
- </tr>
- <tr>
- <td><code>[0]</code></td>
- <td>A read-only element that specifies the last matched characters.</td>
- <td>dbBd</td>
- </tr>
- <tr>
- <td><code>[1], ...[n]</code></td>
- <td>Read-only elements that specify the parenthesized substring matches, if included in the regular expression. The number of possible parenthesized substrings is unlimited.</td>
- <td>[1]: bB<br>
- [2]: d</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Properties">Properties</h2>
-
-<dl>
- <dt><code>Array.length</code></dt>
- <dd>The <code>Array</code> constructor's length property whose value is 1.</dd>
- <dt>{{jsxref("Array.@@species", "get Array[@@species]")}}</dt>
- <dd>The constructor function that is used to create derived objects.</dd>
- <dt>{{jsxref("Array.prototype")}}</dt>
- <dd>Allows the addition of properties to all array objects.</dd>
-</dl>
-
-<h2 id="Methods">Methods</h2>
-
-<dl>
- <dt>{{jsxref("Array.from()")}}</dt>
- <dd>Creates a new <code>Array</code> instance from an array-like or iterable object.</dd>
- <dt>{{jsxref("Array.isArray()")}}</dt>
- <dd>Returns true if a variable is an array, if not false.</dd>
- <dt>{{jsxref("Array.of()")}}</dt>
- <dd>Creates a new <code>Array</code> instance with a variable number of arguments, regardless of number or type of the arguments.</dd>
-</dl>
-
-<h2 id="Array_instances"><code>Array</code> instances</h2>
-
-<p>All <code>Array</code> instances inherit from {{jsxref("Array.prototype")}}. The prototype object of the <code>Array</code> constructor can be modified to affect all <code>Array</code> instances.</p>
-
-<h3 id="Properties_2">Properties</h3>
-
-<div>{{page('/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/prototype', 'Properties')}}</div>
-
-<h3 id="Methods_2">Methods</h3>
-
-<h4 id="Mutator_methods">Mutator methods</h4>
-
-<div>{{page('en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/prototype', 'Mutator_methods')}}</div>
-
-<h4 id="Accessor_methods">Accessor methods</h4>
-
-<div>{{page('en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/prototype', 'Accessor_methods')}}</div>
-
-<h4 id="Iteration_methods">Iteration methods</h4>
-
-<div>{{page('en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/prototype', 'Iteration_methods')}}</div>
-
-<h2 id="Array_generic_methods"><code>Array</code> generic methods</h2>
-
-<div class="warning">
-<p><strong>Array generics are non-standard, deprecated and will get removed near future</strong>. Note that you can not rely on them cross-browser. However, there is a <a href="https://github.com/plusdude/array-generics">shim available on GitHub</a>.</p>
-</div>
-
-<p>Sometimes you would like to apply array methods to strings or other array-like objects (such as function {{jsxref("Functions/arguments", "arguments", "", 1)}}). By doing this, you treat a string as an array of characters (or otherwise treat a non-array as an array). For example, in order to check that every character in the variable <var>str</var> is a letter, you would write:</p>
-
-<pre class="brush: js notranslate">function isLetter(character) {
- return character &gt;= 'a' &amp;&amp; character &lt;= 'z';
-}
-
-if (Array.prototype.every.call(str, isLetter)) {
- console.log("The string '" + str + "' contains only letters!");
-}
-</pre>
-
-<p>This notation is rather wasteful and JavaScript 1.6 introduced a generic shorthand:</p>
-
-<pre class="brush: js notranslate">if (Array.every(str, isLetter)) {
- console.log("The string '" + str + "' contains only letters!");
-}
-</pre>
-
-<p>{{jsxref("Global_Objects/String", "Generics", "#String_generic_methods", 1)}} are also available on {{jsxref("String")}}.</p>
-
-<p>These are <strong>not</strong> part of ECMAScript standards (though the ES2015 {{jsxref("Array.from()")}} can be used to achieve this). The following is a shim to allow its use in all browsers:</p>
-
-<pre class="brush: js notranslate">// Assumes Array extras already present (one may use polyfills for these as well)
-(function() {
- 'use strict';
-
- var i,
- // We could also build the array of methods with the following, but the
- // getOwnPropertyNames() method is non-shimable:
- // Object.getOwnPropertyNames(Array).filter(function(methodName) {
- // return typeof Array[methodName] === 'function'
- // });
- methods = [
- 'join', 'reverse', 'sort', 'push', 'pop', 'shift', 'unshift',
- 'splice', 'concat', 'slice', 'indexOf', 'lastIndexOf',
- 'forEach', 'map', 'reduce', 'reduceRight', 'filter',
- 'some', 'every', 'find', 'findIndex', 'entries', 'keys',
-  'values', 'copyWithin', 'includes'
- ],
- methodCount = methods.length,
- assignArrayGeneric = function(methodName) {
- if (!Array[methodName]) {
- var method = Array.prototype[methodName];
- if (typeof method === 'function') {
- Array[methodName] = function() {
- return method.call.apply(method, arguments);
- };
- }
- }
- };
-
- for (i = 0; i &lt; methodCount; i++) {
- assignArrayGeneric(methods[i]);
- }
-}());
-</pre>
-
-<h2 id="דוגמאות">דוגמאות</h2>
-
-<h3 id="Creating_an_array">Creating an array</h3>
-
-<p>The following example creates an array, <code>msgArray</code>, with a length of 0, then assigns values to <code>msgArray[0]</code> and <code>msgArray[99]</code>, changing the length of the array to 100.</p>
-
-<pre class="brush: js notranslate">var msgArray = [];
-msgArray[0] = 'Hello';
-msgArray[99] = 'world';
-
-if (msgArray.length === 100) {
- console.log('The length is 100.');
-}
-</pre>
-
-<h3 id="Creating_a_two-dimensional_array">Creating a two-dimensional array</h3>
-
-<p>The following creates a chess board as a two dimensional array of strings. The first move is made by copying the 'p' in (6,4) to (4,4). The old position (6,4) is made blank.</p>
-
-<pre class="brush: js notranslate">var board = [
- ['R','N','B','Q','K','B','N','R'],
- ['P','P','P','P','P','P','P','P'],
- [' ',' ',' ',' ',' ',' ',' ',' '],
- [' ',' ',' ',' ',' ',' ',' ',' '],
- [' ',' ',' ',' ',' ',' ',' ',' '],
- [' ',' ',' ',' ',' ',' ',' ',' '],
- ['p','p','p','p','p','p','p','p'],
- ['r','n','b','q','k','b','n','r'] ];
-
-console.log(board.join('\n') + '\n\n');
-
-// Move King's Pawn forward 2
-board[4][4] = board[6][4];
-board[6][4] = ' ';
-console.log(board.join('\n'));
-</pre>
-
-<p>Here is the output:</p>
-
-<pre class="eval notranslate">R,N,B,Q,K,B,N,R
-P,P,P,P,P,P,P,P
- , , , , , , ,
- , , , , , , ,
- , , , , , , ,
- , , , , , , ,
-p,p,p,p,p,p,p,p
-r,n,b,q,k,b,n,r
-
-R,N,B,Q,K,B,N,R
-P,P,P,P,P,P,P,P
- , , , , , , ,
- , , , , , , ,
- , , , ,p, , ,
- , , , , , , ,
-p,p,p,p, ,p,p,p
-r,n,b,q,k,b,n,r
-</pre>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('ES1')}}</td>
- <td>{{Spec2('ES1')}}</td>
- <td>Initial definition.</td>
- </tr>
- <tr>
- <td>{{SpecName('ES5.1', '#sec-15.4', 'Array')}}</td>
- <td>{{Spec2('ES5.1')}}</td>
- <td>New methods added: {{jsxref("Array.isArray")}}, {{jsxref("Array.prototype.indexOf", "indexOf")}}, {{jsxref("Array.prototype.lastIndexOf", "lastIndexOf")}}, {{jsxref("Array.prototype.every", "every")}}, {{jsxref("Array.prototype.some", "some")}}, {{jsxref("Array.prototype.forEach", "forEach")}}, {{jsxref("Array.prototype.map", "map")}}, {{jsxref("Array.prototype.filter", "filter")}}, {{jsxref("Array.prototype.reduce", "reduce")}}, {{jsxref("Array.prototype.reduceRight", "reduceRight")}}</td>
- </tr>
- <tr>
- <td>{{SpecName('ES2015', '#sec-array-objects', 'Array')}}</td>
- <td>{{Spec2('ES2015')}}</td>
- <td>New methods added: {{jsxref("Array.from")}}, {{jsxref("Array.of")}}, {{jsxref("Array.prototype.find", "find")}}, {{jsxref("Array.prototype.findIndex", "findIndex")}}, {{jsxref("Array.prototype.fill", "fill")}}, {{jsxref("Array.prototype.copyWithin", "copyWithin")}}</td>
- </tr>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-array-objects', 'Array')}}</td>
- <td>{{Spec2('ESDraft')}}</td>
- <td>New method added: {{jsxref("Array.prototype.includes()")}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-<div>{{CompatibilityTable}}</div>
-
-<div id="compat-desktop">
-<table class="compat-table">
- <tbody>
- <tr>
- <th>Feature</th>
- <th>Chrome</th>
- <th>Firefox (Gecko)</th>
- <th>Internet Explorer</th>
- <th>Opera</th>
- <th>Safari</th>
- </tr>
- <tr>
- <td>Basic support</td>
- <td>{{CompatVersionUnknown}}</td>
- <td>{{CompatVersionUnknown}}</td>
- <td>{{CompatVersionUnknown}}</td>
- <td>{{CompatVersionUnknown}}</td>
- <td>{{CompatVersionUnknown}}</td>
- </tr>
- </tbody>
-</table>
-</div>
-
-<div id="compat-mobile">
-<table class="compat-table">
- <tbody>
- <tr>
- <th>Feature</th>
- <th>Android</th>
- <th>Chrome for Android</th>
- <th>Firefox Mobile (Gecko)</th>
- <th>IE Mobile</th>
- <th>Opera Mobile</th>
- <th>Safari Mobile</th>
- </tr>
- <tr>
- <td>Basic support</td>
- <td>{{CompatVersionUnknown}}</td>
- <td>{{CompatVersionUnknown}}</td>
- <td>{{CompatVersionUnknown}}</td>
- <td>{{CompatVersionUnknown}}</td>
- <td>{{CompatVersionUnknown}}</td>
- <td>{{CompatVersionUnknown}}</td>
- </tr>
- </tbody>
-</table>
-</div>
-
-<h2 id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li><a href="/en-US/docs/Web/JavaScript/Guide/Working_with_Objects#Indexing_object_properties">JavaScript Guide: “Indexing object properties”</a></li>
- <li><a href="/en-US/docs/Web/JavaScript/Guide/Predefined_Core_Objects#Array_Object">JavaScript Guide: “Predefined Core Objects: <code>Array</code> Object”</a></li>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Array_comprehensions">Array comprehensions</a></li>
- <li><a href="https://github.com/plusdude/array-generics">Polyfill for JavaScript 1.8.5 Array Generics and ECMAScript 5 Array Extras</a></li>
- <li><a href="/en-US/docs/JavaScript_typed_arrays">Typed Arrays</a></li>
-</ul>
diff --git a/files/he/web/javascript/reference/global_objects/array/unshift/index.html b/files/he/web/javascript/reference/global_objects/array/unshift/index.html
deleted file mode 100644
index 9febfb5ad4..0000000000
--- a/files/he/web/javascript/reference/global_objects/array/unshift/index.html
+++ /dev/null
@@ -1,94 +0,0 @@
----
-title: Array.prototype.unshift()
-slug: Web/JavaScript/Reference/Global_Objects/Array/unshift
-translation_of: Web/JavaScript/Reference/Global_Objects/Array/unshift
----
-<div dir="rtl">{{JSRef}}</div>
-
-<div dir="rtl">המתודה ()<code><strong>unshift</strong></code>  מוסיפה אלמנט אחד או יותר לתחילת מערך ומחזירה את גודלו החדש של המערך. </div>
-
-<div dir="rtl">{{EmbedInteractiveExample("pages/js/array-unshift.html")}}</div>
-
-<h2 id="Syntax">Syntax</h2>
-
-<pre class="syntaxbox"><var>arr</var>.unshift(<var>element1</var>[, ...[, <var>elementN</var>]])</pre>
-
-<h3 dir="rtl" id="פרמטרים">פרמטרים</h3>
-
-<dl>
- <dt dir="rtl"><code>element<em>N</em></code></dt>
- <dd dir="rtl">אלמנטים להוספה לתחילת המערך.</dd>
-</dl>
-
-<h3 dir="rtl" id="ערך_מוחזר">ערך מוחזר</h3>
-
-<p dir="rtl">את ערך השדה {{jsxref("Array.length", "length")}} החדש של המערך עליו הופעלה המתודה.</p>
-
-<h2 dir="rtl" id="תאור">תאור</h2>
-
-<p dir="rtl">המתודה <code>unshift</code> מכניסה את ערכי האלמנטים שקיבלה כפרמטר לתחילת אובייקט המערך. </p>
-
-<p dir="rtl"><code>unshift</code> is intentionally generic; this method can be {{jsxref("Function.call", "called", "", 1)}} or {{jsxref("Function.apply", "applied", "", 1)}} to objects resembling arrays. Objects which do not contain a <code>length</code> property reflecting the last in a series of consecutive, zero-based numerical properties may not behave in any meaningful manner.</p>
-
-<h2 id="Examples">Examples</h2>
-
-<pre class="brush: js">var arr = [1, 2];
-
-arr.unshift(0); // result of call is 3, the new array length
-// arr is [0, 1, 2]
-
-arr.unshift(-2, -1); // = 5
-// arr is [-2, -1, 0, 1, 2]
-
-arr.unshift([-3]);
-// arr is [[-3], -2, -1, 0, 1, 2]
-</pre>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('ES3')}}</td>
- <td>{{Spec2('ES3')}}</td>
- <td>Initial definition. Implemented in JavaScript 1.2.</td>
- </tr>
- <tr>
- <td>{{SpecName('ES5.1', '#sec-15.4.4.13', 'Array.prototype.unshift')}}</td>
- <td>{{Spec2('ES5.1')}}</td>
- <td> </td>
- </tr>
- <tr>
- <td>{{SpecName('ES6', '#sec-array.prototype.unshift', 'Array.prototype.unshift')}}</td>
- <td>{{Spec2('ES6')}}</td>
- <td> </td>
- </tr>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-array.prototype.unshift', 'Array.prototype.unshift')}}</td>
- <td>{{Spec2('ESDraft')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-<div>
-
-
-<p>{{Compat("javascript.builtins.Array.unshift")}}</p>
-</div>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li>{{jsxref("Array.prototype.push()")}}</li>
- <li>{{jsxref("Array.prototype.pop()")}}</li>
- <li>{{jsxref("Array.prototype.shift()")}}</li>
- <li>{{jsxref("Array.prototype.concat()")}}</li>
-</ul>
diff --git a/files/he/web/javascript/reference/global_objects/index.html b/files/he/web/javascript/reference/global_objects/index.html
deleted file mode 100644
index f215b83a20..0000000000
--- a/files/he/web/javascript/reference/global_objects/index.html
+++ /dev/null
@@ -1,183 +0,0 @@
----
-title: Standard built-in objects
-slug: Web/JavaScript/Reference/Global_Objects
-tags:
- - JavaScript
- - Objects
- - אובייקטים
- - סקריפט
- - פונקציות
-translation_of: Web/JavaScript/Reference/Global_Objects
----
-<div>{{jsSidebar("Objects")}}</div>
-
-<p>This chapter documents all of JavaScript's standard, built-in objects, including their methods and properties.</p>
-
-<div class="onlyinclude">
-<p>The term "global objects" (or standard built-in objects) here is not to be confused with the <strong>global object</strong>. Here, global objects refer to <strong>objects in the global scope</strong> (but only if ECMAScript 5 strict mode is not used; in that case it returns {{jsxref("undefined")}}). The <strong>global object</strong> itself can be accessed using the {{jsxref("Operators/this", "this")}} operator in the global scope. In fact, the global scope <strong>consists of</strong> the properties of the global object, including inherited properties, if any.</p>
-
-<p>Other objects in the global scope are either <a href="/en-US/docs/Web/JavaScript/Guide/Working_with_Objects#Creating_new_objects">created by the user script</a> or provided by the host application. The host objects available in browser contexts are documented in the <a href="/en-US/docs/Web/API/Reference">API reference</a>. For more information about the distinction between the <a href="/en-US/docs/DOM/DOM_Reference">DOM</a> and core <a href="/en-US/docs/Web/JavaScript">JavaScript</a>, see <a href="/en-US/docs/Web/JavaScript/JavaScript_technologies_overview">JavaScript technologies overview</a>.</p>
-
-<h2 id="Standard_objects_by_category">Standard objects by category</h2>
-
-<h3 id="Value_properties">Value properties</h3>
-
-<p>These global properties return a simple value; they have no properties or methods.</p>
-
-<ul>
- <li>{{jsxref("Infinity")}}</li>
- <li>{{jsxref("NaN")}}</li>
- <li>{{jsxref("undefined")}}</li>
- <li>{{jsxref("null")}} literal</li>
-</ul>
-
-<h3 id="Function_properties">Function properties</h3>
-
-<p>These global functions—functions which are called globally rather than on an object—directly return their results to the caller.</p>
-
-<ul>
- <li>{{jsxref("Global_Objects/eval", "eval()")}}</li>
- <li>{{jsxref("Global_Objects/uneval", "uneval()")}} {{non-standard_inline}}</li>
- <li>{{jsxref("Global_Objects/isFinite", "isFinite()")}}</li>
- <li>{{jsxref("Global_Objects/isNaN", "isNaN()")}}</li>
- <li>{{jsxref("Global_Objects/parseFloat", "parseFloat()")}}</li>
- <li>{{jsxref("Global_Objects/parseInt", "parseInt()")}}</li>
- <li>{{jsxref("Global_Objects/decodeURI", "decodeURI()")}}</li>
- <li>{{jsxref("Global_Objects/decodeURIComponent", "decodeURIComponent()")}}</li>
- <li>{{jsxref("Global_Objects/encodeURI", "encodeURI()")}}</li>
- <li>{{jsxref("Global_Objects/encodeURIComponent", "encodeURIComponent()")}}</li>
- <li>{{jsxref("Global_Objects/escape", "escape()")}} {{deprecated_inline}}</li>
- <li>{{jsxref("Global_Objects/unescape", "unescape()")}} {{deprecated_inline}}</li>
-</ul>
-
-<h3 id="Fundamental_objects">Fundamental objects</h3>
-
-<p>These are the fundamental, basic objects upon which all other objects are based. This includes objects that represent general objects, functions, and errors.</p>
-
-<ul>
- <li>{{jsxref("Object")}}</li>
- <li>{{jsxref("Function")}}</li>
- <li>{{jsxref("Boolean")}}</li>
- <li>{{jsxref("Symbol")}} {{experimental_inline}}</li>
- <li>{{jsxref("Error")}}</li>
- <li>{{jsxref("EvalError")}}</li>
- <li>{{jsxref("InternalError")}}</li>
- <li>{{jsxref("RangeError")}}</li>
- <li>{{jsxref("ReferenceError")}}</li>
- <li>{{jsxref("SyntaxError")}}</li>
- <li>{{jsxref("TypeError")}}</li>
- <li>{{jsxref("URIError")}}</li>
-</ul>
-
-<h3 id="Numbers_and_dates">Numbers and dates</h3>
-
-<p>These are the base objects representing numbers, dates, and mathematical calculations.</p>
-
-<ul>
- <li>{{jsxref("Number")}}</li>
- <li>{{jsxref("Math")}}</li>
- <li>{{jsxref("Date")}}</li>
-</ul>
-
-<h3 id="Text_processing">Text processing</h3>
-
-<p>These objects represent strings and support manipulating them.</p>
-
-<ul>
- <li>{{jsxref("String")}}</li>
- <li>{{jsxref("RegExp")}}</li>
-</ul>
-
-<h3 id="Indexed_collections">Indexed collections</h3>
-
-<p>These objects represent collections of data which are ordered by an index value. This includes (typed) arrays and array-like constructs.</p>
-
-<ul>
- <li>{{jsxref("Array")}}</li>
- <li>{{jsxref("Int8Array")}}</li>
- <li>{{jsxref("Uint8Array")}}</li>
- <li>{{jsxref("Uint8ClampedArray")}}</li>
- <li>{{jsxref("Int16Array")}}</li>
- <li>{{jsxref("Uint16Array")}}</li>
- <li>{{jsxref("Int32Array")}}</li>
- <li>{{jsxref("Uint32Array")}}</li>
- <li>{{jsxref("Float32Array")}}</li>
- <li>{{jsxref("Float64Array")}}</li>
-</ul>
-
-<h3 id="Keyed_collections">Keyed collections</h3>
-
-<p>These objects represent collections which use keys; these contain elements which are iterable in the order of insertion.</p>
-
-<ul>
- <li>{{jsxref("Map")}} {{experimental_inline}}</li>
- <li>{{jsxref("Set")}} {{experimental_inline}}</li>
- <li>{{jsxref("WeakMap")}} {{experimental_inline}}</li>
- <li>{{jsxref("WeakSet")}} {{experimental_inline}}</li>
-</ul>
-
-<h3 id="Vector_collections">Vector collections</h3>
-
-<p>{{Glossary("SIMD")}} vector data types are objects where data is arranged into lanes.</p>
-
-<ul>
- <li>{{jsxref("SIMD")}} {{experimental_inline}}</li>
- <li>{{jsxref("Float32x4", "SIMD.Float32x4")}} {{experimental_inline}}</li>
- <li>{{jsxref("Float64x2", "SIMD.Float64x2")}} {{experimental_inline}}</li>
- <li>{{jsxref("Int8x16", "SIMD.Int8x16")}} {{experimental_inline}}</li>
- <li>{{jsxref("Int16x8", "SIMD.Int16x8")}} {{experimental_inline}}</li>
- <li>{{jsxref("Int32x4", "SIMD.Int32x4")}} {{experimental_inline}}</li>
-</ul>
-
-<h3 id="Structured_data">Structured data</h3>
-
-<p>These objects represent and interact with structured data buffers and data coded using JavaScript Object Notation (JSON).</p>
-
-<ul>
- <li>{{jsxref("ArrayBuffer")}}</li>
- <li>{{jsxref("DataView")}}</li>
- <li>{{jsxref("JSON")}}</li>
-</ul>
-
-<h3 id="Control_abstraction_objects">Control abstraction objects</h3>
-
-<ul>
- <li>{{jsxref("Promise")}} {{experimental_inline}}</li>
- <li>{{jsxref("Generator")}} {{experimental_inline}}</li>
- <li>{{jsxref("GeneratorFunction")}} {{experimental_inline}}</li>
-</ul>
-
-<h3 id="Reflection">Reflection</h3>
-
-<ul>
- <li>{{jsxref("Reflect")}} {{experimental_inline}}</li>
- <li>{{jsxref("Proxy")}} {{experimental_inline}}</li>
-</ul>
-
-<h3 id="Internationalization">Internationalization</h3>
-
-<p>Additions to the ECMAScript core for language-sensitive functionalities.</p>
-
-<ul>
- <li>{{jsxref("Intl")}}</li>
- <li>{{jsxref("Global_Objects/Collator", "Intl.Collator")}}</li>
- <li>{{jsxref("Global_Objects/DateTimeFormat", "Intl.DateTimeFormat")}}</li>
- <li>{{jsxref("Global_Objects/NumberFormat", "Intl.NumberFormat")}}</li>
-</ul>
-
-<h3 id="Non-standard_objects">Non-standard objects</h3>
-
-<ul>
- <li>{{jsxref("Iterator")}} {{non-standard_inline}}</li>
- <li>{{jsxref("ParallelArray")}} {{non-standard_inline}}</li>
- <li>{{jsxref("StopIteration")}} {{non-standard_inline}}</li>
-</ul>
-
-<h3 id="Other">Other</h3>
-
-<ul>
- <li><code><a href="/en-US/docs/Web/JavaScript/Reference/Functions/arguments">arguments</a></code></li>
-</ul>
-</div>
-
-<p> </p>
diff --git a/files/he/web/javascript/reference/global_objects/object/assign/index.html b/files/he/web/javascript/reference/global_objects/object/assign/index.html
deleted file mode 100644
index 26e424598a..0000000000
--- a/files/he/web/javascript/reference/global_objects/object/assign/index.html
+++ /dev/null
@@ -1,272 +0,0 @@
----
-title: Object.assign()
-slug: Web/JavaScript/Reference/Global_Objects/Object/assign
-translation_of: Web/JavaScript/Reference/Global_Objects/Object/assign
----
-<p>{{JSRef}}</p>
-
-<p dir="rtl">מתודת <span class="seoSummary"><strong><code>Object.assign</code> מעתיקה אובייקט על שלל </strong>{{jsxref("Object/propertyIsEnumerable", "מאפייניו", "", "1")}} {{jsxref("Object/hasOwnProperty", "הקיימים", "", "1")}} לאובייקט אחר וממזגת אותם ביחד. המתודה מחזירה את האובייקט שאליו העתקנו את התכונות החדשות. </span></p>
-
-<div dir="rtl">תחביר</div>
-
-<pre class="syntaxbox notranslate">Object.assign(<var>target</var>, ...<var>sources</var>)</pre>
-
-<h3 dir="rtl" id="פרמטרים">פרמטרים</h3>
-
-<dl>
- <dt dir="rtl"><code><var>target - אובייקט היעד</var></code></dt>
- <dd dir="rtl">אובייקט היעד- האובייקט שאליו אנחנו מעתיקים את כל המאפיינים של האובייקט המקורי, כאשר הוא מחזיר את האובייקט אחרי המיזוג.</dd>
- <dt dir="rtl"><code><var>sources - אובייקט המקור</var></code></dt>
- <dd></dd>
-</dl>
-
-<dl>
- <dd dir="rtl">אובייקט המקור - האובייקט מכיל את המאפיינים שאנחנו רוצים להעתיק לאובייקט נוסף. </dd>
-</dl>
-
-<h3 dir="rtl" id="Return_value_-_הנתון_התוצאה">Return value - הנתון התוצאה</h3>
-
-<p dir="rtl">The target object - האובייקט שאליו העתקנו את התכונות של האובייקט המקורי.</p>
-
-<h2 dir="rtl" id="תיאור">תיאור</h2>
-
-<p dir="rtl">מאפיינים באובייקט היעד ישוכתבו או ידרסו ע"י המאפיינים של אובייקט המקור אם הם חולקים את אותו ה-{{jsxref("Object/keys", "key", "", 1)}}. מאפיינים חדשים שיוגדו על מאפיינים משותפים (properties) בהמשך ידרסו גם באובייקט היעד וגם באופייקט המקור.</p>
-
-<p dir="rtl"></p>
-
-<p>The <code>Object.assign()</code> method only copies <em>enumerable</em> and <em>own</em> properties from a source object to a target object. It uses <code>[[Get]]</code> on the source and <code>[[Set]]</code> on the target, so it will invoke <a href="/en-US/docs/Web/JavaScript/Reference/Functions/get">getters</a> and <a href="/en-US/docs/Web/JavaScript/Reference/Functions/set">setters</a>. Therefore it <em>assigns</em> properties, versus copying or defining new properties. This may make it unsuitable for merging new properties into a prototype if the merge sources contain getters.</p>
-
-<p>For copying property definitions (including their enumerability) into prototypes, use {{jsxref("Object.getOwnPropertyDescriptor()")}} and {{jsxref("Object.defineProperty()")}} instead.</p>
-
-<p>Both {{jsxref("String")}} and {{jsxref("Symbol")}} properties are copied.</p>
-
-<p>In case of an error, for example if a property is non-writable, a {{jsxref("TypeError")}} is raised, and the <code><var>target</var></code> object is changed if any properties are added before the error is raised.</p>
-
-<div class="blockIndicator note">
-<p><strong>Note:</strong> <code>Object.assign()</code> does not throw on {{jsxref("null")}} or {{jsxref("undefined")}} sources.</p>
-</div>
-
-<h2 id="Polyfill">Polyfill</h2>
-
-<p>This <a href="/en-US/docs/Glossary/Polyfill">polyfill</a> doesn't support symbol properties, since ES5 doesn't have symbols anyway:</p>
-
-<pre class="brush: js notranslate">if (typeof Object.assign !== 'function') {
- // Must be writable: true, enumerable: false, configurable: true
- Object.defineProperty(Object, "assign", {
- value: function assign(target, varArgs) { // .length of function is 2
- 'use strict';
- if (target === null || target === undefined) {
- throw new TypeError('Cannot convert undefined or null to object');
- }
-
- var to = Object(target);
-
- for (var index = 1; index &lt; arguments.length; index++) {
- var nextSource = arguments[index];
-
- if (nextSource !== null &amp;&amp; nextSource !== undefined) {
- for (var nextKey in nextSource) {
- // Avoid bugs when hasOwnProperty is shadowed
- if (Object.prototype.hasOwnProperty.call(nextSource, nextKey)) {
- to[nextKey] = nextSource[nextKey];
- }
- }
- }
- }
- return to;
- },
- writable: true,
- configurable: true
- });
-}
-</pre>
-
-<h2 id="Examples">Examples</h2>
-
-<h3 id="Cloning_an_object">Cloning an object</h3>
-
-<pre class="brush: js notranslate">const obj = { a: 1 };
-const copy = Object.assign({}, obj);
-console.log(copy); // { a: 1 }
-</pre>
-
-<h3 id="Deep_Clone" name="Deep_Clone">Warning for Deep Clone</h3>
-
-<p>For deep cloning, we need to use alternatives, because <code>Object.assign()</code> copies property values.</p>
-
-<p>If the source value is a reference to an object, it only copies the reference value.</p>
-
-<pre class="brush: js notranslate">function test() {
- 'use strict';
-
- let obj1 = { a: 0 , b: { c: 0}};
- let obj2 = Object.assign({}, obj1);
- console.log(JSON.stringify(obj2)); // { "a": 0, "b": { "c": 0}}
-
- obj1.a = 1;
- console.log(JSON.stringify(obj1)); // { "a": 1, "b": { "c": 0}}
- console.log(JSON.stringify(obj2)); // { "a": 0, "b": { "c": 0}}
-
- obj2.a = 2;
- console.log(JSON.stringify(obj1)); // { "a": 1, "b": { "c": 0}}
- console.log(JSON.stringify(obj2)); // { "a": 2, "b": { "c": 0}}
-
- obj2.b.c = 3;
- console.log(JSON.stringify(obj1)); // { "a": 1, "b": { "c": 3}}
- console.log(JSON.stringify(obj2)); // { "a": 2, "b": { "c": 3}}
-
- // Deep Clone
- obj1 = { a: 0 , b: { c: 0}};
- let obj3 = JSON.parse(JSON.stringify(obj1));
- obj1.a = 4;
- obj1.b.c = 4;
- console.log(JSON.stringify(obj3)); // { "a": 0, "b": { "c": 0}}
-}
-
-test();</pre>
-
-<h3 id="Merging_objects">Merging objects</h3>
-
-<pre class="brush: js notranslate">const o1 = { a: 1 };
-const o2 = { b: 2 };
-const o3 = { c: 3 };
-
-const obj = Object.assign(o1, o2, o3);
-console.log(obj); // { a: 1, b: 2, c: 3 }
-console.log(o1); // { a: 1, b: 2, c: 3 }, target object itself is changed.</pre>
-
-<h3 id="Merging_objects_with_same_properties">Merging objects with same properties</h3>
-
-<pre class="brush: js notranslate">const o1 = { a: 1, b: 1, c: 1 };
-const o2 = { b: 2, c: 2 };
-const o3 = { c: 3 };
-
-const obj = Object.assign({}, o1, o2, o3);
-console.log(obj); // { a: 1, b: 2, c: 3 }</pre>
-
-<p>The properties are overwritten by other objects that have the same properties later in the parameters order.</p>
-
-<h3 id="Copying_symbol-typed_properties">Copying symbol-typed properties</h3>
-
-<pre class="brush: js notranslate">const o1 = { a: 1 };
-const o2 = { [Symbol('foo')]: 2 };
-
-const obj = Object.assign({}, o1, o2);
-console.log(obj); // { a : 1, [Symbol("foo")]: 2 } (cf. bug 1207182 on Firefox)
-Object.getOwnPropertySymbols(obj); // [Symbol(foo)]
-</pre>
-
-<h3 id="Properties_on_the_prototype_chain_and_non-enumerable_properties_cannot_be_copied">Properties on the prototype chain and non-enumerable properties cannot be copied</h3>
-
-<pre class="brush: js notranslate">const obj = Object.create({ foo: 1 }, { // foo is on obj's prototype chain.
- bar: {
- value: 2 // bar is a non-enumerable property.
- },
- baz: {
- value: 3,
- enumerable: true // baz is an own enumerable property.
- }
-});
-
-const copy = Object.assign({}, obj);
-console.log(copy); // { baz: 3 }
-</pre>
-
-<h3 id="Primitives_will_be_wrapped_to_objects">Primitives will be wrapped to objects</h3>
-
-<pre class="brush: js notranslate">const v1 = 'abc';
-const v2 = true;
-const v3 = 10;
-const v4 = Symbol('foo');
-
-const obj = Object.assign({}, v1, null, v2, undefined, v3, v4);
-// Primitives will be wrapped, null and undefined will be ignored.
-// Note, only string wrappers can have own enumerable properties.
-console.log(obj); // { "0": "a", "1": "b", "2": "c" }
-</pre>
-
-<h3 id="Exceptions_will_interrupt_the_ongoing_copying_task">Exceptions will interrupt the ongoing copying task</h3>
-
-<pre class="brush: js notranslate">const target = Object.defineProperty({}, 'foo', {
- value: 1,
- writable: false
-}); // target.foo is a read-only property
-
-Object.assign(target, { bar: 2 }, { foo2: 3, foo: 3, foo3: 3 }, { baz: 4 });
-// TypeError: "foo" is read-only
-// The Exception is thrown when assigning target.foo
-
-console.log(target.bar); // 2, the first source was copied successfully.
-console.log(target.foo2); // 3, the first property of the second source was copied successfully.
-console.log(target.foo); // 1, exception is thrown here.
-console.log(target.foo3); // undefined, assign method has finished, foo3 will not be copied.
-console.log(target.baz); // undefined, the third source will not be copied either.
-</pre>
-
-<h3 id="Copying_accessors">Copying accessors</h3>
-
-<pre class="brush: js notranslate">const obj = {
- foo: 1,
- get bar() {
- return 2;
- }
-};
-
-let copy = Object.assign({}, obj);
-console.log(copy);
-// { foo: 1, bar: 2 }
-// The value of copy.bar is obj.bar's getter's return value.
-
-// This is an assign function that copies full descriptors
-function completeAssign(target, ...sources) {
- sources.forEach(source =&gt; {
- let descriptors = Object.keys(source).reduce((descriptors, key) =&gt; {
- descriptors[key] = Object.getOwnPropertyDescriptor(source, key);
- return descriptors;
- }, {});
-
-  // By default, Object.assign copies enumerable Symbols, too
- Object.getOwnPropertySymbols(source).forEach(sym =&gt; {
- let descriptor = Object.getOwnPropertyDescriptor(source, sym);
- if (descriptor.enumerable) {
- descriptors[sym] = descriptor;
- }
- });
- Object.defineProperties(target, descriptors);
- });
- return target;
-}
-
-copy = completeAssign({}, obj);
-console.log(copy);
-// { foo:1, get bar() { return 2 } }
-</pre>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">Specification</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-object.assign', 'Object.assign')}}</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-
-
-<p>{{Compat("javascript.builtins.Object.assign")}}</p>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li>{{jsxref("Object.defineProperties()")}}</li>
- <li><a href="/en-US/docs/Web/JavaScript/Enumerability_and_ownership_of_properties">Enumerability and ownership of properties</a></li>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Spread_syntax#Spread_in_object_literals">Spread in object literals</a></li>
-</ul>
diff --git a/files/he/web/javascript/reference/global_objects/object/index.html b/files/he/web/javascript/reference/global_objects/object/index.html
deleted file mode 100644
index 9feed92ddc..0000000000
--- a/files/he/web/javascript/reference/global_objects/object/index.html
+++ /dev/null
@@ -1,184 +0,0 @@
----
-title: Object
-slug: Web/JavaScript/Reference/Global_Objects/Object
-tags:
- - Constructor
- - JavaScript
- - NeedsTranslation
- - Object
- - TopicStub
-translation_of: Web/JavaScript/Reference/Global_Objects/Object
----
-<div>{{JSRef}}</div>
-
-<p>The <code><strong>Object</strong></code> constructor creates an object wrapper.</p>
-
-<h2 id="Syntax">Syntax</h2>
-
-<pre class="syntaxbox">// Object initialiser or literal
-{ [ <var>nameValuePair1</var>[, <var>nameValuePair2</var>[, ...<var>nameValuePairN</var>] ] ] }
-
-// Called as a constructor
-new Object([<var>value</var>])</pre>
-
-<h3 id="Parameters">Parameters</h3>
-
-<dl>
- <dt><code>nameValuePair1, nameValuePair2, ... nameValuePair<em>N</em></code></dt>
- <dd>Pairs of names (strings) and values (any value) where the name is separated from the value by a colon.</dd>
- <dt><code>value</code></dt>
- <dd>Any value.</dd>
-</dl>
-
-<h2 id="Description">Description</h2>
-
-<p>The <code>Object</code> constructor creates an object wrapper for the given value. If the value is {{jsxref("null")}} or {{jsxref("undefined")}}, it will create and return an empty object, otherwise, it will return an object of a Type that corresponds to the given value. If the value is an object already, it will return the value.</p>
-
-<p>When called in a non-constructor context, <code>Object</code> behaves identically to <code>new Object()</code>.</p>
-
-<p>See also the <a href="/en-US/docs/Web/JavaScript/Reference/Operators/Object_initializer">object initializer / literal syntax</a>.</p>
-
-<h2 id="Properties_of_the_Object_constructor">Properties of the <code>Object</code> constructor</h2>
-
-<dl>
- <dt><code>Object.length</code></dt>
- <dd>Has a value of 1.</dd>
- <dt>{{jsxref("Object.prototype")}}</dt>
- <dd>Allows the addition of properties to all objects of type Object.</dd>
-</dl>
-
-<h2 id="Methods_of_the_Object_constructor">Methods of the <code>Object</code> constructor</h2>
-
-<dl>
- <dt>{{jsxref("Object.assign()")}}</dt>
- <dd>Copies the values of all enumerable own properties from one or more source objects to a target object.</dd>
- <dt>{{jsxref("Object.create()")}}</dt>
- <dd>Creates a new object with the specified prototype object and properties.</dd>
- <dt>{{jsxref("Object.defineProperty()")}}</dt>
- <dd>Adds the named property described by a given descriptor to an object.</dd>
- <dt>{{jsxref("Object.defineProperties()")}}</dt>
- <dd>Adds the named properties described by the given descriptors to an object.</dd>
- <dt>{{jsxref("Object.entries()")}}</dt>
- <dd>Returns an array containing all of the <code>[key, value]</code> pairs of a given object's <strong>own</strong> enumerable string properties.</dd>
- <dt>{{jsxref("Object.freeze()")}}</dt>
- <dd>Freezes an object: other code can't delete or change any properties.</dd>
- <dt>{{jsxref("Object.fromEntries()")}}</dt>
- <dd>Returns a new object from an iterable of key-value pairs (reverses {{jsxref("Object.entries")}}).</dd>
- <dt>{{jsxref("Object.getOwnPropertyDescriptor()")}}</dt>
- <dd>Returns a property descriptor for a named property on an object.</dd>
- <dt>{{jsxref("Object.getOwnPropertyDescriptors()")}}</dt>
- <dd>Returns an object containing all own property descriptors for an object.</dd>
- <dt>{{jsxref("Object.getOwnPropertyNames()")}}</dt>
- <dd>Returns an array containing the names of all of the given object's <strong>own</strong> enumerable and non-enumerable properties.</dd>
- <dt>{{jsxref("Object.getOwnPropertySymbols()")}}</dt>
- <dd>Returns an array of all symbol properties found directly upon a given object.</dd>
- <dt>{{jsxref("Object.getPrototypeOf()")}}</dt>
- <dd>Returns the prototype of the specified object.</dd>
- <dt>{{jsxref("Object.is()")}}</dt>
- <dd>Compares if two values are the same value. Equates all NaN values (which differs from both Abstract Equality Comparison and Strict Equality Comparison).</dd>
- <dt>{{jsxref("Object.isExtensible()")}}</dt>
- <dd>Determines if extending of an object is allowed.</dd>
- <dt>{{jsxref("Object.isFrozen()")}}</dt>
- <dd>Determines if an object was frozen.</dd>
- <dt>{{jsxref("Object.isSealed()")}}</dt>
- <dd>Determines if an object is sealed.</dd>
- <dt>{{jsxref("Object.keys()")}}</dt>
- <dd>Returns an array containing the names of all of the given object's <strong>own</strong> enumerable string properties.</dd>
- <dt>{{jsxref("Object.preventExtensions()")}}</dt>
- <dd>Prevents any extensions of an object.</dd>
- <dt>{{jsxref("Object.seal()")}}</dt>
- <dd>Prevents other code from deleting properties of an object.</dd>
- <dt>{{jsxref("Object.setPrototypeOf()")}}</dt>
- <dd>Sets the prototype (i.e., the internal <code>[[Prototype]]</code> property).</dd>
- <dt>{{jsxref("Object.values()")}}</dt>
- <dd>Returns an array containing the values that correspond to all of a given object's <strong>own</strong> enumerable string properties.</dd>
-</dl>
-
-<h2 id="Object_instances_and_Object_prototype_object"><code>Object</code> instances and <code>Object</code> prototype object</h2>
-
-<p>All objects in JavaScript are descended from <code>Object</code>; all objects inherit methods and properties from {{jsxref("Object.prototype")}}, although they may be overridden. For example, other constructors' prototypes override the <code>constructor</code> property and provide their own <code>toString()</code> methods. Changes to the <code>Object</code> prototype object are propagated to all objects unless the properties and methods subject to those changes are overridden further along the prototype chain.</p>
-
-<h3 id="Properties">Properties</h3>
-
-<div>{{page('/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/prototype', 'Properties') }}</div>
-
-<h3 id="Methods">Methods</h3>
-
-<div>{{page('/en-US/docs/Web/JavaScript/Reference/Global_Objects/Object/prototype', 'Methods') }}</div>
-
-<h2 id="Deleting_a_property_from_an_object">Deleting a property from an object</h2>
-
-<p>There isn't any method in an Object itself to delete its own properties (e.g. like <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/delete">Map.prototype.delete()</a></code>). To do so one has to use the <a href="/en-US/docs/Web/JavaScript/Reference/Operators/delete">delete operator</a>.</p>
-
-<h2 id="Examples">Examples</h2>
-
-<h3 id="Using_Object_given_undefined_and_null_types">Using <code>Object</code> given <code>undefined</code> and <code>null</code> types</h3>
-
-<p>The following examples store an empty <code>Object</code> object in <code>o</code>:</p>
-
-<pre class="brush: js">var o = new Object();
-</pre>
-
-<pre class="brush: js">var o = new Object(undefined);
-</pre>
-
-<pre class="brush: js">var o = new Object(null);
-</pre>
-
-<h3 id="Using_Object_to_create_Boolean_objects">Using <code>Object</code> to create <code>Boolean</code> objects</h3>
-
-<p>The following examples store {{jsxref("Boolean")}} objects in <code>o</code>:</p>
-
-<pre class="brush: js">// equivalent to o = new Boolean(true);
-var o = new Object(true);
-</pre>
-
-<pre class="brush: js">// equivalent to o = new Boolean(false);
-var o = new Object(Boolean());
-</pre>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('ES1')}}</td>
- <td>{{Spec2('ES1')}}</td>
- <td>Initial definition. Implemented in JavaScript 1.0.</td>
- </tr>
- <tr>
- <td>{{SpecName('ES5.1', '#sec-15.2', 'Object')}}</td>
- <td>{{Spec2('ES5.1')}}</td>
- <td> </td>
- </tr>
- <tr>
- <td>{{SpecName('ES6', '#sec-object-objects', 'Object')}}</td>
- <td>{{Spec2('ES6')}}</td>
- <td>Added Object.assign, Object.getOwnPropertySymbols, Object.setPrototypeOf, Object.is</td>
- </tr>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-object-objects', 'Object')}}</td>
- <td>{{Spec2('ESDraft')}}</td>
- <td>Added Object.entries, Object.values and Object.getOwnPropertyDescriptors.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-<div>
-
-
-<p>{{Compat("javascript.builtins.Object")}}</p>
-</div>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Object_initializer">Object initializer</a></li>
-</ul>
diff --git a/files/he/web/javascript/reference/global_objects/promise/index.html b/files/he/web/javascript/reference/global_objects/promise/index.html
deleted file mode 100644
index 1f1c71827c..0000000000
--- a/files/he/web/javascript/reference/global_objects/promise/index.html
+++ /dev/null
@@ -1,244 +0,0 @@
----
-title: Promise
-slug: Web/JavaScript/Reference/Global_Objects/Promise
-translation_of: Web/JavaScript/Reference/Global_Objects/Promise
----
-<div>{{JSRef}}</div>
-
-<p>The <strong><code>Promise</code></strong> object represents the eventual completion (or failure) of an asynchronous operation, and its resulting value.</p>
-
-<div class="note">
-<p><strong>Note:</strong> This article describes the <code>Promise</code> constructor and the methods and properties of such objects. To learn about the way promises work and how you can use them, we advise you to read <a href="/en-US/docs/Web/JavaScript/Guide/Using_promises">Using promises</a> first. The constructor is primarily used to wrap functions that do not already support promises.</p>
-</div>
-
-<div>{{EmbedInteractiveExample("pages/js/promise-constructor.html")}}</div>
-
-<p class="hidden">The source for this interactive demo is stored in a GitHub repository. If you'd like to contribute to the interactive demo project, please clone <a href="https://github.com/mdn/interactive-examples">https://github.com/mdn/interactive-examples</a> and send us a pull request.</p>
-
-<h2 id="תחביר">תחביר</h2>
-
-<pre class="brush: js">new Promise( /* executor */ function(resolve, reject) { ... } );</pre>
-
-<h3 id="פרמטרים">פרמטרים</h3>
-
-<dl>
- <dt>executor</dt>
- <dd>A function that is passed with the arguments <code>resolve</code> and <code>reject</code>. The <code>executor</code> function is executed immediately by the Promise implementation, passing <code>resolve</code> and <code>reject</code> functions (the executor is called before the <code>Promise</code> constructor even returns the created object). The <code>resolve</code> and <code>reject</code> functions, when called, resolve or reject the promise, respectively. The executor normally initiates some asynchronous work, and then, once that completes, either calls the <code>resolve</code> function to resolve the promise or else rejects it if an error occurred. If an error is thrown in the executor function, the promise is rejected. The return value of the executor is ignored.</dd>
-</dl>
-
-<h2 id="תיאור">תיאור</h2>
-
-<p>A <code><strong>Promise</strong></code> is a proxy for a value not necessarily known when the promise is created. It allows you to associate handlers with an asynchronous action's eventual success value or failure reason. This lets asynchronous methods return values like synchronous methods: instead of immediately returning the final value, the asynchronous method returns a <em>promise</em> to supply the value at some point in the future.</p>
-
-<p>A <code>Promise</code> is in one of these states:</p>
-
-<ul>
- <li><em>pending</em>: initial state, neither fulfilled nor rejected.</li>
- <li><em>fulfilled</em>: meaning that the operation completed successfully.</li>
- <li><em>rejected</em>: meaning that the operation failed.</li>
-</ul>
-
-<p>A pending promise can either be <em>fulfilled</em> with a value, or <em>rejected</em> with a reason (error). When either of these options happens, the associated handlers queued up by a promise's <code>then</code> method are called. (If the promise has already been fulfilled or rejected when a corresponding handler is attached, the handler will be called, so there is no race condition between an asynchronous operation completing and its handlers being attached.)</p>
-
-<p>As the <code>{{jsxref("Promise.then", "Promise.prototype.then()")}}</code> and <code>{{jsxref("Promise.catch", "Promise.prototype.catch()")}}</code> methods return promises, they can be chained.</p>
-
-<p><img alt="" src="https://mdn.mozillademos.org/files/15911/promises.png" style="height: 297px; width: 801px;"></p>
-
-<div class="note">
-<p><strong>Not to be confused with:</strong> Several other languages have mechanisms for lazy evaluation and deferring a computation, which they also call "promises", e.g. Scheme. Promises in JavaScript represent processes which are already happening, which can be chained with callback functions. If you are looking to lazily evaluate an expression, consider the <a href="/en-US/docs/Web/JavaScript/Reference/Functions/Arrow_functions">arrow function</a> with no arguments: <code>f = () =&gt; <em>expression</em></code> to create the lazily-evaluated expression, and <code>f()</code> to evaluate.</p>
-</div>
-
-<div class="note">
-<p><strong>Note</strong>: A promise is said to be <em>settled</em> if it is either fulfilled or rejected, but not pending. You will also hear the term <em>resolved</em> used with promises — this means that the promise is settled or “locked in” to match the state of another promise. <a href="https://github.com/domenic/promises-unwrapping/blob/master/docs/states-and-fates.md">States and fates</a> contains more details about promise terminology.</p>
-</div>
-
-<h2 id="מאפיינים">מאפיינים</h2>
-
-<dl>
- <dt><code>Promise.length</code></dt>
- <dd>Length property whose value is always 1 (number of constructor arguments).</dd>
- <dt>{{jsxref("Promise.prototype")}}</dt>
- <dd>Represents the prototype for the <code>Promise</code> constructor.</dd>
-</dl>
-
-<h2 id="Methods">Methods</h2>
-
-<dl>
- <dt>{{jsxref("Promise.all", "Promise.all(iterable)")}}</dt>
- <dd>Returns a promise that either fulfills when all of the promises in the iterable argument have fulfilled or rejects as soon as one of the promises in the iterable argument rejects. If the returned promise fulfills, it is fulfilled with an array of the values from the fulfilled promises in the same order as defined in the iterable. If the returned promise rejects, it is rejected with the reason from the first promise in the iterable that rejected. This method can be useful for aggregating results of multiple promises.</dd>
- <dt>{{jsxref("Promise.race", "Promise.race(iterable)")}}</dt>
- <dd>Returns a promise that fulfills or rejects as soon as one of the promises in the iterable fulfills or rejects, with the value or reason from that promise.</dd>
- <dt>{{jsxref("Promise.reject", "Promise.reject(reason)")}}</dt>
- <dd>Returns a <code>Promise</code> object that is rejected with the given reason.</dd>
- <dt>{{jsxref("Promise.resolve", "Promise.resolve(value)")}}</dt>
- <dd>Returns a <code>Promise</code> object that is resolved with the given value. If the value is a thenable (i.e. has a <code>then</code> method), the returned promise will "follow" that thenable, adopting its eventual state; otherwise the returned promise will be fulfilled with the value. Generally, if you don't know if a value is a promise or not, {{jsxref("Promise.resolve", "Promise.resolve(value)")}} it instead and work with the return value as a promise.</dd>
-</dl>
-
-<h2 id="Promise_prototype">Promise prototype</h2>
-
-<h3 id="Properties">Properties</h3>
-
-<p>{{page('en-US/Web/JavaScript/Reference/Global_Objects/Promise/prototype','Properties')}}</p>
-
-<h3 id="Methods_2">Methods</h3>
-
-<p>{{page('en-US/Web/JavaScript/Reference/Global_Objects/Promise/prototype','Methods')}}</p>
-
-<h2 id="Creating_a_Promise">Creating a Promise</h2>
-
-<p>A <code>Promise</code> object is created using the <code>new </code>keyword and its constructor. This constructor takes as its argument a function, called the "executor function". This function should take two functions as parameters. The first of these functions (<code>resolve</code>) is called when the asynchronous task completes successfully and returns the results of the task as a value. The second (<code>reject</code>) is called when the task fails, and returns the reason for failure, which is typically an error object.</p>
-
-<pre class="brush: js">const myFirstPromise = new Promise((resolve, reject) =&gt; {
- // do something asynchronous which eventually calls either:
- //
- // resolve(someValue); // fulfilled
- // or
- // reject("failure reason"); // rejected
-});
-</pre>
-
-<p>To provide a function with promise functionality, simply have it return a promise:</p>
-
-<pre class="brush: js">function myAsyncFunction(url) {
- return new Promise((resolve, reject) =&gt; {
- const xhr = new XMLHttpRequest();
- xhr.open("GET", url);
- xhr.onload = () =&gt; resolve(xhr.responseText);
- xhr.onerror = () =&gt; reject(xhr.statusText);
- xhr.send();
- });
-}</pre>
-
-<h2 id="דוגמאות">דוגמאות</h2>
-
-<h3 id="דוגמה_בסיסית">דוגמה בסיסית</h3>
-
-<pre class="brush: js">let myFirstPromise = new Promise((resolve, reject) =&gt; {
- // We call resolve(...) when what we were doing asynchronously was successful, and reject(...) when it failed.
- // In this example, we use setTimeout(...) to simulate async code.
- // In reality, you will probably be using something like XHR or an HTML5 API.
- setTimeout(function(){
- resolve("Success!"); // Yay! Everything went well!
- }, 250);
-});
-
-myFirstPromise.then((successMessage) =&gt; {
- // successMessage is whatever we passed in the resolve(...) function above.
- // It doesn't have to be a string, but if it is only a succeed message, it probably will be.
- console.log("Yay! " + successMessage);
-});
-</pre>
-
-<h3 id="דוגמה_מתקדמת">דוגמה מתקדמת</h3>
-
-<pre class="brush: html hidden">&lt;button id="btn"&gt;Make a promise!&lt;/button&gt;
-&lt;div id="log"&gt;&lt;/div&gt;
-</pre>
-
-<p>This small example shows the mechanism of a <code>Promise</code>. The <code>testPromise()</code> method is called each time the {{HTMLElement("button")}} is clicked. It creates a promise that will be fulfilled, using {{domxref("window.setTimeout()")}}, to the promise count (number starting from 1) every 1-3 seconds, at random. The <code>Promise()</code> constructor is used to create the promise.</p>
-
-<p>The fulfillment of the promise is simply logged, via a fulfill callback set using {{jsxref("Promise.prototype.then()","p1.then()")}}. A few logs show how the synchronous part of the method is decoupled from the asynchronous completion of the promise.</p>
-
-<pre class="brush: js">'use strict';
-var promiseCount = 0;
-
-function testPromise() {
- let thisPromiseCount = ++promiseCount;
-
- let log = document.getElementById('log');
- log.insertAdjacentHTML('beforeend', thisPromiseCount +
- ') Started (&lt;small&gt;Sync code started&lt;/small&gt;)&lt;br/&gt;');
-
- // We make a new promise: we promise a numeric count of this promise, starting from 1 (after waiting 3s)
- let p1 = new Promise(
- // The executor function is called with the ability to resolve or
- // reject the promise
- (resolve, reject) =&gt; {
- log.insertAdjacentHTML('beforeend', thisPromiseCount +
- ') Promise started (&lt;small&gt;Async code started&lt;/small&gt;)&lt;br/&gt;');
- // This is only an example to create asynchronism
- window.setTimeout(
- function() {
- // We fulfill the promise !
- resolve(thisPromiseCount);
- }, Math.random() * 2000 + 1000);
- }
- );
-
- // We define what to do when the promise is resolved with the then() call,
- // and what to do when the promise is rejected with the catch() call
- p1.then(
- // Log the fulfillment value
- function(val) {
- log.insertAdjacentHTML('beforeend', val +
- ') Promise fulfilled (&lt;small&gt;Async code terminated&lt;/small&gt;)&lt;br/&gt;');
- }).catch(
- // Log the rejection reason
- (reason) =&gt; {
- console.log('Handle rejected promise ('+reason+') here.');
- });
-
- log.insertAdjacentHTML('beforeend', thisPromiseCount +
- ') Promise made (&lt;small&gt;Sync code terminated&lt;/small&gt;)&lt;br/&gt;');
-}</pre>
-
-<pre class="brush:js hidden">if ("Promise" in window) {
- let btn = document.getElementById("btn");
- btn.addEventListener("click",testPromise);
-} else {
- log = document.getElementById('log');
- log.innerHTML = "Live example not available as your browser doesn't support the &lt;code&gt;Promise&lt;code&gt; interface.";
-}
-</pre>
-
-<p>This example is started by clicking the button. You need a browser that supports <code>Promise</code>. By clicking the button several times in a short amount of time, you'll even see the different promises being fulfilled one after another.</p>
-
-<p>{{EmbedLiveSample("Advanced_Example", "500", "200")}}</p>
-
-<h2 id="טעינת_תמונה_באמצעות_XHR">טעינת תמונה באמצעות XHR</h2>
-
-<p>Another simple example using <code>Promise</code> and {{domxref("XMLHttpRequest")}} to load an image is available at the MDN GitHub <a href="https://github.com/mdn/js-examples/tree/master/promises-test">js-examples</a> repository. You can also <a href="https://mdn.github.io/js-examples/promises-test/">see it in action</a>. Each step is commented and allows you to follow the Promise and XHR architecture closely.</p>
-
-<h2 id="מפרט">מפרט</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('ES2015', '#sec-promise-objects', 'Promise')}}</td>
- <td>{{Spec2('ES2015')}}</td>
- <td>Initial definition in an ECMA standard.</td>
- </tr>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-promise-objects', 'Promise')}}</td>
- <td>{{Spec2('ESDraft')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תאימות_דפדפן">תאימות דפדפן</h2>
-
-<p class="hidden">To contribute to this compatibility data, please write a pull request against this repository: <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a>.</p>
-
-<p>{{Compat("javascript.builtins.Promise")}}</p>
-
-<h2 id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li><a href="/en-US/docs/Web/JavaScript/Guide/Using_promises">Using promises</a></li>
- <li><a href="http://promisesaplus.com/">Promises/A+ specification</a></li>
- <li><a href="https://medium.com/@ramsunvtech/promises-of-promise-part-1-53f769245a53">Venkatraman.R - JS Promise (Part 1, Basics)</a></li>
- <li><a href="https://medium.com/@ramsunvtech/js-promise-part-2-q-js-when-js-and-rsvp-js-af596232525c#.dzlqh6ski">Venkatraman.R - JS Promise (Part 2 - Using Q.js, When.js and RSVP.js)</a></li>
- <li><a href="https://tech.io/playgrounds/11107/tools-for-promises-unittesting/introduction">Venkatraman.R - Tools for Promises Unit Testing</a></li>
- <li><a href="http://www.html5rocks.com/en/tutorials/es6/promises/">Jake Archibald: JavaScript Promises: There and Back Again</a></li>
- <li><a href="http://de.slideshare.net/domenicdenicola/callbacks-promises-and-coroutines-oh-my-the-evolution-of-asynchronicity-in-javascript">Domenic Denicola: Callbacks, Promises, and Coroutines – Asynchronous Programming Patterns in JavaScript</a></li>
- <li><a href="http://www.mattgreer.org/articles/promises-in-wicked-detail/">Matt Greer: JavaScript Promises ... In Wicked Detail</a></li>
- <li><a href="https://www.promisejs.org/">Forbes Lindesay: promisejs.org</a></li>
- <li><a href="https://github.com/jakearchibald/es6-promise/">Promise polyfill</a></li>
- <li><a href="https://www.udacity.com/course/javascript-promises--ud898">Udacity: JavaScript Promises</a></li>
-</ul>
diff --git a/files/he/web/javascript/reference/global_objects/string/index.html b/files/he/web/javascript/reference/global_objects/string/index.html
deleted file mode 100644
index 8b8911749e..0000000000
--- a/files/he/web/javascript/reference/global_objects/string/index.html
+++ /dev/null
@@ -1,314 +0,0 @@
----
-title: 'String: מחרוזת'
-slug: Web/JavaScript/Reference/Global_Objects/String
-tags:
- - ECMAScript 2015
- - JavaScript
- - NeedsTranslation
- - Reference
- - String
- - TopicStub
-translation_of: Web/JavaScript/Reference/Global_Objects/String
----
-<div>{{JSRef}}</div>
-
-<p>The <strong><code>String</code></strong> global object is a constructor for strings or a sequence of characters.</p>
-
-<h2 id="תחביר">תחביר</h2>
-
-<p>String literals take the forms:</p>
-
-<pre class="syntaxbox">'string text'
-"string text"
-"中文 español Deutsch English देवनागरी العربية português বাংলা русский 日本語 ਪੰਜਾਬੀ 한국어 தமிழ் עברית"</pre>
-
-<p>Strings can also be created using the <code>String</code> global object directly:</p>
-
-<pre class="syntaxbox">String(thing)</pre>
-
-<h3 id="Parameters">Parameters</h3>
-
-<dl>
- <dt><code>thing</code></dt>
- <dd>Anything to be converted to a string.</dd>
-</dl>
-
-<h3 id="Template_literals">Template literals</h3>
-
-<p>Starting with ECMAScript 2015, string literals can also be so-called <a href="/en-US/docs/Web/JavaScript/Reference/Template_literals">Template literals</a>:</p>
-
-<pre class="syntaxbox">`hello world`
-`hello!
- world!`
-`hello ${who}`
-escape `&lt;a&gt;${who}&lt;/a&gt;`</pre>
-
-<dl>
-</dl>
-
-<h3 id="Escape_notation">Escape notation</h3>
-
-<p>Besides regular, printable characters, special characters can be encoded using escape notation:</p>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">Code</th>
- <th scope="col">Output</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td><code>\XXX</code></td>
- <td>an octal Latin-1 character.</td>
- </tr>
- <tr>
- <td><code>\'</code></td>
- <td>single quote</td>
- </tr>
- <tr>
- <td><code>\"</code></td>
- <td>double quote</td>
- </tr>
- <tr>
- <td><code>\\</code></td>
- <td>backslash</td>
- </tr>
- <tr>
- <td><code>\n</code></td>
- <td>new line</td>
- </tr>
- <tr>
- <td><code>\r</code></td>
- <td>carriage return</td>
- </tr>
- <tr>
- <td><code>\v</code></td>
- <td>vertical tab</td>
- </tr>
- <tr>
- <td><code>\t</code></td>
- <td>tab</td>
- </tr>
- <tr>
- <td><code>\b</code></td>
- <td>backspace</td>
- </tr>
- <tr>
- <td><code>\f</code></td>
- <td>form feed</td>
- </tr>
- <tr>
- <td><code>\uXXXX</code></td>
- <td>unicode codepoint</td>
- </tr>
- <tr>
- <td><code>\u{X}</code> ... <code>\u{XXXXXX}</code></td>
- <td>unicode codepoint {{experimental_inline}}</td>
- </tr>
- <tr>
- <td><code>\xXX</code></td>
- <td>the Latin-1 character</td>
- </tr>
- </tbody>
-</table>
-
-<div class="note">
-<p>Unlike some other languages, JavaScript makes no distinction between single-quoted strings and double-quoted strings; therefore, the escape sequences above work in strings created with either single or double quotes.</p>
-</div>
-
-<dl>
-</dl>
-
-<h3 id="Long_literal_strings">Long literal strings</h3>
-
-<p>Sometimes, your code will include strings which are very long. Rather than having lines that go on endlessly, or wrap at the whim of your editor, you may wish to specifically break the string into multiple lines in the source code without affecting the actual string contents. There are two ways you can do this.</p>
-
-<p>You can use the <a href="/en-US/docs/Web/JavaScript/Reference/Operators/Arithmetic_Operators#Addition_()">+</a> operator to append multiple strings together, like this:</p>
-
-<pre class="brush: js">let longString = "This is a very long string which needs " +
- "to wrap across multiple lines because " +
- "otherwise my code is unreadable.";
-</pre>
-
-<p>Or you can use the backslash character ("\") at the end of each line to indicate that the string will continue on the next line. Make sure there is no space or any other character after the backslash (except for a line break), or as an indent; otherwise it will not work. That form looks like this:</p>
-
-<pre class="brush: js">let longString = "This is a very long string which needs \
-to wrap across multiple lines because \
-otherwise my code is unreadable.";
-</pre>
-
-<p>Both of these result in identical strings being created.</p>
-
-<h2 id="תיאור">תיאור</h2>
-
-<p>Strings are useful for holding data that can be represented in text form. Some of the most-used operations on strings are to check their {{jsxref("String.length", "length")}}, to build and concatenate them using the <a href="/en-US/docs/Web/JavaScript/Reference/Operators/String_Operators">+ and += string operators</a>, checking for the existence or location of substrings with the {{jsxref("String.prototype.indexOf()", "indexOf()")}} method, or extracting substrings with the {{jsxref("String.prototype.substring()", "substring()")}} method.</p>
-
-<h3 id="Character_access">Character access</h3>
-
-<p>There are two ways to access an individual character in a string. The first is the {{jsxref("String.prototype.charAt()", "charAt()")}} method:</p>
-
-<pre class="brush: js">return 'cat'.charAt(1); // returns "a"
-</pre>
-
-<p>The other way (introduced in ECMAScript 5) is to treat the string as an array-like object, where individual characters correspond to a numerical index:</p>
-
-<pre class="brush: js">return 'cat'[1]; // returns "a"
-</pre>
-
-<p>For character access using bracket notation, attempting to delete or assign a value to these properties will not succeed. The properties involved are neither writable nor configurable. (See {{jsxref("Object.defineProperty()")}} for more information.)</p>
-
-<h3 id="Comparing_strings">Comparing strings</h3>
-
-<p>C developers have the <code>strcmp()</code> function for comparing strings. In JavaScript, you just use the <a href="/en-US/docs/Web/JavaScript/Reference/Operators/Comparison_Operators">less-than and greater-than operators</a>:</p>
-
-<pre class="brush: js">var a = 'a';
-var b = 'b';
-if (a &lt; b) { // true
- console.log(a + ' is less than ' + b);
-} else if (a &gt; b) {
- console.log(a + ' is greater than ' + b);
-} else {
- console.log(a + ' and ' + b + ' are equal.');
-}
-</pre>
-
-<p>A similar result can be achieved using the {{jsxref("String.prototype.localeCompare()", "localeCompare()")}} method inherited by <code>String</code> instances.</p>
-
-<h3 id="Distinction_between_string_primitives_and_String_objects">Distinction between string primitives and <code>String</code> objects</h3>
-
-<p>Note that JavaScript distinguishes between <code>String</code> objects and primitive string values. (The same is true of {{jsxref("Boolean")}} and {{jsxref("Global_Objects/Number", "Numbers")}}.)</p>
-
-<p>String literals (denoted by double or single quotes) and strings returned from <code>String</code> calls in a non-constructor context (i.e., without using the {{jsxref("Operators/new", "new")}} keyword) are primitive strings. JavaScript automatically converts primitives to <code>String</code> objects, so that it's possible to use <code>String</code> object methods for primitive strings. In contexts where a method is to be invoked on a primitive string or a property lookup occurs, JavaScript will automatically wrap the string primitive and call the method or perform the property lookup.</p>
-
-<pre class="brush: js">var s_prim = 'foo';
-var s_obj = new String(s_prim);
-
-console.log(typeof s_prim); // Logs "string"
-console.log(typeof s_obj); // Logs "object"
-</pre>
-
-<p>String primitives and <code>String</code> objects also give different results when using {{jsxref("Global_Objects/eval", "eval()")}}. Primitives passed to <code>eval</code> are treated as source code; <code>String</code> objects are treated as all other objects are, by returning the object. For example:</p>
-
-<pre class="brush: js">var s1 = '2 + 2'; // creates a string primitive
-var s2 = new String('2 + 2'); // creates a String object
-console.log(eval(s1)); // returns the number 4
-console.log(eval(s2)); // returns the string "2 + 2"
-</pre>
-
-<p>For these reasons, the code may break when it encounters <code>String</code> objects when it expects a primitive string instead, although generally, authors need not worry about the distinction.</p>
-
-<p>A <code>String</code> object can always be converted to its primitive counterpart with the {{jsxref("String.prototype.valueOf()", "valueOf()")}} method.</p>
-
-<pre class="brush: js">console.log(eval(s2.valueOf())); // returns the number 4
-</pre>
-
-<div class="note"><strong>Note:</strong> For another possible approach to strings in JavaScript, please read the article about <a href="/en-US/Add-ons/Code_snippets/StringView"><code>StringView</code> — a C-like representation of strings based on typed arrays</a>.</div>
-
-<h2 id="מאפיינים">מאפיינים</h2>
-
-<dl>
- <dt>{{jsxref("String.prototype")}}</dt>
- <dd>Allows the addition of properties to a <code>String</code> object.</dd>
-</dl>
-
-<h2 id="Methods">Methods</h2>
-
-<dl>
- <dt>{{jsxref("String.fromCharCode()")}}</dt>
- <dd>Returns a string created by using the specified sequence of Unicode values.</dd>
- <dt>{{jsxref("String.fromCodePoint()")}}</dt>
- <dd>Returns a string created by using the specified sequence of code points.</dd>
- <dt>{{jsxref("String.raw()")}} {{experimental_inline}}</dt>
- <dd>Returns a string created from a raw template string.</dd>
-</dl>
-
-<h2 id="String_generic_methods"><code>String</code> generic methods</h2>
-
-<div class="warning">
-<p><strong>String generics are non-standard, deprecated and will get removed near future</strong>.</p>
-</div>
-
-<p>The <code>String</code> instance methods are also available in Firefox as of JavaScript 1.6 (<strong>not</strong> part of the ECMAScript standard) on the <code>String</code> object for applying <code>String</code> methods to any object:</p>
-
-<pre class="brush: js">var num = "15";
-console.log(num.replace("5", "2"));
-</pre>
-
-<p>For migrating away from String generics, see also <a href="/en-US/docs/Web/JavaScript/Reference/Errors/Deprecated_string_generics">Warning: String.x is deprecated; use String.prototype.x instead</a>.</p>
-
-<p>{{jsxref("Global_Objects/Array", "Generics", "#Array_generic_methods", 1)}} are also available on {{jsxref("Array")}} methods.</p>
-
-<h2 id="String_instances"><code>String</code> instances</h2>
-
-<h3 id="Properties">Properties</h3>
-
-<div>{{page('/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/prototype', 'Properties')}}</div>
-
-<h3 id="Methods_2">Methods</h3>
-
-<h4 id="Methods_unrelated_to_HTML">Methods unrelated to HTML</h4>
-
-<div>{{page('/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/prototype', 'Methods_unrelated_to_HTML')}}</div>
-
-<h4 id="HTML_wrapper_methods">HTML wrapper methods</h4>
-
-<div>{{page('/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/prototype', 'HTML_wrapper_methods')}}</div>
-
-<h2 id="דוגמאות">דוגמאות</h2>
-
-<h3 id="String_conversion">String conversion</h3>
-
-<p>It's possible to use <code>String</code> as a more reliable {{jsxref("String.prototype.toString()", "toString()")}} alternative, as it works when used on {{jsxref("null")}}, {{jsxref("undefined")}}, and on {{jsxref("Symbol", "symbols")}}. For example:</p>
-
-<pre class="brush: js">var outputStrings = [];
-for (var i = 0, n = inputValues.length; i &lt; n; ++i) {
- outputStrings.push(String(inputValues[i]));
-}
-</pre>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('ES1')}}</td>
- <td>{{Spec2('ES1')}}</td>
- <td>Initial definition.</td>
- </tr>
- <tr>
- <td>{{SpecName('ES5.1', '#sec-15.5', 'String')}}</td>
- <td>{{Spec2('ES5.1')}}</td>
- <td> </td>
- </tr>
- <tr>
- <td>{{SpecName('ES2015', '#sec-string-objects', 'String')}}</td>
- <td>{{Spec2('ES2015')}}</td>
- <td> </td>
- </tr>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-string-objects', 'String')}}</td>
- <td>{{Spec2('ESDraft')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תאימות_דפדפן">תאימות דפדפן</h2>
-
-<p class="hidden">The compatibility table in this page is generated from structured data. If you'd like to contribute to the data, please check out <a href="https://github.com/mdn/browser-compat-data">https://github.com/mdn/browser-compat-data</a> and send us a pull request.</p>
-
-<p>{{Compat("javascript.builtins.String",2)}}</p>
-
-<h2 id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{domxref("DOMString")}}</li>
- <li><a href="/en-US/Add-ons/Code_snippets/StringView"><code>StringView</code> — a C-like representation of strings based on typed arrays</a></li>
- <li><a href="/en-US/docs/Web/API/DOMString/Binary">Binary strings</a></li>
-</ul>
diff --git a/files/he/web/javascript/reference/index.html b/files/he/web/javascript/reference/index.html
deleted file mode 100644
index 1f46b431e0..0000000000
--- a/files/he/web/javascript/reference/index.html
+++ /dev/null
@@ -1,58 +0,0 @@
----
-title: JavaScript reference
-slug: Web/JavaScript/Reference
-tags:
- - JavaScript
- - NeedsTranslation
- - TopicStub
-translation_of: Web/JavaScript/Reference
----
-<div dir="rtl">{{JsSidebar}}</div>
-
-<div dir="rtl">הדף הנ"ל משמש כמאגר של עובדות ורפרנסים לנושאים מרכזיים בשפת התכנות ג'אווה סקריפט. קרא עוד על <a href="/en-US/docs/Web/JavaScript/Reference/About">עמוד זה</a><strong>.</strong></div>
-
-<div dir="rtl"> </div>
-
-<h2 dir="rtl" id="אובייקטים_גלובאלים">אובייקטים גלובאלים</h2>
-
-<p dir="rtl">פרק זה הוא תיעוד של כלל האובייקטים שמובנים כסטנדרט בג'אווה סקריפט, יחד עם המתודות (methods) והתכונות (properties) שלהם.</p>
-
-<div dir="rtl">{{page('/en-US/docs/Web/JavaScript/Reference/Global_Objects', 'Standard objects (by category)')}}</div>
-
-<h2 dir="rtl" id="הצהרות">הצהרות</h2>
-
-<p dir="rtl">פרק זה הוא תיעוד של כלל <a href="/en-US/docs/Web/JavaScript/Reference/Statements">ההצהרות והמשפטים* בג'אווה סקריפט</a>.</p>
-
-<p dir="rtl">* התרגום של statement ו declaration לעברית הוא "הצהרה".<br>
- כאן הכוונה להצהרה ( declaration ), לדוגמא - var a = 123.<br>
- ומשפט (statement), לדוגמא - משפטי if.</p>
-
-<div dir="rtl">{{page('/he/docs/Web/JavaScript/Reference/Statements', 'Statements_and_declarations_by_category')}}</div>
-
-<h2 dir="rtl" id="ביטויים_ואופרטורים">ביטויים ואופרטורים</h2>
-
-<p dir="rtl">פרק זה הוא תיעוד של כלל <a href="/en-US/docs/Web/JavaScript/Reference/Operators">הביטויים והאופרטורים בג'אווה סקריפט</a>.</p>
-
-<div dir="rtl">{{page('/en-US/docs/Web/JavaScript/Reference/Operators', 'Expressions_and_operators_by_category')}}</div>
-
-<h2 dir="rtl" id="פונקציות">פונקציות</h2>
-
-<p dir="rtl">פרק זה הוא תיעוד של מהלך העבודה עם <a href="/en-US/docs/Web/JavaScript/Reference/Functions">פונקציות בג'אווה סקריפט</a> בפיתוח תוכנות.</p>
-
-<ul dir="rtl">
- <li><code><a href="/en-US/docs/Web/JavaScript/Reference/Functions/arguments">ארגומנטים</a></code></li>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Functions/Arrow_functions">פונקציות חץ</a></li>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Functions/Default_parameters">פרמטרים ברירת מחדל</a></li>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Functions/rest_parameters">פרמטרי רסט</a>*</li>
-</ul>
-
-<p dir="rtl">* סביר שיש תרגום טוב יותר למונח rest parameters./</p>
-
-<h2 dir="rtl" id="רפרנסים_נוספים">רפרנסים נוספים</h2>
-
-<ul dir="rtl">
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Lexical_grammar">דקדוק לקסיקלי</a></li>
- <li><a href="/en-US/docs/Web/JavaScript/Data_structures">סוגי ומבני נתונים </a></li>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Strict_mode">מצב קפדני (strict mode)</a></li>
- <li><a href="/he/docs//en-US/docs/Web/JavaScript/Reference/Deprecated_and_obsolete_features">פיצ'רים שהוצאו משימוש</a></li>
-</ul>
diff --git a/files/he/web/javascript/reference/operators/destructuring_assignment/index.html b/files/he/web/javascript/reference/operators/destructuring_assignment/index.html
deleted file mode 100644
index 07b2957fe2..0000000000
--- a/files/he/web/javascript/reference/operators/destructuring_assignment/index.html
+++ /dev/null
@@ -1,416 +0,0 @@
----
-title: השמה מפורקת
-slug: Web/JavaScript/Reference/Operators/Destructuring_assignment
-translation_of: Web/JavaScript/Reference/Operators/Destructuring_assignment
----
-<div style="direction: rtl;">{{jsSidebar("Operators")}}</div>
-
-<p style="direction: rtl;">תחביר <strong>השמה מפורקת </strong>הוא ביטוי JavaScript המאפשר לחלץ נתונים ממערכים או אובייקטים לערכים מפורשים, בעזרת שימוש בתחביר שמשקף את מבנה המערך או האובייקט המילולי.</p>
-
-<h2 id="תחביר" style="direction: rtl;">תחביר</h2>
-
-<pre class="brush:js">var a, b, rest;
-[a, b] = [1, 2]
-console.log(a); // 1
-console.log(b); // 2
-
-[a, b, ...rest] = [1, 2, 3, 4, 5]
-console.log(a); // 1
-console.log(b); // 2
-console.log(rest); // [3, 4, 5]
-
-({a, b} = {a: 1, b :2});
-console.log(a); // 1 console.log(b); // 2
-
-({a, b, ...rest} = {a: 1, b: 2, c: 3, d: 4}); //ES2016
-console.log(a); // 1
-console.log(b); // 2
-console.log(rest); // {c: 3, d: 4}
-</pre>
-
-<div class="note">
-<p style="direction: rtl;">{a, b} = {a:1, b:2} הוא לא תחביר עצמאי תקף, כי {a, b} בצד השמאלי נחשב כבלוק ולא כאובייקט מילולי.</p>
-
-<p dir="rtl">עם זאת, ({a, b} = {a:1, b:2}) תקף, כמו גם {var {a, b} = {a:1, b:2.</p>
-</div>
-
-<h2 id="תאור" style="direction: rtl;">תאור</h2>
-
-<div style="direction: rtl;"><span style="line-height: 1.5;">ביטויים ליטרלים של אובייקטים או מערכים מספקים דרך פשוטה ליצירה של חבילת נתונים <em>לפי דרישה</em>. לאחר יצירת חבילות נתונים אלה, ניתן להשתמש בהם בכל דרך שתרצה. ניתן אפילו להחזיר אותם מפונקציות.</span></div>
-
-<pre class="brush: js">var x = [10, 20, 30, 40, 50];</pre>
-
-<p style="direction: rtl;">השמה מפורקת משתמשת בתחביר דומה, אך צד שמאל של ההשמה מציין אילו ערכים לפרוק ממשתנה המקור.</p>
-
-<pre class="brush: js" style="direction: rtl;">var x = [10, 20, 30, 40, 50];
-var [y, x] = x;
-console.log(y); // 10
-console.log(z); // 20
-</pre>
-
-<p style="direction: rtl;">דבר אחד שימושי במיוחד שאתה יכול לעשות עם השמה מפורקת הוא לקרוא מבנה שלם בהשמה אחת, אם כי יש עוד מספר דברים מעניינים שאתה יכול לעשות איתם, כפי שמוצג בדוגמאות הבאות.</p>
-
-<p style="direction: rtl;">יכולת זו דומה לתכונות קיימות בשפות כמו פרל ופייתון.</p>
-
-<h2 id="פירוק_מערך" style="direction: rtl;">פירוק מערך</h2>
-
-<h3 id="דוגמה_פשוטה" style="direction: rtl;">דוגמה פשוטה</h3>
-
-<pre class="brush: js">var foo = ["one", "two", "three"];
-
-// without destructuring
-var one = foo[0];
-var two = foo[1];
-var three = foo[2];
-
-// with destructuring
-var [one, two, three] = foo;</pre>
-
-<h3 id="השמה_ללא_הצהרה" style="direction: rtl;">השמה ללא הצהרה</h3>
-
-<p style="direction: rtl;">השמה מפורקת יכולה להתבצע ללא הצהרה בעת ההשמה.</p>
-
-<pre class="brush:js">var a, b;
-
-[a, b] = [1, 2];</pre>
-
-<h3 id="החלפת_משתנים" style="direction: rtl;">החלפת משתנים</h3>
-
-<p style="direction: rtl;">לאחר ביצוע הקוד הזה, b הוא 1 וa הוא 3. ללא השמה מפורקת, החלפת שני ערכים דורשת שימוש במשתנה זמני (או, בכמה שפות נמוכות, טריק ההחלפת XOR).</p>
-
-<pre class="brush:js">var a = 1;
-var b = 3;
-
-[a, b] = [b, a];</pre>
-
-<h3 id="החזרה_מרובת_ערכים" style="direction: rtl;">החזרה מרובת ערכים</h3>
-
-<p style="direction: rtl;">תודה להשמה מפורקת פונקציות יכולות להחזיר ערכים מרובים. למרות שתמיד היה ניתן להחזיר מערך מפונקציה, זה עדיין מספק מידה נוספת של גמישות.</p>
-
-<pre class="brush:js">function f() {
- return [1, 2];
-}
-</pre>
-
-<p style="direction: rtl;">כפי שניתן לראות, החזרת תוצאות נעשית באמצעות סימון כמו מערך, עם כל הערכים בתוך סוגריים. אתה יכול להחזיר מספר בלתי מוגבל של תוצאות בדרך זו. בדוגמא זו, ()f מחזירה את הערכים [1, 2] כפלט שלה.</p>
-
-<pre class="brush:js">var a, b;
-[a, b] = f();
-console.log("A is " + a + " B is " + b);
-</pre>
-
-<p style="direction: rtl;">ההצהרה ()a, b] = f] מקצה את התוצאות של הפונקציה למשתנים בסוגריים, בהתאמה: a הוא 1 ו- b מוגדר 2.</p>
-
-<p style="direction: rtl;">גם אתה יכול לקבל את ערכי החזרה כמערך:</p>
-
-<pre class="brush:js">var a = f();
-console.log("A is " + a);
-</pre>
-
-<p style="direction: rtl;">במקרה זה, a הוא מערך המכיל את הערכים 1 ו-2.</p>
-
-<h3 id="התעלמות_ממספר_ערכי_החזר" style="direction: rtl;">התעלמות ממספר ערכי החזר</h3>
-
-<p style="direction: rtl;">אתה יכול להתעלם מערכי החזר שאתה לא מעוניין בהם:</p>
-
-<pre class="brush:js">function f() {
- return [1, 2, 3];
-}
-
-var [a, , b] = f();
-console.log("A is " + a + " B is " + b);
-</pre>
-
-<p style="direction: rtl;">לאחר הרצת קוד זה, a הוא 1 ו- b הוא 3. הערך 2 נדחה. אתה יכול להתעלם מכל ערכי ההחזר בדרך זו. לדוגמה:</p>
-
-<pre class="brush:js">[,,] = f();
-</pre>
-
-<h3 id="משיכת_ערכים_מתוצאה_של_regular_expression" style="direction: rtl;">משיכת ערכים מתוצאה של regular expression</h3>
-
-<p dir="rtl">כאשר המתודה  <code><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/RegExp/exec"> exec</a> </code>של regular expression מוצאת התאמה, היא מחזירה מערך המכיל במיקום הראשון את כל ההתאמה של המחרוזת ולאחר מכן את כל החלקים של המחרוזת שתאמה כל קבוצה בסוגריים בregular expression. השמה מפורקת מאפשרת לך למשוך את החלקים מתוך מערך זה בקלות, תוך התעלמות מההתאמה המלאה אם היא לא נחוצה.</p>
-
-<pre class="brush:js">var url = "https://developer.mozilla.org/en-US/Web/JavaScript";
-
-var parsedURL = /^(\w+)\:\/\/([^\/]+)\/(.*)$/.exec(url);
-var [, protocol, fullhost, fullpath] = parsedURL;
-
-console.log(protocol); // logs "https"
-</pre>
-
-<h2 id="פירוק_אובייקט" style="direction: rtl;">פירוק אובייקט</h2>
-
-<h3 id="דוגמה_פשוטה_2" style="direction: rtl;">דוגמה פשוטה</h3>
-
-<pre class="brush: js">var o = {p: 42, q: true};
-var {p, q} = o;
-
-console.log(p); // 42
-console.log(q); // true
-
-// Assign new variable names
-var {p: foo, q: bar} = o;
-
-console.log(foo); // 42
-console.log(bar); // true  </pre>
-
-<h3 id="השמה_ללא_הצהרה_2" style="direction: rtl;">השמה ללא הצהרה</h3>
-
-<p style="direction: rtl;">השמה מפורקת יכולה להתבצע ללא הצהרה בעת ההשמה.</p>
-
-<pre class="brush:js">var a, b;
-
-({a, b} = {a:1, b:2});</pre>
-
-<div class="note">
-<p>The <code>( .. )</code> around the assignment statement is required syntax when using object literal destructuring assignment without a declaration.</p>
-</div>
-
-<h3 id="ברירות_המחדל_של_ארגומנטים_מפונקציה">ברירות המחדל של ארגומנטים מפונקציה</h3>
-
-<h4 id="גרסת_ES5">גרסת ES5</h4>
-
-<pre class="brush: js">function drawES5Chart(options) {
- options = options === undefined ? {} : options;
- var size = options.size === undefined ? 'big' : options.size;
- var cords = options.cords === undefined ? { x: 0, y: 0 } : options.cords;
- var radius = options.radius === undefined ? 25 : options.radius;
- console.log(size, cords, radius);
- // now finally do some chart drawing
-}
-
-drawES5Chart({
- cords: { x: 18, y: 30 },
- radius: 30
-});</pre>
-
-<h4 id="גרסת_ES2015">גרסת ES2015</h4>
-
-<pre class="brush: js">function drawES2015Chart({size: size = 'big', cords: cords = { x: 0, y: 0 }, radius: radius = 25} = {})
-{
- console.log(size, cords, radius);
- // do some chart drawing
-}
-
-drawES2015Chart({
- cords: { x: 18, y: 30 },
- radius: 30
-});</pre>
-
-<div class="note">
-<p>In Firefox, default values for destructuring assignments are not yet implemented: var { x = 3 } = {} and var [foo = "bar"] = []. See {{bug(932080)}} for destructured default values in functions.</p>
-</div>
-
-<h3 id="Module_(non-ES2015)_loading">Module (non-ES2015) loading</h3>
-
-<p>Destructuring can help to load specific subsets of a non-ES2015 module like here in the <a href="/en-US/Add-ons/SDK">Add-on SDK</a>:</p>
-
-<pre class="brush: js">const { Loader, main } = require('toolkit/loader');
-</pre>
-
-<h3 id="Nested_object_and_array_destructuring">Nested object and array destructuring</h3>
-
-<pre class="brush:js">var metadata = {
-    title: "Scratchpad",
-    translations: [
-       {
-        locale: "de",
-        localization_tags: [ ],
-        last_edit: "2014-04-14T08:43:37",
-        url: "/de/docs/Tools/Scratchpad",
-        title: "JavaScript-Umgebung"
-       }
-    ],
-    url: "/en-US/docs/Tools/Scratchpad"
-};
-
-var { title: englishTitle, translations: [{ title: localeTitle }] } = metadata;
-
-console.log(englishTitle); // "Scratchpad"
-console.log(localeTitle);  // "JavaScript-Umgebung"</pre>
-
-<h3 id="For_of_iteration_and_destructuring">For of iteration and destructuring</h3>
-
-<pre class="brush: js">var people = [
-  {
-    name: "Mike Smith",
-    family: {
-      mother: "Jane Smith",
-      father: "Harry Smith",
-      sister: "Samantha Smith"
-    },
-    age: 35
-  },
-  {
-    name: "Tom Jones",
-    family: {
-      mother: "Norah Jones",
-      father: "Richard Jones",
-      brother: "Howard Jones"
-    },
-    age: 25
-  }
-];
-
-for (var {name: n, family: { father: f } } of people) {
- console.log("Name: " + n + ", Father: " + f);
-}
-
-// "Name: Mike Smith, Father: Harry Smith"
-// "Name: Tom Jones, Father: Richard Jones"</pre>
-
-<h3 id="Pulling_fields_from_objects_passed_as_function_parameter">Pulling fields from objects passed as function parameter</h3>
-
-<pre class="brush:js">function userId({id}) {
- return id;
-}
-
-function whois({displayName: displayName, fullName: {firstName: name}}){
- console.log(displayName + " is " + name);
-}
-
-var user = {
- id: 42,
- displayName: "jdoe",
- fullName: {
- firstName: "John",
- lastName: "Doe"
- }
-};
-
-console.log("userId: " + userId(user)); // "userId: 42"
-whois(user); // "jdoe is John"</pre>
-
-<p>This pulls the <code>id</code>, <code>displayName</code> and <code>firstName</code> from the user object and prints them.</p>
-
-<h3 id="Computed_object_property_names_and_destructuring">Computed object property names and destructuring</h3>
-
-<p>Computed property names, like on <a href="/en-US/docs/Web/JavaScript/Reference/Operators/Object_initializer#Computed_property_names">object literals</a>, can be used with destructuring.</p>
-
-<pre class="brush: js">let key = "z";
-let { [key]: foo } = { z: "bar" };
-
-console.log(foo); // "bar"
-</pre>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('ES2015', '#sec-destructuring-assignment', 'Destructuring assignment')}}</td>
- <td>{{Spec2('ES2015')}}</td>
- <td>Initial definition.</td>
- </tr>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-destructuring-assignment', 'Destructuring assignment')}}</td>
- <td>{{Spec2('ESDraft')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-<p>{{CompatibilityTable}}</p>
-
-<div id="compat-desktop">
-<table class="compat-table">
- <tbody>
- <tr>
- <th>Feature</th>
- <th>Chrome</th>
- <th>Firefox (Gecko)</th>
- <th>Internet Explorer</th>
- <th>Opera</th>
- <th>Safari</th>
- </tr>
- <tr>
- <td>Basic support</td>
- <td>{{CompatNo}}</td>
- <td>{{ CompatGeckoDesktop("1.8.1") }}</td>
- <td>{{CompatNo}}</td>
- <td>{{CompatNo}}</td>
- <td>7.1</td>
- </tr>
- <tr>
- <td>Computed property names</td>
- <td>{{CompatNo}}</td>
- <td>{{ CompatGeckoDesktop("34") }}</td>
- <td>{{CompatNo}}</td>
- <td>{{CompatNo}}</td>
- <td>{{CompatNo}}</td>
- </tr>
- <tr>
- <td>Spread operator</td>
- <td>{{CompatUnknown}}</td>
- <td>{{ CompatGeckoDesktop("34") }}</td>
- <td>{{CompatUnknown}}</td>
- <td>{{CompatUnknown}}</td>
- <td>{{CompatUnknown}}</td>
- </tr>
- </tbody>
-</table>
-</div>
-
-<div id="compat-mobile">
-<table class="compat-table">
- <tbody>
- <tr>
- <th>Feature</th>
- <th>Android</th>
- <th>Chrome for Android</th>
- <th>Firefox Mobile (Gecko)</th>
- <th>IE Mobile</th>
- <th>Opera Mobile</th>
- <th>Safari Mobile</th>
- </tr>
- <tr>
- <td>Basic support</td>
- <td>{{CompatNo}}</td>
- <td>{{CompatNo}}</td>
- <td>{{ CompatGeckoMobile("1.0") }}</td>
- <td>{{CompatNo}}</td>
- <td>{{CompatNo}}</td>
- <td>8</td>
- </tr>
- <tr>
- <td>Computed property names</td>
- <td>{{CompatNo}}</td>
- <td>{{CompatNo}}</td>
- <td>{{ CompatGeckoMobile("34") }}</td>
- <td>{{CompatNo}}</td>
- <td>{{CompatNo}}</td>
- <td>{{CompatNo}}</td>
- </tr>
- <tr>
- <td>Spread operator</td>
- <td>{{CompatUnknown}}</td>
- <td>{{CompatUnknown}}</td>
- <td>{{ CompatGeckoMobile("34") }}</td>
- <td>{{CompatUnknown}}</td>
- <td>{{CompatUnknown}}</td>
- <td>{{CompatUnknown}}</td>
- </tr>
- </tbody>
-</table>
-</div>
-
-<h2 id="Firefox-specific_notes">Firefox-specific notes</h2>
-
-<ul>
- <li>Firefox provided a non-standard language extension in <a href="/en-US/docs/Web/JavaScript/New_in_JavaScript/1.7">JS1.7</a> for destructuring. This extension has been removed in Gecko 40 {{geckoRelease(40)}}. See {{bug(1083498)}}.</li>
- <li>Starting with Gecko 41 {{geckoRelease(41)}} and to comply with the ES2015 specification, parenthesized destructuring patterns, like <code>([a, b]) = [1, 2]</code> or <code>({a, b}) = { a: 1, b: 2 }</code>, are now considered invalid and will throw a {{jsxref("SyntaxError")}}. See <a class="external external-icon" href="http://whereswalden.com/2015/06/20/new-changes-to-make-spidermonkeys-and-firefoxs-parsing-of-destructuring-patterns-more-spec-compliant/">Jeff Walden's blog post</a> and {{bug(1146136)}} for more details.</li>
-</ul>
-
-<h2 dir="rtl" id="ראה_גם">ראה גם</h2>
-
-<ul dir="rtl">
- <li><a href="/he/docs/Web/JavaScript/Reference/Operators/Assignment_Operators">אופרטורי השמה</a></li>
- <li><a href="https://hacks.mozilla.org/2015/05/es6-in-depth-destructuring/">"ES6 in Depth: Destructuring" on hacks.mozilla.org</a></li>
-</ul>
diff --git a/files/he/web/javascript/reference/operators/index.html b/files/he/web/javascript/reference/operators/index.html
deleted file mode 100644
index 08b776e8d8..0000000000
--- a/files/he/web/javascript/reference/operators/index.html
+++ /dev/null
@@ -1,289 +0,0 @@
----
-title: Expressions and operators
-slug: Web/JavaScript/Reference/Operators
-tags:
- - JavaScript
- - NeedsTranslation
- - Operators
- - TopicStub
-translation_of: Web/JavaScript/Reference/Operators
----
-<div>{{jsSidebar("Operators")}}</div>
-
-<p>This chapter documents all the JavaScript language operators, expressions and keywords.</p>
-
-<h2 id="Expressions_and_operators_by_category">Expressions and operators by category</h2>
-
-<p>For an alphabetical listing see the sidebar on the left.</p>
-
-<h3 id="Primary_expressions">Primary expressions</h3>
-
-<p>Basic keywords and general expressions in JavaScript.</p>
-
-<dl>
- <dt>{{jsxref("Operators/this", "this")}}</dt>
- <dd>The <code>this</code> keyword refers to the function's execution context.</dd>
- <dt>{{jsxref("Operators/function", "function")}}</dt>
- <dd>The <code>function</code> keyword defines a function expression.</dd>
- <dt>{{experimental_inline}} {{jsxref("Operators/class", "class")}}</dt>
- <dd>The <code>class</code> keyword defines a class expression.</dd>
- <dt>{{experimental_inline}} {{jsxref("Operators/function*", "function*")}}</dt>
- <dd>The <code>function*</code> keyword defines a generator function expression.</dd>
- <dt>{{experimental_inline}} {{jsxref("Operators/yield", "yield")}}</dt>
- <dd>Pause and resume a generator function</dd>
- <dt>{{experimental_inline}} {{jsxref("Operators/yield*", "yield*")}}</dt>
- <dd>Delegate to another generator function or iterable object.</dd>
- <dt>{{jsxref("Global_Objects/Array", "[]")}}</dt>
- <dd>Array initializer/literal syntax.</dd>
- <dt>{{jsxref("Operators/Object_initializer", "{}")}}</dt>
- <dd>Object initializer/literal syntax.</dd>
- <dt>{{jsxref("Global_Objects/RegExp", "/ab+c/i")}}</dt>
- <dd>Regular expression literal syntax.</dd>
- <dt>{{experimental_inline}} {{jsxref("Operators/Array_comprehensions", "[for (x of y) x]")}}</dt>
- <dd>Array comprehensions.</dd>
- <dt>{{experimental_inline}} {{jsxref("Operators/Generator_comprehensions", "(for (x of y) y)")}}</dt>
- <dd>Generator comprehensions.</dd>
- <dt>{{jsxref("Operators/Grouping", "( )")}}</dt>
- <dd>Grouping operator.</dd>
-</dl>
-
-<h3 id="Left-hand-side_expressions">Left-hand-side expressions</h3>
-
-<p>Left values are the destination of an assignment.</p>
-
-<dl>
- <dt>{{jsxref("Operators/Property_accessors", "Property accessors", "", 1)}}</dt>
- <dd>Member operators provide access to a property or method of an object<br>
- (<code>object.property</code> and <code>object["property"]</code>).</dd>
- <dt>{{jsxref("Operators/new", "new")}}</dt>
- <dd>The <code>new</code> operator creates an instance of a constructor.</dd>
- <dt>{{experimental_inline}} <a href="/en-US/docs/Web/JavaScript/Reference/Operators/new.target">new.target</a></dt>
- <dd>In constructors, <code>new.target</code> refers to the constructor that was invoked by {{jsxref("Operators/new", "new")}}.</dd>
- <dt>{{experimental_inline}} {{jsxref("Operators/super", "super")}}</dt>
- <dd>The <code>super</code> keyword calls the parent constructor.</dd>
- <dt>{{experimental_inline}} {{jsxref("Operators/Spread_operator", "...obj")}}</dt>
- <dd>The spread operator allows an expression to be expanded in places where multiple arguments (for function calls) or multiple elements (for array literals) are expected.</dd>
-</dl>
-
-<h3 id="Increment_and_decrement">Increment and decrement</h3>
-
-<p>Postfix/prefix increment and postfix/prefix decrement operators.</p>
-
-<dl>
- <dt>{{jsxref("Operators/Arithmetic_Operators", "A++", "#Increment")}}</dt>
- <dd>Postfix increment operator.</dd>
- <dt>{{jsxref("Operators/Arithmetic_Operators", "A--", "#Decrement")}}</dt>
- <dd>Postfix decrement operator.</dd>
- <dt>{{jsxref("Operators/Arithmetic_Operators", "++A", "#Increment")}}</dt>
- <dd>Prefix increment operator.</dd>
- <dt>{{jsxref("Operators/Arithmetic_Operators", "--A", "#Decrement")}}</dt>
- <dd>Prefix decrement operator.</dd>
-</dl>
-
-<h3 id="Unary_operators">Unary operators</h3>
-
-<p>A unary operation is operation with only one operand.</p>
-
-<dl>
- <dt>{{jsxref("Operators/delete", "delete")}}</dt>
- <dd>The <code>delete</code> operator deletes a property from an object.</dd>
- <dt>{{jsxref("Operators/void", "void")}}</dt>
- <dd>The <code>void</code> operator discards an expression's return value.</dd>
- <dt>{{jsxref("Operators/typeof", "typeof")}}</dt>
- <dd>The <code>typeof</code> operator determines the type of a given object.</dd>
- <dt>{{jsxref("Operators/Arithmetic_Operators", "+", "#Unary_plus")}}</dt>
- <dd>The unary plus operator converts its operand to Number type.</dd>
- <dt>{{jsxref("Operators/Arithmetic_Operators", "-", "#Unary_negation")}}</dt>
- <dd>The unary negation operator converts its operand to Number type and then negates it.</dd>
- <dt>{{jsxref("Operators/Bitwise_Operators", "~", "#Bitwise_NOT")}}</dt>
- <dd>Bitwise NOT operator.</dd>
- <dt>{{jsxref("Operators/Logical_Operators", "!", "#Logical_NOT")}}</dt>
- <dd>Logical NOT operator.</dd>
-</dl>
-
-<h3 id="Arithmetic_operators">Arithmetic operators</h3>
-
-<p>Arithmetic operators take numerical values (either literals or variables) as their operands and return a single numerical value.</p>
-
-<dl>
- <dt>{{jsxref("Operators/Arithmetic_Operators", "+", "#Addition")}}</dt>
- <dd>Addition operator.</dd>
- <dt>{{jsxref("Operators/Arithmetic_Operators", "-", "#Subtraction")}}</dt>
- <dd>Subtraction operator.</dd>
- <dt>{{jsxref("Operators/Arithmetic_Operators", "/", "#Division")}}</dt>
- <dd>Division operator.</dd>
- <dt>{{jsxref("Operators/Arithmetic_Operators", "*", "#Multiplication")}}</dt>
- <dd>Multiplication operator.</dd>
- <dt>{{jsxref("Operators/Arithmetic_Operators", "%", "#Remainder")}}</dt>
- <dd>Remainder operator.</dd>
-</dl>
-
-<dl>
- <dt>{{experimental_inline}} {{jsxref("Operators/Arithmetic_Operators", "**", "#Exponentiation")}}</dt>
- <dd>Exponentiation operator.</dd>
-</dl>
-
-<h3 id="Relational_operators">Relational operators</h3>
-
-<p>A comparison operator compares its operands and returns a <code>Boolean</code> value based on whether the comparison is true.</p>
-
-<dl>
- <dt>{{jsxref("Operators/in", "in")}}</dt>
- <dd>The <code>in</code> operator determines whether an object has a given property.</dd>
- <dt>{{jsxref("Operators/instanceof", "instanceof")}}</dt>
- <dd>The <code>instanceof</code> operator determines whether an object is an instance of another object.</dd>
- <dt>{{jsxref("Operators/Comparison_Operators", "&lt;", "#Less_than_operator")}}</dt>
- <dd>Less than operator.</dd>
- <dt>{{jsxref("Operators/Comparison_Operators", "&gt;", "#Greater_than_operator")}}</dt>
- <dd>Greater than operator.</dd>
- <dt>{{jsxref("Operators/Comparison_Operators", "&lt;=", "#Less_than_or_equal_operator")}}</dt>
- <dd>Less than or equal operator.</dd>
- <dt>{{jsxref("Operators/Comparison_Operators", "&gt;=", "#Greater_than_or_equal_operator")}}</dt>
- <dd>Greater than or equal operator.</dd>
-</dl>
-
-<h3 id="Equality_operators">Equality operators</h3>
-
-<p>The result of evaluating an equality operator is always of type <code>Boolean</code> based on whether the comparison is true.</p>
-
-<dl>
- <dt>{{jsxref("Operators/Comparison_Operators", "==", "#Equality")}}</dt>
- <dd>Equality operator.</dd>
- <dt>{{jsxref("Operators/Comparison_Operators", "!=", "#Inequality")}}</dt>
- <dd>Inequality operator.</dd>
- <dt>{{jsxref("Operators/Comparison_Operators", "===", "#Identity")}}</dt>
- <dd>Identity operator.</dd>
- <dt>{{jsxref("Operators/Comparison_Operators", "!==", "#Nonidentity")}}</dt>
- <dd>Nonidentity operator.</dd>
-</dl>
-
-<h3 id="Bitwise_shift_operators">Bitwise shift operators</h3>
-
-<p>Operations to shift all bits of the operand.</p>
-
-<dl>
- <dt>{{jsxref("Operators/Bitwise_Operators", "&lt;&lt;", "#Left_shift")}}</dt>
- <dd>Bitwise left shift operator.</dd>
- <dt>{{jsxref("Operators/Bitwise_Operators", "&gt;&gt;", "#Right_shift")}}</dt>
- <dd>Bitwise right shift operator.</dd>
- <dt>{{jsxref("Operators/Bitwise_Operators", "&gt;&gt;&gt;", "#Unsigned_right_shift")}}</dt>
- <dd>Bitwise unsigned right shift operator.</dd>
-</dl>
-
-<h3 id="Binary_bitwise_operators">Binary bitwise operators</h3>
-
-<p>Bitwise operators treat their operands as a set of 32 bits (zeros and ones) and return standard JavaScript numerical values.</p>
-
-<dl>
- <dt>{{jsxref("Operators/Bitwise_Operators", "&amp;", "#Bitwise_AND")}}</dt>
- <dd>Bitwise AND.</dd>
- <dt>{{jsxref("Operators/Bitwise_Operators", "|", "#Bitwise_OR")}}</dt>
- <dd>Bitwise OR.</dd>
- <dt>{{jsxref("Operators/Bitwise_Operators", "^", "#Bitwise_XOR")}}</dt>
- <dd>Bitwise XOR.</dd>
-</dl>
-
-<h3 id="Binary_logical_operators">Binary logical operators</h3>
-
-<p>Logical operators are typically used with boolean (logical) values, and when they are, they return a boolean value.</p>
-
-<dl>
- <dt>{{jsxref("Operators/Logical_Operators", "&amp;&amp;", "#Logical_AND")}}</dt>
- <dd>Logical AND.</dd>
- <dt>{{jsxref("Operators/Logical_Operators", "||", "#Logical_OR")}}</dt>
- <dd>Logical OR.</dd>
-</dl>
-
-<h3 id="Conditional_(ternary)_operator">Conditional (ternary) operator</h3>
-
-<dl>
- <dt>{{jsxref("Operators/Conditional_Operator", "(condition ? ifTrue : ifFalse)")}}</dt>
- <dd>
- <p>The conditional operator returns one of two values based on the logical value of the condition.</p>
- </dd>
-</dl>
-
-<h3 id="Assignment_operators">Assignment operators</h3>
-
-<p>An assignment operator assigns a value to its left operand based on the value of its right operand.</p>
-
-<dl>
- <dt>{{jsxref("Operators/Assignment_Operators", "=", "#Assignment")}}</dt>
- <dd>Assignment operator.</dd>
- <dt>{{jsxref("Operators/Assignment_Operators", "*=", "#Multiplication_assignment")}}</dt>
- <dd>Multiplication assignment.</dd>
- <dt>{{jsxref("Operators/Assignment_Operators", "/=", "#Division_assignment")}}</dt>
- <dd>Division assignment.</dd>
- <dt>{{jsxref("Operators/Assignment_Operators", "%=", "#Remainder_assignment")}}</dt>
- <dd>Remainder assignment.</dd>
- <dt>{{jsxref("Operators/Assignment_Operators", "+=", "#Addition_assignment")}}</dt>
- <dd>Addition assignment.</dd>
- <dt>{{jsxref("Operators/Assignment_Operators", "-=", "#Subtraction_assignment")}}</dt>
- <dd>Subtraction assignment</dd>
- <dt>{{jsxref("Operators/Assignment_Operators", "&lt;&lt;=", "#Left_shift_assignment")}}</dt>
- <dd>Left shift assignment.</dd>
- <dt>{{jsxref("Operators/Assignment_Operators", "&gt;&gt;=", "#Right_shift_assignment")}}</dt>
- <dd>Right shift assignment.</dd>
- <dt>{{jsxref("Operators/Assignment_Operators", "&gt;&gt;&gt;=", "#Unsigned_right_shift_assignment")}}</dt>
- <dd>Unsigned right shift assignment.</dd>
- <dt>{{jsxref("Operators/Assignment_Operators", "&amp;=", "#Bitwise_AND_assignment")}}</dt>
- <dd>Bitwise AND assignment.</dd>
- <dt>{{jsxref("Operators/Assignment_Operators", "^=", "#Bitwise_XOR_assignment")}}</dt>
- <dd>Bitwise XOR assignment.</dd>
- <dt>{{jsxref("Operators/Assignment_Operators", "|=", "#Bitwise_OR_assignment")}}</dt>
- <dd>Bitwise OR assignment.</dd>
- <dt>{{experimental_inline}} {{jsxref("Operators/Destructuring_assignment", "[a, b] = [1, 2]")}}<br>
- {{experimental_inline}} {{jsxref("Operators/Destructuring_assignment", "{a, b} = {a:1, b:2}")}}</dt>
- <dd>
- <p>Destructuring assignment allows you to assign the properties of an array or object to variables using syntax that looks similar to array or object literals.</p>
- </dd>
-</dl>
-
-<h3 id="Comma_operator">Comma operator</h3>
-
-<dl>
- <dt>{{jsxref("Operators/Comma_Operator", ",")}}</dt>
- <dd>The comma operator allows multiple expressions to be evaluated in a single statement and returns the result of the last expression.</dd>
-</dl>
-
-<h3 id="Non-standard_features">Non-standard features</h3>
-
-<dl>
- <dt>{{non-standard_inline}} {{jsxref("Operators/Legacy_generator_function", "Legacy generator function", "", 1)}}</dt>
- <dd>The <code>function</code> keyword can be used to define a legacy generator function inside an expression. To make the function a legacy generator, the function body should contains at least one {{jsxref("Operators/yield", "yield")}} expression.</dd>
- <dt>{{non-standard_inline}} {{jsxref("Operators/Expression_closures", "Expression closures", "", 1)}}</dt>
- <dd>The expression closure syntax is a shorthand for writing simple function.</dd>
-</dl>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('ES6', '#sec-ecmascript-language-expressions', 'ECMAScript Language: Expressions')}}</td>
- <td>{{Spec2('ES6')}}</td>
- <td>New: Spread operator, destructuring assignment, <code>super</code> keyword, Array comprehensions, Generator comprehensions</td>
- </tr>
- <tr>
- <td>{{SpecName('ES5.1', '#sec-11', 'Expressions')}}</td>
- <td>{{Spec2('ES5.1')}}</td>
- <td> </td>
- </tr>
- <tr>
- <td>{{SpecName('ES1', '#sec-11', 'Expressions')}}</td>
- <td>{{Spec2('ES1')}}</td>
- <td>Initial definition</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Operator_Precedence">Operator precedence</a></li>
-</ul>
diff --git a/files/he/web/javascript/reference/operators/operator_precedence/index.html b/files/he/web/javascript/reference/operators/operator_precedence/index.html
deleted file mode 100644
index 2f22b36031..0000000000
--- a/files/he/web/javascript/reference/operators/operator_precedence/index.html
+++ /dev/null
@@ -1,330 +0,0 @@
----
-title: Operator precedence
-slug: Web/JavaScript/Reference/Operators/Operator_Precedence
-translation_of: Web/JavaScript/Reference/Operators/Operator_Precedence
----
-<div dir="rtl">{{jsSidebar("Operators")}}</div>
-
-<p style="direction: rtl;">קדימות אופרטורים קובעת את הסדר שבו מעריכים את תוצאות האופרטורים. אופרטורים בעלי קדימות גבוהה יותר יוערכו ראשונים.</p>
-
-<p style="direction: rtl;">דוגמא נפוצה:</p>
-
-<pre class="brush: js">3 + 4 * 5 // מחזיר 23
-</pre>
-
-<p style="direction: rtl;">לאופרטור הכפל ("*") יש קדימות גבוהה יותר מאשר לאופרטור החיבור ("<code>+</code>") ולכן יוערך ראשון.</p>
-
-<h2 id="אסוציטיביות" style="direction: rtl;">אסוציטיביות</h2>
-
-<p dir="rtl">אסוציטיביות קובעת את הסדר שבו מעריכים אופרטורים בעלי קדימות זהה. למשל, חשבו על הביטוי הבא:</p>
-
-<pre class="syntaxbox" dir="rtl">a OP b OP c
-</pre>
-
-<p dir="rtl">אסוציטיביות שמאלית (משמאל לימין) פירושה שמעריכים (a OP b) OP c , ואסוציטיביות ימנית (מימין לשמאל) פירושה שמעריכים <code>a OP (b OP c)</code>. לאופרטורי השמה יש אסוציטיביות ימנית, אז אפשר לכתוב:</p>
-
-<pre class="brush: js" dir="rtl">a = b = 5;
-</pre>
-
-<p dir="rtl">ולצפות ש-a ו-b יקבלו את הערך 5. זאת משום שאופרטור ההשמה מחזיר את הערך שהושם. תחילה, הערך 5 מושם ל-b. אחר כך הערך של b מושם ל-a.</p>
-
-<h2 dir="rtl" id="טבלה">טבלה</h2>
-
-<p dir="rtl">הטבלה הבאה ממויינת לפי קדימות מהגבוה (19) לנמוך (0).</p>
-
-<table class="fullwidth-table" dir="rtl" style="text-align: right;">
- <tbody>
- <tr>
- <th dir="ltr">אופרטור</th>
- <th dir="ltr">אסוציטיביות</th>
- <th dir="ltr">סוג האופרטור</th>
- <th dir="ltr">קדימות</th>
- </tr>
- <tr>
- <td dir="ltr"><code>( … )</code></td>
- <td dir="ltr">n/a</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Grouping">Grouping</a></td>
- <td dir="ltr">19</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… . …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Property_Accessors#Dot_notation">Member Access</a></td>
- <td dir="ltr" rowspan="3">18</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… [ … ]</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Property_Accessors#Dot_notation">Computed Member Access</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>new … ( … )</code></td>
- <td dir="ltr">n/a</td>
- <td dir="ltr"><a href="/en-US/docs/JavaScript/Reference/Operators/Special/new" title="JavaScript/Reference/Operators/Special_Operators/new_Operator">new</a> (עם רשימת ארכומנטים)</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… ( <var>… </var>)</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Guide/Functions" title="JavaScript/Reference/Operators/Special_Operators/function_call">Function Call</a></td>
- <td dir="ltr" rowspan="2">17</td>
- </tr>
- <tr>
- <td dir="ltr"><code>new …</code></td>
- <td dir="ltr">ימנית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/new" title="JavaScript/Reference/Operators/Special_Operators/new_Operator">new</a> (without argument list)</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… ++</code></td>
- <td dir="ltr">n/a</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Arithmetic_Operators#Increment" title="JavaScript/Reference/Operators/Arithmetic_Operators">Postfix Increment</a></td>
- <td dir="ltr" rowspan="2">16</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… --</code></td>
- <td dir="ltr">n/a</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Arithmetic_Operators#Decrement" title="JavaScript/Reference/Operators/Arithmetic_Operators">Postfix Decrement</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>! …</code></td>
- <td dir="ltr">ימנית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Logical_Operators#Logical_NOT" title="JavaScript/Reference/Operators/Logical_Operators">Logical NOT</a></td>
- <td dir="ltr" rowspan="9">15</td>
- </tr>
- <tr>
- <td dir="ltr"><code>~ …</code></td>
- <td dir="ltr">ימנית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Bitwise_Operators#Bitwise_NOT" title="JavaScript/Reference/Operators/Bitwise_Operators">Bitwise NOT</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>+ …</code></td>
- <td dir="ltr">ימנית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Arithmetic_Operators#Unary_plus" title="JavaScript/Reference/Operators/Arithmetic_Operators">Unary Plus</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>- …</code></td>
- <td dir="ltr">ימנית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Arithmetic_Operators#Unary_negation" title="JavaScript/Reference/Operators/Arithmetic_Operators">Unary Negation</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>++ …</code></td>
- <td dir="ltr">ימנית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Arithmetic_Operators#Increment" title="JavaScript/Reference/Operators/Arithmetic_Operators">Prefix Increment</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>-- …</code></td>
- <td dir="ltr">ימנית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Arithmetic_Operators#Decrement" title="JavaScript/Reference/Operators/Arithmetic_Operators">Prefix Decrement</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>typeof …</code></td>
- <td dir="ltr">ימנית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/typeof" title="JavaScript/Reference/Operators/Special_Operators/typeof_Operator">typeof</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>void …</code></td>
- <td dir="ltr">ימנית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/void" title="JavaScript/Reference/Operators/Special_Operators/void_Operator">void</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>delete …</code></td>
- <td dir="ltr">ימנית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/delete" title="JavaScript/Reference/Operators/Special_Operators/delete_Operator">delete</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… ** …</code></td>
- <td dir="ltr">ימנית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Arithmetic_Operators#Exponentiation" title="JavaScript/Reference/Operators/Arithmetic_Operators">Exponentiation</a></td>
- <td dir="ltr" rowspan="4">14</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… * …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Arithmetic_Operators#Multiplication" title="JavaScript/Reference/Operators/Arithmetic_Operators">Multiplication</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… / …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Arithmetic_Operators#Division" title="JavaScript/Reference/Operators/Arithmetic_Operators">Division</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… % …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Arithmetic_Operators#Remainder" title="JavaScript/Reference/Operators/Arithmetic_Operators">Remainder</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… + …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Arithmetic_Operators#Addition" title="JavaScript/Reference/Operators/Arithmetic_Operators">Addition</a></td>
- <td dir="ltr" rowspan="2">13</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… - …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Arithmetic_Operators#Subtraction" title="JavaScript/Reference/Operators/Arithmetic_Operators">Subtraction</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… &lt;&lt; …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Bitwise_Operators" title="JavaScript/Reference/Operators/Bitwise_Operators">Bitwise Left Shift</a></td>
- <td dir="ltr" rowspan="3">12</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… &gt;&gt; …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Bitwise_Operators" title="JavaScript/Reference/Operators/Bitwise_Operators">Bitwise Right Shift</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… &gt;&gt;&gt; …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Bitwise_Operators" title="JavaScript/Reference/Operators/Bitwise_Operators">Bitwise Unsigned Right Shift</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… &lt; …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Comparison_Operators#Less_than_operator" title="JavaScript/Reference/Operators/Comparison_Operators">Less Than</a></td>
- <td dir="ltr" rowspan="6">11</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… &lt;= …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Comparison_Operators#Less_than__or_equal_operator" title="JavaScript/Reference/Operators/Comparison_Operators">Less Than Or Equal</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… &gt; …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Comparison_Operators#Greater_than_operator" title="JavaScript/Reference/Operators/Comparison_Operators">Greater Than</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… &gt;= …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Comparison_Operators#Greater_than_or_equal_operator" title="JavaScript/Reference/Operators/Comparison_Operators">Greater Than Or Equal</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… in …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/in" title="JavaScript/Reference/Operators/Special_Operators/in_Operator">in</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… instanceof …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/instanceof" title="JavaScript/Reference/Operators/Special_Operators/instanceof_Operator">instanceof</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… == …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Comparison_Operators#Equality" title="JavaScript/Reference/Operators/Comparison_Operators">Equality</a></td>
- <td dir="ltr" rowspan="4">10</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… != …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Comparison_Operators#Inequality" title="JavaScript/Reference/Operators/Comparison_Operators">Inequality</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… === …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Comparison_Operators#Identity" title="JavaScript/Reference/Operators/Comparison_Operators">Strict Equality</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… !== …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Comparison_Operators#Nonidentity" title="JavaScript/Reference/Operators/Comparison_Operators">Strict Inequality</a></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… &amp; …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Bitwise_Operators#Bitwise_AND" title="JavaScript/Reference/Operators/Bitwise_Operators">Bitwise AND</a></td>
- <td dir="ltr">9</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… ^ …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Bitwise_Operators#Bitwise_XOR" title="JavaScript/Reference/Operators/Bitwise_Operators">Bitwise XOR</a></td>
- <td dir="ltr">8</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… | …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Bitwise_Operators#Bitwise_OR" title="JavaScript/Reference/Operators/Bitwise_Operators">Bitwise OR</a></td>
- <td dir="ltr">7</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… &amp;&amp; …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Logical_Operators#Logical_AND" title="JavaScript/Reference/Operators/Logical_Operators">Logical AND</a></td>
- <td dir="ltr">6</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… || …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Logical_Operators#Logical_OR" title="JavaScript/Reference/Operators/Logical_Operators">Logical OR</a></td>
- <td dir="ltr">5</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… ? … : …</code></td>
- <td dir="ltr">ימנית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Conditional_Operator" title="JavaScript/Reference/Operators/Special_Operators/Conditional_Operator">Conditional</a></td>
- <td dir="ltr">4</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… = …</code></td>
- <td dir="ltr" rowspan="13">ימנית</td>
- <td dir="ltr" rowspan="13"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Assignment_Operators" title="JavaScript/Reference/Operators/Assignment_Operators">Assignment</a></td>
- <td dir="ltr" rowspan="13">3</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… += …</code></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… -= …</code></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… **= …</code></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… *= …</code></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… /= …</code></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… %= …</code></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… &lt;&lt;= …</code></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… &gt;&gt;= …</code></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… &gt;&gt;&gt;= …</code></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… &amp;= …</code></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… ^= …</code></td>
- </tr>
- <tr>
- <td dir="ltr"><code>… |= …</code></td>
- </tr>
- <tr>
- <td dir="ltr"><code>yield …</code></td>
- <td dir="ltr">ימנית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/yield" title="JavaScript/Reference/Operators/yield">yield</a></td>
- <td dir="ltr">2</td>
- </tr>
- <tr>
- <td dir="ltr"><code>...</code> …</td>
- <td dir="ltr">n/a</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Spread_operator" title="JavaScript/Reference/Operators/Spread_operator">Spread</a></td>
- <td dir="ltr">1</td>
- </tr>
- <tr>
- <td dir="ltr"><code>… , …</code></td>
- <td dir="ltr">שמאלית</td>
- <td dir="ltr"><a href="/en-US/docs/Web/JavaScript/Reference/Operators/Comma_Operator" title="JavaScript/Reference/Operators/Comma_Operator">Comma / Sequence</a></td>
- <td dir="ltr">0</td>
- </tr>
- </tbody>
-</table>
diff --git a/files/he/web/javascript/reference/statements/const/index.html b/files/he/web/javascript/reference/statements/const/index.html
deleted file mode 100644
index 98de11967b..0000000000
--- a/files/he/web/javascript/reference/statements/const/index.html
+++ /dev/null
@@ -1,133 +0,0 @@
----
-title: const
-slug: Web/JavaScript/Reference/Statements/const
-tags:
- - const
- - מה זה const
- - משתנים
-translation_of: Web/JavaScript/Reference/Statements/const
----
-<div>{{jsSidebar("Statements")}}</div>
-
-<div>מילת ההצהרה <strong><code>const</code></strong> משמשת להכזרה על משתנה קבוע שאין אפשרות לשנות את הערך שלו.<br>
- </div>
-
-<div>{{EmbedInteractiveExample("pages/js/statement-const.html")}}</div>
-
-
-
-<h2 id="תחביר">תחביר</h2>
-
-<pre class="syntaxbox">const <em>name1 = <em>value1 [</em>, <em>name2</em> = <em>value2</em><em> [</em>, ... [</em>, <em>nameN</em> = <em>valueN]]]</em>;</pre>
-
-<dl>
- <dt><code>nameN</code></dt>
- <dd>שם המשתנה.</dd>
- <dt><code>valueN</code></dt>
- <dd>הערך של המשתנה.</dd>
-</dl>
-
-<h2 id="תיאור">תיאור</h2>
-
-<p>בשפת ג'אווה סקריפט אנו משתמשים במשתנים על מנת להחזיק ערכים שונים.<br>
- הצהרה על משתנה באמצעות <strong><code>const</code></strong> הופכת אותו לקבוע ולא ניתן לשנות את הערך שלו.<br>
- הקצאת ערך למשתנה ללא הצהרה מראש הופכת אותו למשתנה גלובלי, אך בשונה מהצהרה באמצעות <strong><code>var</code></strong> הוא אינו כפוף לאובייקט האב <strong><code>window</code></strong>.<br>
- חשוב לציין שהצהרה באמצעות const לא מבצעת <a href="/he/docs/">Hoisting</a>.</p>
-
-<h2 id="דוגמאות">דוגמאות</h2>
-
-<p>הדוגמה הבאה ממחישה כיצד מתנהגים משתנים קבועים.</p>
-
-<pre class="brush:js">// NOTE: Constants can be declared with uppercase or lowercase, but a common
-// convention is to use all-uppercase letters.
-
-// define MY_FAV as a constant and give it the value 7
-const MY_FAV = 7;
-
-// this will throw an error - Uncaught TypeError: Assignment to constant variable.
-MY_FAV = 20;
-
-// MY_FAV is 7
-console.log('my favorite number is: ' + MY_FAV);
-
-// trying to redeclare a constant throws an error - Uncaught SyntaxError: Identifier 'MY_FAV' has already been declared
-const MY_FAV = 20;
-
-// the name MY_FAV is reserved for constant above, so this will fail too
-var MY_FAV = 20;
-
-// this throws an error too
-let MY_FAV = 20;
-
-// it's important to note the nature of block scoping
-if (MY_FAV === 7) {
- // this is fine and creates a block scoped MY_FAV variable
- // (works equally well with let to declare a block scoped non const variable)
- let MY_FAV = 20;
-
- // MY_FAV is now 20
- console.log('my favorite number is ' + MY_FAV);
-
- // this gets hoisted into the global context and throws an error
- var MY_FAV = 20;
-}
-
-// MY_FAV is still 7
-console.log('my favorite number is ' + MY_FAV);
-
-// throws an error - Uncaught SyntaxError: Missing initializer in const declaration
-const FOO;
-
-// const also works on objects
-const MY_OBJECT = {'key': 'value'};
-
-// Attempting to overwrite the object throws an error - Uncaught TypeError: Assignment to constant variable.
-MY_OBJECT = {'OTHER_KEY': 'value'};
-
-// However, object keys are not protected,
-// so the following statement is executed without problem
-MY_OBJECT.key = 'otherValue'; // Use Object.freeze() to make object immutable
-
-// The same applies to arrays
-const MY_ARRAY = [];
-// It's possible to push items into the array
-MY_ARRAY.push('A'); // ["A"]
-// However, assigning a new array to the variable throws an error - Uncaught TypeError: Assignment to constant variable.
-MY_ARRAY = ['B'];</pre>
-
-<h2 id="מפרט">מפרט</h2>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>{{SpecName('ES2015', '#sec-let-and-const-declarations', 'Let and Const Declarations')}}</td>
- <td>{{Spec2('ES2015')}}</td>
- <td>Initial definition.</td>
- </tr>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-let-and-const-declarations', 'Let and Const Declarations')}}</td>
- <td>{{Spec2('ESDraft')}}</td>
- <td>No changes.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תאימות_דפדפן">תאימות דפדפן</h2>
-
-
-
-<p>{{Compat("javascript.statements.const")}}</p>
-
-<h2 id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li><a href="https://developer.mozilla.org/he/docs/Web/JavaScript/Reference/Statements/var"><code>var</code></a></li>
- <li><a href="https://developer.mozilla.org/he/docs/Web/JavaScript/Reference/Statements/let"><code>let</code></a></li>
-</ul>
diff --git a/files/he/web/javascript/reference/statements/for...of/index.html b/files/he/web/javascript/reference/statements/for...of/index.html
deleted file mode 100644
index 86edb2f69e..0000000000
--- a/files/he/web/javascript/reference/statements/for...of/index.html
+++ /dev/null
@@ -1,269 +0,0 @@
----
-title: for...of
-slug: Web/JavaScript/Reference/Statements/for...of
-translation_of: Web/JavaScript/Reference/Statements/for...of
----
-<div>{{jsSidebar("Statements")}}</div>
-
-<div> </div>
-
-<div>הצהרת <strong><code>for...of </code></strong>יוצרת לולאה ע"ג<code> </code><a href="/en-US/docs/Web/JavaScript/Reference/Iteration_protocols#iterable">iterable objects</a> (שכולל {{jsxref("Array")}}, {{jsxref("Map")}}, {{jsxref("Set")}}, {{jsxref("String")}}, {{jsxref("TypedArray")}}, <a href="/en-US/docs/Web/JavaScript/Reference/Functions_and_function_scope/arguments">arguments</a> object וכן הלאה..),</div>
-
-<div>invoking a custom iteration hook with statements to be executed for the value of each distinct property.</div>
-
-<h2 id="Syntax">Syntax</h2>
-
-<pre class="syntaxbox">for (<em>variable</em> of <em>iterable</em>) {
- <em>statement
-</em>}
-</pre>
-
-<dl>
- <dt><code>variable</code></dt>
- <dd>בכל איטרציה, ערך ה property הנוכחי של <em>iterable </em>מוקצה ל <em>variable</em></dd>
- <dt>iterable</dt>
- <dd>אובייקט עם properties ברי איטרציה</dd>
-</dl>
-
-<h3 id="לדוגמא"><span style="font-size: 14px; letter-spacing: normal;">לדוגמא:</span></h3>
-
-<h3 id="איטרציה_עג_jsxref(Array)">איטרציה ע"ג {{jsxref("Array")}}</h3>
-
-<pre class="brush:js">let iterable = [10, 20, 30];
-
-for (let value of iterable) {
- console.log(value);
-}
-// 10
-// 20
-// 30
-</pre>
-
-<p>אפשר להשתמש ג"כ ב <code><a href="/en-US/docs/Web/JavaScript/Reference/Statements/const">const</a> </code>במקום <code><a href="/en-US/docs/Web/JavaScript/Reference/Statements/let">let</a> </code>באם אתה לא משנה את ערך המשתנה בתוך הבלוק.</p>
-
-<p> </p>
-
-<p>איטרציה ע"ג {{jsxref("String")}}</p>
-
-<pre class="brush:js">let iterable = "boo";
-
-for (let value of iterable) {
- console.log(value);
-}
-// "b"
-// "o"
-// "o"
-</pre>
-
-<h3 id="Iterating_over_a_jsxref(TypedArray)">Iterating over a {{jsxref("TypedArray")}}</h3>
-
-<pre class="brush:js">let iterable = new Uint8Array([0x00, 0xff]);
-
-for (let value of iterable) {
- console.log(value);
-}
-// 0
-// 255
-</pre>
-
-<h3 id="Iterating_over_a_jsxref(Map)">Iterating over a {{jsxref("Map")}}</h3>
-
-<pre class="brush:js">let iterable = new Map([["a", 1], ["b", 2], ["c", 3]]);
-
-for (let entry of iterable) {
- console.log(entry);
-}
-// [a, 1]
-// [b, 2]
-// [c, 3]
-
-for (let [key, value] of iterable) {
- console.log(value);
-}
-// 1
-// 2
-// 3
-</pre>
-
-<h3 id="Iterating_over_a_jsxref(Set)">Iterating over a {{jsxref("Set")}}</h3>
-
-<pre class="brush:js">let iterable = new Set([1, 1, 2, 2, 3, 3]);
-
-for (let value of iterable) {
- console.log(value);
-}
-// 1
-// 2
-// 3
-</pre>
-
-<h3 id="Iterating_over_a_DOM_collection">Iterating over a DOM collection</h3>
-
-<p>Iterating over DOM collections like {{domxref("NodeList")}}: the following example adds a <code>read</code> class to paragraphs that are direct descendants of an article:</p>
-
-<pre class="brush:js">// Note: This will only work in platforms that have
-// implemented NodeList.prototype[Symbol.iterator]
-let articleParagraphs = document.querySelectorAll("article &gt; p");
-
-for (let paragraph of articleParagraphs) {
- paragraph.classList.add("read");
-}
-</pre>
-
-<h3 id="Iterating_over_generators">Iterating over generators</h3>
-
-<p>You can also iterate over <a href="/en-US/docs/Web/JavaScript/Reference/Statements/function*">generators</a>:</p>
-
-<pre class="brush:js">function* fibonacci() { // a generator function
- let [prev, curr] = [1, 1];
- while (true) {
- [prev, curr] = [curr, prev + curr];
- yield curr;
- }
-}
-
-for (let n of fibonacci()) {
- console.log(n);
- // truncate the sequence at 1000
- if (n &gt;= 1000) {
- break;
- }
-}
-</pre>
-
-<h3 id="Iterating_over_other_iterable_objects">Iterating over other iterable objects</h3>
-
-<p>You can also iterate over an object that explicitly implements <a href="/en-US/docs/Web/JavaScript/Reference/Iteration_protocols#iterable">iterable</a> protocol:</p>
-
-<pre class="brush:js">var iterable = {
- [Symbol.iterator]() {
- return {
- i: 0,
- next() {
- if (this.i &lt; 3) {
- return { value: this.i++, done: false };
- }
- return { value: undefined, done: true };
- }
- };
- }
-};
-
-for (var value of iterable) {
- console.log(value);
-}
-// 0
-// 1
-// 2
-</pre>
-
-<h3 id="Difference_between_for...of_and_for...in">Difference between <code>for...of</code> and <code>for...in</code></h3>
-
-<p>The <code><a href="/en-US/docs/Web/JavaScript/Reference/Statements/for...in">for...in</a></code> loop will iterate over all enumerable properties of an object.</p>
-
-<p>The <code>for...of</code> syntax is specific to <strong>collections</strong>, rather than all objects. It will iterate in this manner over the elements of any collection that has a <code>[Symbol.iterator]</code> property.</p>
-
-<p>The following example shows the difference between a <code>for...of</code> loop and a <code>for...in</code> loop.</p>
-
-<pre class="brush:js">Object.prototype.objCustom = function () {};
-Array.prototype.arrCustom = function () {};
-
-let iterable = [3, 5, 7];
-iterable.foo = "hello";
-
-for (let i in iterable) {
- console.log(i); // logs 0, 1, 2, "foo", "arrCustom", "objCustom"
-}
-
-for (let i of iterable) {
- console.log(i); // logs 3, 5, 7
-}
-</pre>
-
-<h2 id="Specifications">Specifications</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('ES6', '#sec-for-in-and-for-of-statements', 'for...of statement')}}</td>
- <td>{{Spec2('ES6')}}</td>
- <td>Initial definition.</td>
- </tr>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-for-in-and-for-of-statements', 'for...of statement')}}</td>
- <td>{{Spec2('ESDraft')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="Browser_compatibility">Browser compatibility</h2>
-
-<p>{{CompatibilityTable}}</p>
-
-<div id="compat-desktop">
-<table class="compat-table">
- <tbody>
- <tr>
- <th>Feature</th>
- <th>Chrome</th>
- <th>Firefox (Gecko)</th>
- <th>Edge</th>
- <th>Opera</th>
- <th>Safari</th>
- </tr>
- <tr>
- <td>Basic support</td>
- <td>{{CompatChrome(38)}} <a href="#Chrome_note_1">[1]</a><br>
- {{CompatChrome(51)}} <a href="#Chrome_note_3">[3]</a></td>
- <td>{{CompatGeckoDesktop("13")}} <a href="#Gecko_note_2">[2]</a></td>
- <td>12</td>
- <td>25</td>
- <td>7.1</td>
- </tr>
- </tbody>
-</table>
-</div>
-
-<div id="compat-mobile">
-<table class="compat-table">
- <tbody>
- <tr>
- <th>Feature</th>
- <th>Android</th>
- <th>Chrome for Android</th>
- <th>Firefox Mobile (Gecko)</th>
- <th>IE Mobile</th>
- <th>Opera Mobile</th>
- <th>Safari Mobile</th>
- </tr>
- <tr>
- <td>Basic support</td>
- <td>5.1</td>
- <td>{{CompatChrome(38)}} [1]</td>
- <td>{{CompatGeckoMobile("13")}} [2]</td>
- <td>{{CompatNo}}</td>
- <td>{{CompatUnknown}}</td>
- <td>8</td>
- </tr>
- </tbody>
-</table>
-</div>
-
-<p><a name="Chrome_note_1">[1]</a> From Chrome 29 to Chrome 37 this feature was available behind a preference. In chrome://flags/#enable-javascript-harmony, activate the entry “Enable Experimental JavaScript”.</p>
-
-<p><a name="Gecko_note_2">[2]</a> Prior Firefox 51, using the <code>for...of</code> loop construct with the <code><a href="/en-US/docs/Web/JavaScript/Reference/Statements/const">const</a></code> keyword threw a {{jsxref("SyntaxError")}} ("missing = in const declaration"). This has been fixed ({{bug(1101653)}}).</p>
-
-<p><a name="Chrome_note_3">[3]</a> Support for iteration of objects was added in Chrome 51.</p>
-
-<h2 id="See_also">See also</h2>
-
-<ul>
- <li>{{jsxref("Array.prototype.forEach()")}}</li>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map/forEach">Map.prototype.forEach()</a></li>
-</ul>
diff --git a/files/he/web/javascript/reference/statements/function_star_/index.html b/files/he/web/javascript/reference/statements/function_star_/index.html
deleted file mode 100644
index a72a927859..0000000000
--- a/files/he/web/javascript/reference/statements/function_star_/index.html
+++ /dev/null
@@ -1,212 +0,0 @@
----
-title: function*
-slug: Web/JavaScript/Reference/Statements/function*
-translation_of: Web/JavaScript/Reference/Statements/function*
----
-<div>{{jsSidebar("Statements")}}</div>
-
-<p> </p>
-
-<p>הצהרת <code><strong>function*</strong></code> (מילת <code>function</code> ולאחריה כוכבית) מגדירה <em>פונקצית גנרטור</em>, אשר מחזירה אובייקט {{jsxref("Global_Objects/Generator","Generator")}}.</p>
-
-<div>{{EmbedInteractiveExample("pages/js/statement-functionasterisk.html")}}</div>
-
-
-
-<div class="noinclude">
-<p>ניתן גם להגדיר פונקציות גנרטור על-ידי שימוש בבנאי {{jsxref("GeneratorFunction")}}, או בתחביר של ביטוי פונקציה.</p>
-</div>
-
-<h2 id="תחביר">תחביר</h2>
-
-<pre class="syntaxbox">function* <em>name</em>([<em>param</em>[, <em>param</em>[, ... <em>param</em>]]]) {
- <em>statements</em>
-}
-</pre>
-
-<dl>
- <dt><code>name</code></dt>
- <dd>שם הפונקציה.</dd>
-</dl>
-
-<dl>
- <dt><code>param</code></dt>
- <dd>השם של פרמטר רשמי של הפונקציה.</dd>
-</dl>
-
-<dl>
- <dt><code>statements</code></dt>
- <dd>הפקודות המרכיבות את גוף הפונקציה.</dd>
-</dl>
-
-<h2 id="תיאור">תיאור</h2>
-
-<p>גנרטורים הינם פונקציות שניתן לצאת מהן ולאחר מכן להיכנס אליהן מחדש. ההקשר שלהם (קשירת המשתנים) יישמר לאורך הכניסות מחדש.<br>
- <br>
- גנרטורים ב- JavaScript -- במיוחד בשילוב עם Promises -- הינם כלי חזר מאוד לתכנות אסינכרוני, כיוון שהם מתווכים -- ואפילו מחסלים לחלוטין -- את הבעיות עם קריאות חוזרות, כגון <a href="http://callbackhell.com/">Callback Hell</a> ו- <a href="https://frontendmasters.com/courses/rethinking-async-js/callback-problems-inversion-of-control/">Inversion of Control</a>.<br>
- תבנית זו הינה הבסיס לפונקציות <code><a href="https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Statements/async_function">async</a></code>.</p>
-
-<p>קריאה לפונקצית גנרטור לא מריצה את גוף הפונקציה מיידית; במקום זאת, מוחזר אובייקט <a href="/he/docs/Web/JavaScript/Reference/Iteration_protocols#iterator">איטרטור</a> לפונקציה. כאשר המתודה <code>()next</code> של האיטרטור נקראת, גוף הפונקציה רץ עד לביטוי ה-{{jsxref("Operators/yield", "yield")}} הראשון, אשר מציין את הערך שיוחזר לאיטרטור, או העברה לפונקציה יוצרת אחרת על-ידי שימוש {{jsxref("Operators/yield*", "*yield")}}. מתודת ה- <code>()next</code> מחזירה אובייקט עם שדה <code>value</code>, המכיל את הערך המיוצר ושדה <code>done</code> בכעל ערך בוליאני, המציין האם הגנרטור יצר את הערך האחרון. קריאה למתודת <code>()next</code> עם ארגומנט תמשיך את ריצת פונקציית הגנרטור, תוך החלפת ביטוי ה- <code>yield</code> בו הריצה הופסקה עם הארגומנט מתוך <code>()next</code>.</p>
-
-<p>פקודת <code>return</code> בתוך גנרטור, כאשר הוא רץ, תגרום לגנרטור לסיים (כלומר שדה ה- <code>done</code> המוחזר יהיה בעל <code>true</code>). אם ערך מוחזר, הוא יהיה בשדה <code>value</code> של האובייקט המוחזר על-ידי הגנרטור.<br>
- בדומה לפקודת ה- <code>return</code>, שגיאה שתיזרק בתוך הגנרטור תביא לסיום הגנרטור -- אלא אם היא תיתפס בגוף הגנרטור.<br>
- כאשר גנרטור מסתיים, קריאות נוספות ל- <code>()next</code> לא יגרמו לריצה כלשהי של קוד הגנרטור. הן רק יחזירו אובייקט בצורה זו: <code>{value: undefined, done: true}</code>.</p>
-
-<h2 id="דוגמאות">דוגמאות</h2>
-
-<h3 id="דוגמה_פשוטה">דוגמה פשוטה</h3>
-
-<pre class="brush: js">function* idMaker() {
- var index = 0;
- while (index &lt; index+1)
- yield index++;
-}
-
-var gen = idMaker();
-
-console.log(gen.next().value); // 0
-console.log(gen.next().value); // 1
-console.log(gen.next().value); // 2
-console.log(gen.next().value); // 3
-// ...</pre>
-
-<h3 id="דוגמה_עם_*yield">דוגמה עם *yield</h3>
-
-<pre class="brush: js">function* anotherGenerator(i) {
- yield i + 1;
- yield i + 2;
- yield i + 3;
-}
-
-function* generator(i) {
- yield i;
- yield* anotherGenerator(i);
- yield i + 10;
-}
-
-var gen = generator(10);
-
-console.log(gen.next().value); // 10
-console.log(gen.next().value); // 11
-console.log(gen.next().value); // 12
-console.log(gen.next().value); // 13
-console.log(gen.next().value); // 20
-</pre>
-
-<h3 id="העברת_ארגומנטים_לגנרטורים">העברת ארגומנטים לגנרטורים</h3>
-
-<pre class="brush: js">function* logGenerator() {
- console.log(0);
- console.log(1, yield);
- console.log(2, yield);
- console.log(3, yield);
-}
-
-var gen = logGenerator();
-
-// <span dir="rtl">הקריאה הראשונה ל- next מתבצעת מתחילת הפונקציה</span>
-// <span dir="rtl">עד שהיא מגיעה לפקודת yield הראשונה</span>
-gen.next(); // 0
-gen.next('pretzel'); // 1 pretzel
-gen.next('california'); // 2 california
-gen.next('mayonnaise'); // 3 mayonnaise
-</pre>
-
-<h3 id="פקודת_return_בתוך_גנרטור">פקודת return בתוך גנרטור</h3>
-
-<pre class="brush: js">function* yieldAndReturn() {
- yield "Y";
- return "R";
- yield "unreachable";
-}
-
-var gen = yieldAndReturn()
-console.log(gen.next()); // { value: "Y", done: false }
-console.log(gen.next()); // { value: "R", done: true }
-console.log(gen.next()); // { value: undefined, done: true }
-</pre>
-
-<h3 id="לא_ניתן_ליצור_אובייקט_גנרטור">לא ניתן ליצור אובייקט גנרטור</h3>
-
-<pre class="brush: js">function* f() {}
-var obj = new f; // throws "TypeError: f is not a constructor
-</pre>
-
-<h3 id="גנרטורים_המוגדרים_בתוך_ביטוי">גנרטורים המוגדרים בתוך ביטוי</h3>
-
-<pre class="brush: js">const foo = function* () {
-  yield 10;
-  yield 20;
-};
-
-const bar = foo();
-console.log(bar.next()); // {value: 10, done: false}</pre>
-
-<h2 id="מפרטים">מפרטים</h2>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>{{SpecName('ES2015', '#sec-generator-function-definitions', 'function*')}}</td>
- <td>{{Spec2('ES2015')}}</td>
- <td>הגדרה ראשונית.</td>
- </tr>
- <tr>
- <td>{{SpecName('ES2016', '#sec-generator-function-definitions', 'function*')}}</td>
- <td>{{Spec2('ES2016')}}</td>
- <td>שונה, כך  תהיה מלכודת שבגנרטורים לא [[Construct]] ויזרקו שגיאה בשימוש עם <code>new</code>.</td>
- </tr>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-generator-function-definitions', 'function*')}}</td>
- <td>{{Spec2('ESDraft')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תאימות_לדפדפנים">תאימות לדפדפנים</h2>
-
-<div>
-
-
-<p>{{Compat("javascript.statements.generator_function")}}</p>
-</div>
-
-<h2 id="הערות_ספציפיות_ל-_Firefox">הערות ספציפיות ל- Firefox</h2>
-
-<h4 id="גנרטורים_ואיטרטורים_ב-_Firefox_לפני_גרסה_26">גנרטורים ואיטרטורים ב- Firefox לפני גרסה 26</h4>
-
-<p>גרסאות Firefox ישנות יותר מממשות הגדרת גנרטורים ישנה יותר. בגרסה הקודמת גנרטורים הוגדרו על-ידי שימוש במילת <code>function</code> רגילה (ללא כוכבית), בין היתר. ראה <a href="/he/docs/Web/JavaScript/Reference/Statements/Legacy_generator_function">פונקציה יוצרת מסורתית </a>למידע נוסף.</p>
-
-<h4 id="אובייקט_IteratorResult_מוחזר_במקום_זריקת_שגיאה">אובייקט <code>IteratorResult</code> מוחזר במקום זריקת שגיאה</h4>
-
-<p>החל מ- Gecko 29 {{geckoRelease(29)}}, הפונקציה היוצרת המלאה כבר אינה זורקת {{jsxref("TypeError")}} "generator has already finished". במקום זאת, היא מחזירה אובייקט <code>IteratorResult</code> כדוגמת <code>{ value: undefined, done: true }</code> ({{bug(958951)}}).</p>
-
-<h2 id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li>{{jsxref("Operators/function*", "function* expression")}}</li>
- <li>אובייקט {{jsxref("GeneratorFunction")}}</li>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Iteration_protocols">Iteration protocols</a></li>
- <li>{{jsxref("Operators/yield", "yield")}}</li>
- <li>{{jsxref("Operators/yield*", "*yield")}}</li>
- <li>{{jsxref("Function")}} object</li>
- <li>{{jsxref("Statements/function", "function declaration")}}</li>
- <li>{{jsxref("Operators/function", "function expression")}}</li>
- <li>{{jsxref("Functions_and_function_scope", "Functions and function scope")}}</li>
- <li>Other web resources:
- <ul>
- <li><a href="http://facebook.github.io/regenerator/">Regenerator</a> an ES2015 generator compiler to ES5</li>
- <li><a href="http://www.youtube.com/watch?v=qbKWsbJ76-s">Forbes Lindesay: Promises and Generators: control flow utopia -- JSConf EU 2013</a></li>
- <li><a href="https://github.com/mozilla/task.js">Task.js</a></li>
- <li><a href="https://github.com/getify/You-Dont-Know-JS/blob/master/async%20%26%20performance/ch4.md#iterating-generators-asynchronously">Iterating generators asynchronously</a></li>
- </ul>
- </li>
-</ul>
diff --git a/files/he/web/javascript/reference/statements/index.html b/files/he/web/javascript/reference/statements/index.html
deleted file mode 100644
index 2869ba1ce5..0000000000
--- a/files/he/web/javascript/reference/statements/index.html
+++ /dev/null
@@ -1,148 +0,0 @@
----
-title: Statements and declarations
-slug: Web/JavaScript/Reference/Statements
-tags:
- - JavaScript
- - NeedsTranslation
- - Reference
- - TopicStub
- - statements
-translation_of: Web/JavaScript/Reference/Statements
----
-<div dir="rtl">{{jsSidebar("Statements")}}</div>
-
-<div dir="rtl">יישומי ג'אווה סקריפט מורכבים ממשפטים בעלי תחביר מתאים (syntax).</div>
-
-<div dir="rtl">משפט אחד יכול להתפרס על גבי מספר שורות.</div>
-
-<div dir="rtl">מספר משפטים יכולים להופיע על גבי שורה אחת אם בין משפט למשפט מפריד הסמן ";".</div>
-
-<div dir="rtl">משפט הוא לא מילת מפתח אלא כמה מילות מפתח המאורגנות יחד.</div>
-
-<div dir="rtl"> </div>
-
-<h2 dir="rtl" id="משפטים_והצהרות_לפי_קטגוריה">משפטים והצהרות לפי קטגוריה</h2>
-
-<p dir="rtl"><em>לרשימה אלפבתית ראה סרגל בצד שמאל</em></p>
-
-<h3 dir="rtl" id="זרימת_תהליך">זרימת תהליך</h3>
-
-<dl>
- <dt dir="rtl">{{jsxref("Statements/block", "Block")}}</dt>
- <dd dir="rtl">משפט בלוק נועד לסידור של 0 או יותר משפטים יחד.<br>
- בלוק תחום בין שני סוגריים מסולסלים.</dd>
- <dt dir="rtl">{{jsxref("Statements/break", "break")}}</dt>
- <dd dir="rtl">משפט break עוצר את הלולאה, משפט switch או משפט סיווג (label statement) ומעביר את ריצת התוכנה למשפט שמגיע אחרי המשפט שנעצר.</dd>
- <dt dir="rtl">{{jsxref("Statements/continue", "continue")}}</dt>
- <dd dir="rtl">משפט continue עוצר את האיטרציה הנוכחית\מסווגת של הלולאה הנוכחית וממשיך לאיטרציה הבאה בלולאה.</dd>
- <dt dir="rtl">{{jsxref("Statements/Empty", "Empty")}}</dt>
- <dd dir="rtl">משפט empty נועד לשימוש כמשפט ריק במקומות בהם התחביר של ג'אווה סקריפט מצפה למשפט.</dd>
- <dt dir="rtl">{{jsxref("Statements/if...else", "if...else")}}</dt>
- <dd dir="rtl">משפטי if else מריצים משפטים בהתאם לתנאים מסויימים. אם תנאי מסויים לא מתקיים, יכול לרוץ משפט אחר.</dd>
- <dt dir="rtl">{{jsxref("Statements/switch", "switch")}}</dt>
- <dd dir="rtl">משפט switch מכיל ביטוי מסויים שבהתאם לערך שלו נבחרת פסקת case והמשפטים שבה מורצים.</dd>
- <dt dir="rtl">{{jsxref("Statements/throw", "throw")}}</dt>
- <dd dir="rtl">משפט throw זורק שגיאה מותאמת אישית.</dd>
- <dt dir="rtl">{{jsxref("Statements/try...catch", "try...catch")}}</dt>
- <dd dir="rtl">משפט try/catch מנסה להריץ בלוק מסויים, ומגדיר תגובה במקרה שנזרקת שגיאה.</dd>
-</dl>
-
-<h3 dir="rtl" id="הצהרות"> הצהרות</h3>
-
-<dl>
- <dt dir="rtl">{{jsxref("Statements/var", "var")}}</dt>
- <dd dir="rtl">המילה var מצהירה על משתנה חדש ומאפשרת לתת לו ערך ראשוני.</dd>
- <dt dir="rtl">{{experimental_inline}} {{jsxref("Statements/let", "let")}}</dt>
- <dd dir="rtl">המילה let מצהירה על משתנה חדש ומקומי לבלוק שבו הוצהר (בניגוד ל var שנמצא בתחום הגלובאלי (global scope), אפשר לתת ערך ראשוני בזמן ההצהרה.</dd>
- <dt dir="rtl">{{experimental_inline}} {{jsxref("Statements/const", "const")}}</dt>
- <dd dir="rtl">המילה const מצהירה על קבוע (constant) לקריאה בלבד.</dd>
-</dl>
-
-<h3 dir="rtl" id="פונקציות_ומחלקות">פונקציות ומחלקות</h3>
-
-<dl>
- <dt dir="rtl">{{jsxref("Statements/function", "function")}}</dt>
- <dd dir="rtl">המילה function מצהירה על פונקציה עם הפרמטרים שצויינו.</dd>
- <dt dir="rtl">{{experimental_inline}} {{jsxref("Statements/function*", "function*")}}</dt>
- <dd dir="rtl">פונקציות מחוללות המאפשרות כתיבה פשוטה יותר של איטרטורים.</dd>
- <dt dir="rtl">{{jsxref("Statements/return", "return")}}</dt>
- <dd dir="rtl">המילה return מציינת את הערך שהפונקציה מחזירה.</dd>
- <dt dir="rtl">{{experimental_inline}} {{jsxref("Statements/class", "class")}}</dt>
- <dd dir="rtl">המילה class מגדירה מחלקה.</dd>
-</dl>
-
-<h3 dir="rtl" id="Iterations">Iterations</h3>
-
-<dl>
- <dt dir="rtl">{{jsxref("Statements/do...while", "do...while")}}</dt>
- <dd dir="rtl">משפט do...while יוצר לולאה שמריצה משפט מסויים עד שהתנאי שבה הופך לשלילי. <br>
- בהרצה הראשונה המשפט מורץ בלי קשר לערך התנאי ורק לאחר מכן נבדק לפני כל הרצה מחדש. </dd>
- <dt dir="rtl">{{jsxref("Statements/for", "for")}}</dt>
- <dd dir="rtl">משפט for יוצר לולאה שמורכבת משלושה ביטויים (אופציונאליים) התחומים בסוגריים ומופרדים ע"י סמן ";", שלאחריהם מורצים המשפטים שבתוך הלולאה.</dd>
- <dt dir="rtl">{{deprecated_inline}} {{non-standard_inline()}} {{jsxref("Statements/for_each...in", "for each...in")}}</dt>
- <dd dir="rtl">משפט for each...in עובר על כל הערכים של התכונות באובייקט מסויים ומריץ על כל אחת את המשפט שנמצא בלולאה.</dd>
- <dt dir="rtl">{{jsxref("Statements/for...in", "for...in")}}</dt>
- <dd dir="rtl">משפט for...in עובר על כל התכונות של אובייקט מסויים, בסדר שרירותי.<br>
- על תכונה יכולים לרוץ משפטים.</dd>
- <dt dir="rtl">{{experimental_inline}} {{jsxref("Statements/for...of", "for...of")}}</dt>
- <dd dir="rtl">משפט for...of עובר על אובייקטים הנתנים לאיטרציה (מערכים, אובייקטים, איטרטורים ומחוללים) ויוצר איטרציה מותאמת לכל אחד מהאובייקטים שבה יכולים לרוץ משפטים מסויימים על הערך של כל תכונה באובייקט.</dd>
- <dt dir="rtl">{{jsxref("Statements/while", "while")}}</dt>
- <dd dir="rtl">משפט while יוצר לולאה שמריצה משפט מסויים כל עוד התנאי שבה חיובי. <br>
- התנאי מורץ לפני כל הרצה.</dd>
-</dl>
-
-<h3 dir="rtl" id="Others">Others</h3>
-
-<dl>
- <dt dir="rtl">{{jsxref("Statements/debugger", "debugger")}}</dt>
- <dd dir="rtl">Invokes any available debugging functionality. If no debugging functionality is available, this statement has no effect.</dd>
- <dt dir="rtl">{{experimental_inline}} {{jsxref("Statements/export", "export")}}</dt>
- <dd dir="rtl">Used to export functions to make them available for imports in external modules, another scripts.</dd>
- <dt dir="rtl">{{experimental_inline}} {{jsxref("Statements/import", "import")}}</dt>
- <dd dir="rtl">Used to import functions exported from an external module, another script.</dd>
- <dt dir="rtl">{{jsxref("Statements/label", "label")}}</dt>
- <dd dir="rtl">Provides a statement with an identifier that you can refer to using a <code>break</code> or <code>continue</code> statement.</dd>
-</dl>
-
-<dl>
- <dt dir="rtl">{{deprecated_inline}} {{jsxref("Statements/with", "with")}}</dt>
- <dd dir="rtl">Extends the scope chain for a statement.</dd>
-</dl>
-
-<h2 dir="rtl" id="Specifications">Specifications</h2>
-
-<table class="standard-table" dir="rtl">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('ES6', '#sec-ecmascript-language-statements-and-declarations', 'ECMAScript Language: Statements and Declarations')}}</td>
- <td>{{Spec2('ES6')}}</td>
- <td>New: function*, let, for...of, yield, class</td>
- </tr>
- <tr>
- <td>{{SpecName('ES5.1', '#sec-12', 'Statements')}}</td>
- <td>{{Spec2('ES5.1')}}</td>
- <td> </td>
- </tr>
- <tr>
- <td>{{SpecName('ES3', '#sec-12', 'Statements')}}</td>
- <td>{{Spec2('ES3')}}</td>
- <td> </td>
- </tr>
- <tr>
- <td>{{SpecName('ES1', '#sec-12', 'Statements')}}</td>
- <td>{{Spec2('ES1')}}</td>
- <td>Initial definition</td>
- </tr>
- </tbody>
-</table>
-
-<h2 dir="rtl" id="See_also">See also</h2>
-
-<ul>
- <li dir="rtl"><a href="/en-US/docs/Web/JavaScript/Reference/Operators">Operators</a></li>
-</ul>
diff --git a/files/he/web/javascript/reference/statements/return/index.html b/files/he/web/javascript/reference/statements/return/index.html
deleted file mode 100644
index dea3cb868f..0000000000
--- a/files/he/web/javascript/reference/statements/return/index.html
+++ /dev/null
@@ -1,151 +0,0 @@
----
-title: return
-slug: Web/JavaScript/Reference/Statements/return
-translation_of: Web/JavaScript/Reference/Statements/return
----
-<div>{{jsSidebar("Statements")}}</div>
-
-<p>הצהרה באמצעות <strong><code>return</code></strong> מתבצעת בעת סיום הפונקציה, גורמת לעצירתה ומציינת ערך שיש להחזיר למבקש הפונקציה.</p>
-
-<div>{{EmbedInteractiveExample("pages/js/statement-return.html")}}</div>
-
-
-
-<h2 id="תחביר">תחביר</h2>
-
-<pre class="syntaxbox">return [[expression]]; </pre>
-
-<dl>
- <dt><code>expression</code></dt>
- <dd>הביטוי שערכו יוחזר. במידה והביטוי לא הוזכר, הערך <strong><code>undefined</code></strong> יוחזר במקומו.</dd>
-</dl>
-
-<h2 id="תיאור">תיאור</h2>
-
-<p>השימוש בהצהרה <strong><code>return</code></strong> בגוף הפונקציה, יפסיק את תהליך הריצה שלה.<br>
- לדוגמה, לפונקציה <code>()square</code> ארגומנט בשם x, כאשר x יהיה מספר הפונקציה תחזיר את הערך של הארגומנט כפול עצמו.</p>
-
-<pre class="brush: js">function square(x) {
- return x * x;
-}
-var demo = square(3);
-// demo will equal 9
-</pre>
-
-<p>במידה וארגומנט חסר, הערך שיוחזר יהיה <strong><code>undefined</code></strong>. <br>
- הצהרות ה-<strong><code>return</code></strong> הבאות מפסיקות את הריצה של הפונקציה:</p>
-
-<pre class="brush: js">return;
-return true;
-return false;
-return x;
-return x + y / 3;
-</pre>
-
-<h3 id="הוספת_נקודה_פסיק_באופן_אוטומטי">הוספת נקודה פסיק באופן אוטומטי</h3>
-
-<p>להצהרה באמצעות <strong><code>return</code></strong> מתווספת באופן אוטומטי נקודה פסיק (ASI).<br>
- אין לקשר בין שורת ההצהרה של <strong><code>return</code></strong> לביטוי .</p>
-
-<pre class="brush: js">return
-a + b;
-</pre>
-
-<pre class="brush: js">return;
-a + b;
-</pre>
-
-<p>כדי להימנע ממצב של הוספת נקודה פסיק באופן אוטומטי, יש להוסיף סוגריים באופן הבא:</p>
-
-<pre class="brush: js">return (
-  a + b
-);
-</pre>
-
-<h2 id="דוגמאות">דוגמאות</h2>
-
-<h3 id="עצירת_הפונקציה">עצירת הפונקציה</h3>
-
-<p>הפונקציה נעצרת מיד בעת הקריאה ל-<strong><code>return</code></strong>.</p>
-
-<pre class="brush: js">function counter() {
- for (var count = 1; ; count++) { // infinite loop
- console.log(count + 'A'); // until 5
- if (count === 5) {
- return;
- }
- console.log(count + 'B'); // until 4
- }
- console.log(count + 'C'); // never appears
-}
-
-counter();
-
-// Output:
-// 1A
-// 1B
-// 2A
-// 2B
-// 3A
-// 3B
-// 4A
-// 4B
-// 5A
-</pre>
-
-<h3 id="החזרת_פונקציה">החזרת פונקציה</h3>
-
-<p>ראו את המאמר הבא בנושא <a href="/en-US/docs/Web/JavaScript/Closures">Closures</a>.</p>
-
-<pre class="brush: js">function magic() {
- return function calc(x) { return x * 42; };
-}
-
-var answer = magic();
-answer(1337); // 56154
-</pre>
-
-<h2 id="מפרט">מפרט</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('ES1')}}</td>
- <td>{{Spec2('ES1')}}</td>
- <td>Initial definition.</td>
- </tr>
- <tr>
- <td>{{SpecName('ES5.1', '#sec-12.9', 'Return statement')}}</td>
- <td>{{Spec2('ES5.1')}}</td>
- <td> </td>
- </tr>
- <tr>
- <td>{{SpecName('ES6', '#sec-return-statement', 'Return statement')}}</td>
- <td>{{Spec2('ES6')}}</td>
- <td> </td>
- </tr>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-return-statement', 'Return statement')}}</td>
- <td>{{Spec2('ESDraft')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תאימות_דפדפן">תאימות דפדפן</h2>
-
-
-
-<p>{{Compat("javascript.statements.return")}}</p>
-
-<h2 id="ראו_גם">ראו גם</h2>
-
-<ul>
- <li><a href="/en-US/docs/Web/JavaScript/Reference/Functions_and_function_scope" title="En/Core_JavaScript_1.5_Reference/Functions">Functions</a></li>
- <li><a href="/en-US/docs/Web/JavaScript/Closures">Closures</a></li>
-</ul>
diff --git a/files/he/web/javascript/reference/statements/var/index.html b/files/he/web/javascript/reference/statements/var/index.html
deleted file mode 100644
index 64020dee3e..0000000000
--- a/files/he/web/javascript/reference/statements/var/index.html
+++ /dev/null
@@ -1,171 +0,0 @@
----
-title: var
-slug: Web/JavaScript/Reference/Statements/var
-tags:
- - hoisted
- - הכרזה
- - משתנה
-translation_of: Web/JavaScript/Reference/Statements/var
----
-<div>{{jsSidebar("Statements")}}</div>
-
-<p>מילת ההצהרה <strong><code>var</code></strong> משמשת להכזרה על משתנה.</p>
-
-<div>{{EmbedInteractiveExample("pages/js/statement-var.html")}}</div>
-
-
-
-<h2 id="תחביר">תחביר</h2>
-
-<pre class="syntaxbox">var <em>varname1 [</em>= <em>value1] [</em>, <em>varname2 [</em>= <em>value2] </em><em>... [</em>, <em>varnameN [</em>= <em>valueN]]]</em>;</pre>
-
-<dl>
- <dt><code>varnameN</code></dt>
- <dd>שם המשתנה.</dd>
-</dl>
-
-<dl>
- <dt><code>valueN</code></dt>
- <dd> הערך של המשתנה.</dd>
-</dl>
-
-<h2 id="תיאור">תיאור</h2>
-
-<p>בשפת ג'אווה סקריפט אנו משתמשים במשתנים על מנת להחזיק ערכים שונים.<br>
- הקצאת ערך למשתנה ללא הצהרה מראש הופכת אותו למשתנה כגלובלי.<br>
- ניתן להשתמש במשתנה לפני שהוכרז, השימוש יעשה באמצעות Hoisting.</p>
-
-<p><strong>מהם ההבדלים בין משתנים מוצהרים לאלה שאינם?</strong><br>
- 1. ראשית, משתנים מוצהרים יעשו רק את הפעולה שלשמה נוצרו, לעומת משתנים לא מוצהרים הנחשבים גלובלים.</p>
-
-<pre class="brush: js">function x() {
- y = 1; // Throws a ReferenceError in strict mode
- var z = 2;
-}
-
-x();
-
-console.log(y); // logs "1"
-console.log(z); // Throws a ReferenceError: z is not defined outside x
-</pre>
-
-<p>2. משתנים מוצהרים מוכרזים לפני ביצוע קוד כלשהו לעומת זאת משתנים לא מוצהרים אינם קיימים עד שהקוד שמכריז עליהם מתבצע.</p>
-
-<pre class="brush: js">console.log(a); // Throws a ReferenceError.
-console.log('still going...'); // Never executes.</pre>
-
-<pre class="brush: js">var a;
-console.log(a); // logs "undefined" or "" depending on browser.
-console.log('still going...'); // logs "still going...".</pre>
-
-<p>בשל שני ההבדלים הללו, אי הכרזה על משתנים עשויה להוביל לשגיאות בלתי צפויות.<br>
- לכן, מומלץ תמיד להכריז על משתנים, גם אם הם נמצאים בפונקציה.</p>
-
-<h3 id="var_hoisting">var hoisting</h3>
-
-<p>זוהי התנהגות ברירת המחדל של השפה, שתפקידה להעביר את כל ההצהרות לחלק העליון של הסקריפט או הפונקציה ולכן משמעות הדבר היא שניתן להשתמש במשתנה לפני שהוכרז.</p>
-
-<pre class="brush: js">bla = 2;
-var bla;
-// ...
-
-// is implicitly understood as:
-
-var bla;
-bla = 2;
-</pre>
-
-<p>מומלץ להצהיר על משתנים בחלקו העליון של הסקריפט או הפונקציה וכך יהיה ברור אילו משתנים שייכים לפונקציה באופן מקומי ואילו גלובלים.</p>
-
-<p>חשוב לזכור ששימוש ב-Hoisting ישפיע על הצהרת המשתנה אך לא על אתחול הערך:</p>
-
-<pre class="brush: js">function do_something() {
-  console.log(bar); // undefined
-  var bar = 111;
-  console.log(bar); // 111
-}
-
-// is implicitly understood as:
-function do_something() {
-  var bar;
-  console.log(bar); // undefined
- bar = 111;
-  console.log(bar); // 111
-}
-</pre>
-
-<h2 id="דוגמאות">דוגמאות</h2>
-
-<h3 id="הכרזה_אחת_של_שני_משתנים">הכרזה אחת של שני משתנים</h3>
-
-<pre class="brush: js" dir="rtl">var a = 0, b = 0;
-</pre>
-
-<h3 id="הקצאת_שני_משתנים_עם_ערך_מחרוזת_יחיד">הקצאת שני משתנים עם ערך מחרוזת יחיד</h3>
-
-<pre class="brush: js">var a = 'A';
-var b = a;
-
-// Equivalent to:
-
-var a, b = a = 'A';
-</pre>
-
-<h3 id="משתנה_מקומי_וגלובלי">משתנה מקומי וגלובלי</h3>
-
-<pre class="brush: js">var x = 0;
-
-function f() {
- var x = y = 1; // x is declared locally. y is not!
-}
-f();
-
-console.log(x, y); // Throws a ReferenceError in strict mode (y is not defined). 0, 1 otherwise.
-// In non-strict mode:
-// x is the global one as expected
-// y leaked outside of the function, though!</pre>
-
-<h2 id="מפרט">מפרט</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('ES1')}}</td>
- <td>{{Spec2('ES1')}}</td>
- <td>Initial definition. Implemented in JavaScript 1.0</td>
- </tr>
- <tr>
- <td>{{SpecName('ES5.1', '#sec-12.2', 'var statement')}}</td>
- <td>{{Spec2('ES5.1')}}</td>
- <td> </td>
- </tr>
- <tr>
- <td>{{SpecName('ES6', '#sec-variable-statement', 'variable statement')}}</td>
- <td>{{Spec2('ES6')}}</td>
- <td> </td>
- </tr>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-variable-statement', 'variable statement')}}</td>
- <td>{{Spec2('ESDraft')}}</td>
- <td> </td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="תאימות_דפדפן">תאימות דפדפן</h2>
-
-
-
-<p>{{Compat("javascript.statements.var")}}</p>
-
-<h2 id="ראה_גם">ראה גם</h2>
-
-<ul>
- <li><a href="https://developer.mozilla.org/he/docs/Web/JavaScript/Reference/Statements/let"><code>let</code></a></li>
- <li><a href="https://developer.mozilla.org/he/docs/Web/JavaScript/Reference/Statements/const"><code>const</code></a></li>
-</ul>