الوصف
استخدِم واجهة برمجة التطبيقات chrome.windows
للتفاعل مع نوافذ المتصفّح. يمكنك استخدام واجهة برمجة التطبيقات هذه لإنشاء النوافذ وتعديلها وإعادة ترتيبها في المتصفّح.
الأذونات
عند الطلب، يحتوي windows.Window
على مصفوفة من عناصر tabs.Tab
. يجب الإفصاح عن إذن "tabs"
في ملف البيان إذا كنت بحاجة إلى الوصول إلى السمات url
أو pendingUrl
أو title
أو favIconUrl
الخاصة بفئة tabs.Tab
. على سبيل المثال:
{ "name": "My extension", ... "permissions": ["tabs"], ... }
المفاهيم والاستخدام
النافذة الحالية
تتضمّن العديد من الدوال في نظام الإضافات وسيطة windowId
اختيارية، تكون القيمة التلقائية لها هي النافذة الحالية.
النافذة الحالية هي النافذة التي تحتوي على الرمز الذي يتم تنفيذه حاليًا. من المهم معرفة أنّ هذا الإطار قد يختلف عن الإطار العلوي أو الإطار الذي يتم التركيز عليه.
على سبيل المثال، لنفترض أنّ إضافةً تنشئ بضع علامات تبويب أو نوافذ من ملف HTML واحد، وأنّ ملف HTML يتضمّن طلبًا إلى tabs.query()
. النافذة الحالية هي النافذة التي تحتوي على الصفحة التي أجرت الطلب، بغض النظر عن النافذة الأعلى.
في حالة برامج الخدمة، تعود قيمة النافذة الحالية إلى آخر نافذة نشطة. في بعض الحالات، قد لا تكون هناك نافذة حالية للصفحات التي تعمل في الخلفية.
أمثلة
لتجربة واجهة برمجة التطبيقات هذه، ثبِّت مثال واجهة برمجة التطبيقات لنظام التشغيل Windows من مستودع chrome-extension-samples.

الأنواع
CreateType
تحدّد هذه السمة نوع نافذة المتصفّح التي سيتم إنشاؤها. تم إيقاف "اللوحة" نهائيًا، وهي متاحة فقط للإضافات الحالية المدرَجة في القائمة المسموح بها على ChromeOS.
Enum
"normal"
تحدّد هذه السمة النافذة كنافذة عادية.
"popup"
تحدّد النافذة على أنّها نافذة منبثقة.
"لوحة"
تحدّد النافذة على أنّها لوحة.
QueryOptions
الخصائص
- تعبئة
boolean اختياري
إذا كانت القيمة صحيحة، يحتوي العنصر
windows.Window
على السمةtabs
التي تتضمّن قائمة بالعناصرtabs.Tab
. لا تحتوي عناصرTab
إلا على السماتurl
وpendingUrl
وtitle
وfavIconUrl
إذا كان ملف بيان الإضافة يتضمّن الإذن"tabs"
. - windowTypes
WindowType[] اختياري
في حال ضبطها، يتم فلترة
windows.Window
الذي تم عرضه استنادًا إلى نوعه. في حال عدم ضبط هذه السياسة، يتم ضبط الفلتر التلقائي على['normal', 'popup']
.
Window
الخصائص
- alwaysOnTop
قيمة منطقية
تحديد ما إذا كان سيتم ضبط النافذة لتكون دائمًا في المقدّمة
- التركيز
قيمة منطقية
تُستخدَم لتحديد ما إذا كانت النافذة هي النافذة التي يتم التركيز عليها حاليًا.
- الطول
number اختياري
تمثّل هذه السمة ارتفاع النافذة، بما في ذلك الإطار، بالبكسل. في بعض الحالات، قد لا يتمّ إسناد السمة
height
إلى نافذة، مثلاً عند طلب البحث عن النوافذ المغلقة من خلال واجهة برمجة التطبيقاتsessions
. - id
number اختياري
معرّف النافذة تكون أرقام تعريف النوافذ فريدة ضمن جلسة المتصفّح. في بعض الحالات، قد لا يتمّ تخصيص السمة
ID
لنافذة، مثلاً عند طلب البحث عن نوافذ باستخدام واجهة برمجة التطبيقاتsessions
، وفي هذه الحالة قد يكون معرّف الجلسة متوفّرًا. - incognito
قيمة منطقية
تُستخدَم لتحديد ما إذا كانت النافذة في وضع التصفّح المتخفي.
- لليسار
number اختياري
إزاحة النافذة عن الحافة اليسرى للشاشة بالبكسل في بعض الحالات، قد لا يتمّ إسناد السمة
left
إلى نافذة، مثلاً عند طلب البحث عن النوافذ المغلقة من خلال واجهة برمجة التطبيقاتsessions
. - sessionId
سلسلة اختيارية
معرّف الجلسة المستخدَم لتحديد نافذة بشكل فريد، ويتم الحصول عليه من واجهة برمجة التطبيقات
sessions
. - الولاية
WindowState اختيارية
حالة نافذة المتصفّح هذه
- علامات التبويب
Tab[] اختياري
مصفوفة من عناصر
tabs.Tab
التي تمثّل علامات التبويب الحالية في النافذة. - العلوية
number اختياري
إزاحة النافذة عن الحافة العلوية للشاشة بالبكسل في بعض الحالات، قد لا يتمّ إسناد السمة
top
إلى نافذة، مثلاً عند طلب البحث عن النوافذ المغلقة من خلال واجهة برمجة التطبيقاتsessions
. - النوع
WindowType اختياري
تمثّل هذه السمة نوع نافذة المتصفّح.
- العرض
number اختياري
تمثّل هذه السمة عرض النافذة، بما في ذلك الإطار، بوحدة البكسل. في بعض الحالات، قد لا يتمّ إسناد السمة
width
إلى نافذة، مثلاً عند طلب البحث عن النوافذ المغلقة من خلال واجهة برمجة التطبيقاتsessions
.
WindowState
حالة نافذة المتصفّح هذه في بعض الحالات، قد لا يتمّ إسناد السمة state
إلى نافذة، مثلاً عند طلب البحث عن النوافذ المغلقة من خلال واجهة برمجة التطبيقات sessions
.
Enum
"normal"
حالة النافذة العادية (ليست مصغّرة أو مكبّرة أو بملء الشاشة)
"minimized"
حالة النافذة المصغّرة
"maximized"
حالة النافذة في وضع التكبير
"fullscreen"
حالة النافذة في وضع ملء الشاشة.
"locked-fullscreen"
حالة نافذة ملء الشاشة المقفلة. لا يمكن للمستخدم الخروج من وضع ملء الشاشة هذا من خلال اتّخاذ إجراء، وهو متاح فقط للإضافات المدرَجة في القائمة المسموح بها على نظام التشغيل Chrome.
WindowType
نوع نافذة المتصفّح. في بعض الحالات، قد لا يتمّ تعيين السمة type
لنافذة، مثلاً عند طلب البحث عن النوافذ المغلقة من واجهة برمجة التطبيقات sessions
.
Enum
"normal"
نافذة متصفّح عادية
"نافذة منبثقة"
نافذة منبثقة في المتصفّح
"panel"
تم إيقاف هذه السمة نهائيًا في واجهة برمجة التطبيقات هذه. نافذة على شكل لوحة في تطبيق Chrome يمكن للإضافات الاطّلاع على نوافذ اللوحات الخاصة بها فقط.
"app"
تم إيقاف هذا الحقل نهائيًا في واجهة برمجة التطبيقات هذه. نافذة تطبيق Chrome يمكن للإضافات الاطّلاع على نوافذ تطبيقاتها فقط.
"devtools"
نافذة "أدوات المطوّرين"
الخصائص
WINDOW_ID_CURRENT
قيمة windowId التي تمثّل النافذة الحالية
القيمة
-2
WINDOW_ID_NONE
قيمة windowId التي تمثّل عدم توفّر نافذة متصفّح Chrome
القيمة
-1
الطُرق
create()
chrome.windows.create(
createData?: object,
): Promise<Window | undefined>
تنشئ هذه السمة (تفتح) نافذة متصفّح جديدة مع أي حجم أو موضع أو عنوان URL تلقائي اختياري يتم توفيره.
المعلمات
- createData
العنصر اختياري
- التركيز
boolean اختياري
إذا كان
true
، سيتم فتح نافذة نشطة. إذا كانfalse
، سيتم فتح نافذة غير نشطة. - الطول
number اختياري
تمثّل هذه السمة ارتفاع النافذة الجديدة بالبكسل، بما في ذلك الإطار. إذا لم يتم تحديدها، يتم ضبط القيمة التلقائية على ارتفاع طبيعي.
- incognito
boolean اختياري
تحديد ما إذا كان يجب أن تكون النافذة الجديدة نافذة تصفّح متخفّي
- لليسار
number اختياري
عدد وحدات البكسل التي سيتم تحديد موضع النافذة الجديدة منها من الحافة اليسرى للشاشة إذا لم يتم تحديد ذلك، سيتم إزاحة النافذة الجديدة بشكل طبيعي عن النافذة الأخيرة التي تم التركيز عليها. يتم تجاهل هذه القيمة في اللوحات.
- setSelfAsOpener
boolean اختياري
Chrome 64 والإصدارات الأحدثإذا كان
true
، يتم ضبط السمة "window.opener" للنافذة التي تم إنشاؤها حديثًا على المتصل وتكون في وحدة سياقات التصفّح ذات الصلة نفسها التي يكون فيها المتصل. - الولاية
WindowState اختيارية
Chrome 44 والإصدارات الأحدثتمثّل هذه السمة الحالة الأولية للنافذة. لا يمكن الجمع بين الحالات
minimized
وmaximized
وfullscreen
والحالاتleft
أوtop
أوwidth
أوheight
. - tabId
number اختياري
رقم تعريف علامة التبويب التي ستتم إضافتها إلى النافذة الجديدة
- العلوية
number اختياري
عدد وحدات البكسل لتحديد موضع النافذة الجديدة من الحافة العلوية للشاشة إذا لم يتم تحديد ذلك، سيتم إزاحة النافذة الجديدة بشكل طبيعي عن النافذة الأخيرة التي تم التركيز عليها. يتم تجاهل هذه القيمة في اللوحات.
- النوع
CreateType اختياري
تحدّد هذه السمة نوع نافذة المتصفّح التي سيتم إنشاؤها.
- url
string | string[] اختيارية
عنوان URL أو مصفوفة من عناوين URL لفتحها كعلامات تبويب في النافذة يجب أن تتضمّن عناوين URL المؤهَّلة بالكامل مخططًا، مثل: http://www.google.com وليس www.google.com تُعتبر عناوين URL غير المؤهَّلة بالكامل ذات صلة ضمن الإضافة. يتم ضبط هذه الخاصية تلقائيًا على "صفحة علامة التبويب الجديدة".
- العرض
number اختياري
تمثّل هذه السمة عرض النافذة الجديدة بالبكسل، بما في ذلك الإطار. إذا لم يتم تحديدها، يتم ضبط القيمة التلقائية على عرض طبيعي.
-
المرتجعات
-
Promise<Window | undefined>
الإصدار 88 من Chrome والإصدارات الأحدث
get()
chrome.windows.get(
windowId: number,
queryOptions?: QueryOptions,
): Promise<Window>
تعرض هذه الطريقة تفاصيل حول نافذة.
المعلمات
- windowId
الرقم
- queryOptions
QueryOptions اختيارية
الإصدار 88 من Chrome والإصدارات الأحدث
المرتجعات
-
Promise<Window>
الإصدار 88 من Chrome والإصدارات الأحدث
getAll()
chrome.windows.getAll(
queryOptions?: QueryOptions,
): Promise<Window[]>
تعرض هذه السمة جميع النوافذ.
المعلمات
- queryOptions
QueryOptions اختيارية
الإصدار 88 من Chrome والإصدارات الأحدث
المرتجعات
-
Promise<Window[]>
الإصدار 88 من Chrome والإصدارات الأحدث
getCurrent()
chrome.windows.getCurrent(
queryOptions?: QueryOptions,
): Promise<Window>
تعرض هذه السمة النافذة الحالية.
المعلمات
- queryOptions
QueryOptions اختيارية
الإصدار 88 من Chrome والإصدارات الأحدث
المرتجعات
-
Promise<Window>
الإصدار 88 من Chrome والإصدارات الأحدث
getLastFocused()
chrome.windows.getLastFocused(
queryOptions?: QueryOptions,
): Promise<Window>
تعرض هذه السمة النافذة التي تم التركيز عليها مؤخرًا، وهي عادةً النافذة "في الأعلى".
المعلمات
- queryOptions
QueryOptions اختيارية
الإصدار 88 من Chrome والإصدارات الأحدث
المرتجعات
-
Promise<Window>
الإصدار 88 من Chrome والإصدارات الأحدث
remove()
chrome.windows.remove(
windowId: number,
): Promise<void>
يزيل (يغلق) نافذة وجميع علامات التبويب بداخلها.
المعلمات
- windowId
الرقم
المرتجعات
-
Promise<void>
الإصدار 88 من Chrome والإصدارات الأحدث
update()
chrome.windows.update(
windowId: number,
updateInfo: object,
): Promise<Window>
تعدّل هذه الطريقة خصائص إحدى النوافذ. حدِّد الخصائص المطلوب تغييرها فقط، وستبقى الخصائص غير المحدّدة بدون تغيير.
المعلمات
- windowId
الرقم
- updateInfo
عنصر
- drawAttention
boolean اختياري
إذا كانت القيمة
true
، سيتم عرض النافذة بطريقة تجذب انتباه المستخدم إليها، بدون تغيير النافذة المركّز عليها. ويستمر التأثير إلى أن يركّز المستخدم على النافذة. ليس لهذا الخيار أي تأثير إذا كانت النافذة مركّزة. اضبط القيمة علىfalse
لإلغاء طلبdrawAttention
سابق. - التركيز
boolean اختياري
إذا كانت القيمة
true
، يتم عرض النافذة في المقدّمة، ولا يمكن دمجها مع الحالة "مصغّرة". إذا كانت القيمةfalse
، سيتم نقل النافذة التالية في ترتيب z إلى المقدّمة، ولا يمكن دمجها مع الحالة "ملء الشاشة" أو "مكبّرة". - الطول
number اختياري
تمثّل هذه السمة ارتفاع النافذة المطلوب تغيير حجمها إليه بالبكسل. يتم تجاهل هذه القيمة في اللوحات.
- لليسار
number اختياري
الإزاحة من الحافة اليسرى للشاشة لنقل النافذة إليها بالبكسل يتم تجاهل هذه القيمة في اللوحات.
- الولاية
WindowState اختيارية
الحالة الجديدة للنافذة لا يمكن الجمع بين الحالات "minimized" و"maximized" و"fullscreen" مع "left" أو "top" أو "width" أو "height".
- العلوية
number اختياري
الإزاحة من الحافة العلوية للشاشة لنقل النافذة إليها بالبكسل يتم تجاهل هذه القيمة في اللوحات.
- العرض
number اختياري
تمثّل هذه السمة عرض النافذة المطلوب تغيير حجمها إليه بالبكسل. يتم تجاهل هذه القيمة في اللوحات.
-
المرتجعات
-
Promise<Window>
الإصدار 88 من Chrome والإصدارات الأحدث
الفعاليات
onBoundsChanged
chrome.windows.onBoundsChanged.addListener(
callback: function,
)
يتم تنشيط هذا الحدث عند تغيير حجم النافذة، ولا يتم إرساله إلا عند تطبيق الحدود الجديدة، وليس للتغييرات الجارية.
المعلمات
- callback
دالة
تظهر المَعلمة
callback
على النحو التالي:(window: Window) => void
- نافذة
-
onCreated
chrome.windows.onCreated.addListener(
callback: function,
filters?: object,
)
يتم إطلاق هذا الحدث عند إنشاء نافذة.
المعلمات
- callback
دالة
Chrome 46 والإصدارات الأحدثتظهر المَعلمة
callback
على النحو التالي:(window: Window) => void
- نافذة
تفاصيل النافذة التي تم إنشاؤها
-
- الفلاتر
العنصر اختياري
- windowTypes
الشروط التي يجب أن يستوفيها نوع النافذة التي يتم إنشاؤها ويستوفي هذا الشرط تلقائيًا
['normal', 'popup']
.
-
onFocusChanged
chrome.windows.onFocusChanged.addListener(
callback: function,
filters?: object,
)
يتم تنشيط هذا الحدث عند تغيير النافذة التي يتم التركيز عليها حاليًا. تعرض القيمة chrome.windows.WINDOW_ID_NONE
إذا فقدت جميع نوافذ Chrome التركيز. ملاحظة: في بعض برامج إدارة نوافذ Linux، يتم إرسال WINDOW_ID_NONE
دائمًا قبل التبديل من نافذة Chrome إلى أخرى.
المعلمات
- callback
دالة
Chrome 46 والإصدارات الأحدثتظهر المَعلمة
callback
على النحو التالي:(windowId: number) => void
- windowId
الرقم
معرّف النافذة التي تم التركيز عليها حديثًا.
-
- الفلاتر
العنصر اختياري
- windowTypes
الشروط التي يجب أن يستوفيها نوع النافذة الذي تتم إزالته ويستوفي هذا الشرط تلقائيًا
['normal', 'popup']
.
-
onRemoved
chrome.windows.onRemoved.addListener(
callback: function,
filters?: object,
)
يتم تنشيط هذا الحدث عند إزالة (إغلاق) نافذة.
المعلمات
- callback
دالة
Chrome 46 والإصدارات الأحدثتظهر المَعلمة
callback
على النحو التالي:(windowId: number) => void
- windowId
الرقم
معرّف النافذة التي تمت إزالتها.
-
- الفلاتر
العنصر اختياري
- windowTypes
الشروط التي يجب أن يستوفيها نوع النافذة الذي تتم إزالته ويستوفي هذا الشرط تلقائيًا
['normal', 'popup']
.
-