تؤدي مشغّلات "برمجة تطبيقات Google" إلى استخدام نص برمجي محدّد (دالة المشغل) لتنفيذها عندما يحدث حدث محدد تحدث المقابلة. يمكن أن تتسبب أحداث معينة فقط في تنشيط المشغلات، يتوافق تطبيق Google Workspace مع مجموعة مختلفة من الأحداث.
عند تنشيط عامل تشغيل، يتم إنشاء كائن حدث. بنية JSON هذه يحتوي على تفاصيل عن الحدث الذي وقع. المعلومات الواردة في الحدث يتم تنظيم بنية الكائن بشكل مختلف حسب نوع المشغل.
بعد إنشاء كائن الحدث، تمرره "برمجة تطبيقات Google" كمعلمة إلى
. دالة المشغل هي دالة استدعاء يجب عليك
وتنفيذه بنفسك، لاتخاذ الإجراءات المناسبة للرد على
فعالية. على سبيل المثال، في إضافة "المحرر"، المشغل
يُستخدم لإنشاء عناصر قائمة الإضافات عند فتح مستند. في هذه الحالة،
تنفيذها على دالة الشغِّل onOpen(e)
لإنشاء عناصر القائمة التي تحتوي على
ربما باستخدام البيانات الموجودة في كائن الحدث.
تقدم هذه الصفحة إرشادات حول استخدام المشغلات في محرِّر لمشروعات الوظائف الإضافية.
أنواع عوامل تشغيل إضافات المحرّر
يمكنك استخدام معظم أنواع العوامل العامة المتاحة لمشاريع "برمجة التطبيقات". في إضافات "محرّر إعلانات Google"، بما في ذلك العوامل المشغِّلة البسيطة ومعظم المشغِّلات القابلة للتثبيت تشير رسالة الأشكال البيانية تعتمد المجموعة الدقيقة من أنواع المشغلات المتاحة على التطبيق الذي يتم توسيعه.
ويوضح الجدول التالي أنواع المشغلات البسيطة والقابلة للتثبيت التي يمكن لإضافات "محرّر إعلانات Google" استخدام عناصر الأحداث المقابلة لها، كما توفّر روابط تؤدي إلى العناصر التالية:
الحدث | كائن الحدث | عوامل تشغيل بسيطة | العوامل المشغِّلة القابلة للتثبيت |
---|---|---|---|
فتح يتم فتح ملف محرّر. |
عنصر حدث onOpen في "مستندات Google" كائن الحدث onOpen في النماذج عنصر حدث onOpen في "جداول بيانات Google" عنصر حدث onOpen في "العروض التقديمية من Google" |
مستندات Google نماذج Google* جداول بيانات Google العروض التقديمية من Google
|
مستندات Google نماذج Google جداول بيانات Google |
تثبيت تم تثبيت الإضافة. |
كائن حدث onInstall |
مستندات Google نماذج Google جداول بيانات Google العروض التقديمية من Google
|
|
تعديل يتم تغيير محتوى خلايا جدول البيانات. |
كائن حدث onEdit في "جداول بيانات Google" |
جداول بيانات Google
|
جداول بيانات Google |
التغيير يتم تعديل المحتوى في جدول بيانات أو تنسيقه. |
كائن حدث onChange في "جداول بيانات Google" |
جداول بيانات Google |
|
إرسال النموذج يتم إرسال "نموذج Google". |
عنصر حدث إرسال النموذج في "نماذج Google" كائن إرسال النموذج في "جداول بيانات Google" |
نماذج Google جداول بيانات Google |
|
الاستناد إلى الوقت (الساعة) يتم تنشيط المشغِل خلال فترة زمنية أو فاصل محدَّد. |
كائن الحدث المستند إلى الوقت |
مستندات Google نماذج Google جداول بيانات Google العروض التقديمية من Google |
* لا يحدث الحدث المفتوح في "نماذج Google" عندما يفتح المستخدم للرد، ولكن بدلاً من ذلك عندما يفتح أحد المحررين النموذج لتعديله.
المشغلات البسيطة في الإضافات
تستخدم المشغلات البسيطة مجموعة محجوزة وأسماء الدوال، ولا يمكنه استخدام الخدمات التي تتطلب تفويضًا، يتم تفعيلها تلقائيًا. وفي بعض الحالات، يمكن أن يؤدي حدث تشغيل بسيط باستخدام عامل تشغيل قابل للتثبيت بدلاً من ذلك.
يمكنك إضافة مشغل بسيط إلى إضافة عن طريق تنفيذ دالة ببساطة بأحد الأسماء المحجوزة التالية:
- يتم تنفيذ
onOpen(e)
عندما يفتح المستخدم مستندًا أو جدول بيانات أو عرضنا التقديمي. يمكن أيضًا لـonOpen(e)
التنفيذ عند فتح نموذج في المحرِّر. (ولكن ليس عند الرد على النموذج). ولا يتم تنفيذه إلا إذا كان لدى المستخدم إذن لتعديل الملف المعني، وغالبًا ما يُستخدم لإنشاء عناصر القائمة. - يتم تنفيذ
onInstall(e)
عندما يثبّت أحد المستخدمين إضافة. السعر المعتادonInstall(e)
يُستخدم فقط للاتصال بـonOpen(e)
؛ يضمن ظهور القوائم الإضافية مباشرةً بعد التثبيت بدون أن يُطلَب من المستخدم إعادة تحميل الصفحة - يتم تنفيذ
onEdit(e)
عندما يغيّر المستخدم قيمة خلية في جدول بيانات. لا يتم تنشيط هذا المشغِّل استجابةً لعمليات نقل الخلايا أو التنسيق أو تغييرات أخرى لا تغير قيم الخلية.
القيود
تخضع المشغلات البسيطة في الإضافات لنفس للقيود التي تنظم ممارسات المشغلات في أنواع أخرى من مشاريع برمجة التطبيقات. قم بتدوين هذه القيود عند تصميم الإضافات:
- لا تعمل المشغلات البسيطة إذا تم فتح الملف في وضع القراءة فقط (عرض أو التعليق) . يؤدي هذا السلوك إلى منع تعبئة قوائم الإضافات.
- في ظروف معينة، تشغل إضافات "المحررين"
onOpen(e)
onEdit(e)
عامل تشغيل بسيط في وضع عدم التفويض. يقدم هذا الوضع بعض الإضافات الإضافية كما هو موضح في نموذج تفويض الإضافة. - لا يمكن للمشغلات البسيطة استخدام الخدمات أو اتخاذ إجراءات أخرى تتطلب التفويض، باستثناء الموضحة في نموذج تفويض الإضافة
- لا يمكن تشغيل المشغلات البسيطة لأكثر من 30 ثانية. احرص على تقليل مقدار المعالجة المنجزة في دالة تشغيل بسيطة.
- تخضع المشغّلات البسيطة لمشغّل "برمجة تطبيقات Google". حدود الحصص.
المشغِّلات القابلة للتثبيت في الإضافات
يمكن للإضافات
إنشاء المشغِّلات القابلة للتثبيت وتعديلها آليًا
باستخدام خدمة "برمجة التطبيقات" Script
.
لا يمكن إنشاء المشغلات القابلة للتثبيت يدويًا. على عكس المشغلات البسيطة،
يمكن للمشغلات القابلة للتثبيت استخدام الخدمات التي تتطلب إذنًا.
لا ترسل المشغلات القابلة للتثبيت في الإضافات رسائل الخطأ الإلكترونية للمستخدم عندما تواجه أخطاء، حيث إنه في معظم الحالات غير قادر على لمعالجة المشكلة. لهذا السبب، يجب عليك تصميم الإضافة الخاصة بك التعامل مع الأخطاء بسلاسة بالنيابة عن المستخدم كلما أمكن ذلك.
يمكن للإضافات استخدام المشغِّلات التالية القابلة للتثبيت:
- يتم تنفيذ أمر فتح المشغَّل القابل للتثبيت عندما يفتح أحد المستخدمين مستندًا. أو عند فتح نموذج في المحرر (ولكن ليس عند الرد النموذج).
- يتم تنفيذ تعديل المشغِّلات القابلة للتثبيت عندما يغيِّر مستخدم قيمة خلية في جدول بيانات. لا يتم تنشيط هذا المشغِّل استجابةً للتنسيق أو غير ذلك التغييرات التي لا تغير قيم الخلية.
- يتم تنفيذ تغيير المشغلات القابلة للتثبيت عندما يُجري المستخدم أي تغيير في جدول بيانات، بما في ذلك تعديلات التنسيق والتعديلات على جدول البيانات نفسها (مثل إضافة صف).
يتم تنفيذ المشغِّلات القابلة للتثبيت form-submit عند تنفيذ استجابة "نموذج Google". تم إرسالها.
العوامل المشغِّلة المستندة إلى الوقت (وتسمى أيضًا مشغلات الساعة) يتم إطلاقها في وقت محدد أو بشكل متكرر في فاصل زمني منتظم.
الموافقة على المشغِّلات القابلة للتثبيت
عادةً، إذا حدَّث مطوّر برامج إضافة لاستخدام خدمات جديدة تتطلب تفويض إضافي، سيطلب من المستخدمين إعادة تفويض الإضافة في وقت استخدامه.
ومع ذلك، تواجه الإضافات التي تستخدم مشغلات تحديات خاصة في التفويض. تخيل إضافة تستخدم مشغلاً لمراقبة عمليات إرسال النماذج: نموذج قد يسمح صانع المحتوى بالإضافة في المرة الأولى التي يستخدمها، ثم يتركها التشغيل لأشهر أو سنوات دون إعادة فتح النموذج على الإطلاق. إذا كان مطوّر الإضافة سيحدّث الإضافة لاستخدام خدمات جديدة تتطلب تفويضًا إضافيًا، فلن تظهر لمنشئ النموذج مربّع حوار إعادة التفويض لأنّها لم تعيد فتح النموذج أبدًا، فضلاً عن عن العمل.
على عكس المشغلات في مشاريع برمجة التطبيقات العادية، فإن المشغلات في
يستمر تنشيط الإضافات حتى إذا كانت بحاجة إلى إعادة تفويض. ومع ذلك، فإن النص
لا يزال يتعذّر تشغيله إذا وصل إلى سطر من الرمز يتطلب إذنًا للنص البرمجي
لا يحتوي عليه. ولتجنب هذا الموقف، يمكن للمطوّرين استخدام الطريقة
ScriptApp.getAuthorizationInfo()
إلى بوابة الوصول إلى أجزاء من الرمز تغيرت بين الإصدارات المنشورة من
الوظيفة الإضافية.
فيما يلي مثال على البنية التي يُنصح باستخدامها في دوال التشغيل تجنب أخطاء التفويض. تستجيب مثال دالة المشغل لـ إرسال النموذج في إضافة على "جداول بيانات Google"، وفي حال كانت إعادة التفويض مطلوب، ترسل إلى مستخدم الإضافة رسالة إلكترونية للتنبيه باستخدام نموذج HTML النموذجي.
Code.gs
authorizationemail.html
القيود
تخضع المشغلات القابلة للتثبيت في الإضافات لنفس القيود التي تحكم المشغلات القابلة للتثبيت في أنواع أخرى من مشاريع برمجة التطبيقات.
بالإضافة إلى هذه القيود، تسري العديد من القيود على الأجهزة القابلة للتثبيت. المشغلات في الإضافات على وجه التحديد:
- يمكن أن تحتوي كل إضافة على عامل تشغيل واحد فقط من كل نوع لكل مستخدم لكل مستند. على سبيل المثال، في جدول بيانات معين، يمكن لمستخدم معين إجراء تعديل واحد فقط رغم أن المستخدم قد يكون لديه أيضًا مشغِّل إرسال النموذج أو مشغل مستند إلى الوقت في نفس جدول البيانات. مستخدم آخر لديه إذن الوصول إلى جدول البيانات نفسه مجموعة منفصلة من المشغلات.
- يمكن للإضافات إنشاء مشغلات للملف الذي يتم استخدام الإضافة فيه فقط. أي أن الإضافة المستخدمة في مستند Google أ لا يمكنها إنشاء مشغل عندما يتم فتح مستند Google B.
- لا يمكن تشغيل المشغلات المستندة إلى الوقت بشكل متكرر أكثر من مرة في الساعة.
- لا ترسل الإضافات رسالة إلكترونية تلقائيًا إلى المستخدم عند تشغيل الرمز بواسطة المشغل القابل للتثبيت يطرح استثناء. الأمر متروك لمطور البرامج للتحقق لحالات الفشل والتعامل معها بشكل رشيق.
- يتوقّف تنشيط مشغلات الإضافات في أي من الحالات التالية:
- إذا ألغى المستخدم تثبيت الإضافة،
- إذا تم إيقاف الإضافة في مستند (إذا أعيد تفعيلها، فإن المشغّل تصبح جاهزة للعمل مرة أخرى) أو
- إذا ألغى مطوِّر البرامج نشر الإضافة أو أرسل إصدارًا معطّلاً إلى متجر الوظائف الإضافية.
- يتم تنفيذ دوال مشغل الإضافة حتى تصل إلى التعليمات البرمجية التي تستخدم أو خدمة غير مصرح بها، وعندها يتوقفون. هذا صحيح فقط إذا نشر الإضافة المشغل نفسه في مشروع "برمجة تطبيقات Google" العادي أو لا يتم على الإطلاق تنفيذ إضافة غير منشورة إذا كان أي جزء من النص البرمجي يحتاج إلى التفويض.
- تخضع المشغِّلات القابلة للتثبيت لمشغّل "برمجة تطبيقات Google". حدود الحصص.