blob: b2c80924a5d84ab027bf5b465ae78d1f706bfc76 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
|
---
title: المجالات
slug: Glossary/المجالات
translation_of: Glossary/Scope
---
<p>تعبر عن سياق التنفيذ الحالي للبرنامج والذي يمكنك فيه الوصول لقيم المتغيرات والتوابع واستعمالها. فإذا تم البحث عن متغير او تابع خارج المجال (أو سياق التنفيذ) الحالي وتبين أنّه غير موجود فلن تستطيع الوصول إليه واستعماله. وتتشكل هذه المجالات بشكل هرمي (أو دائري بشرط لايوجد دائرتين متقاطعتين وكل الدوائر محتواة في بعضها البعض) بحيث ان المجال الداخلي (أو الدائرة الداخلية) الابن يستطيع الوصول لمجال الأب (الدائرة التي تحتويه) ولكن العكس غير ممكن.</p>
<p><img alt="nested scopes intro in javascript" src="https://mdn.mozillademos.org/files/16465/nestedScopesInJS.png" style="height: 498px; width: 461px;"></p>
<p>التوابع (<strong>{{glossary("function")}})</strong> في {{glossary("JavaScript")}} تستعمل لإنشاء مجالات جديدة (كل تابع يمثل مجال جديد خاص به) فعلى سبيل المثال,إن تعريف متغير داخل التابع لن يمكنك من استعماله داخل تابع آخر او من اي مجال خارج هذا التابع, وهذا مثال يوضح لك الفكرة:</p>
<pre class="syntaxbox">function exampleFunction() {
// هذا المتغير لا يمكن استعماله إلا ضمن التابع الحالي فقط
// او أي تابع محتوى داخله
var x = "متغير داخل التابع";
console.log("داخل التابع");
console.log(x);
}
console.log(x); // لا يمكن الوصول للمتغير من الخارج</pre>
<p>بينما يستطيع التابع الوصول للمتغيرات المعرفة في مجال يقع خارجه او في المجال العام للبرنامج الخاص بك</p>
<pre class="syntaxbox">var x = "انا متغير مُعرف خارج التابع";
exampleFunction();
function exampleFunction() {
console.log("انا داخل التابع");
console.log(x); // يمكن لمجال داخلي ابن ان يصل لمتغيرات مجال خارجي أب
}
console.log("انا خارج التابع في المجال العام");
console.log(x);</pre>
<h2 id="Learn_more">Learn more</h2>
<h3 id="General_knowledge">General knowledge</h3>
<ul>
<li>{{Interwiki("wikipedia", "Scope (computer science)")}} في ويكبيديا</li>
</ul>
|