يوضّح هذا الدليل كيفية إنشاء متغيّر إخراج.
يتم عرض متغيّرات الإخراج من خلال الخطوات ويمكن إرسالها إلى خطوة أخرى. على سبيل المثال، يمكنك تمرير عنوان بريد إلكتروني إلى خطوة أخرى تستخدمه لتحديد مستلم رسالة إلكترونية.
حدِّد متغيّر الإخراج في مكانَين: ملف البيان الخاص بالإضافة، وفي الرمز البرمجي باستخدام دالة تعرض متغيّر الإخراج.
يعرض المثال التالي نتيجة رياضية محسوبة من ثلاثة متغيرات إدخال، وهي عددان وعملية حسابية.
تحديد متغيّر الإخراج في ملف البيان
في ملف بيان "برمجة تطبيقات Google"، حدِّد مصفوفة outputs[] وonExecuteFunction().
يحتوي كل عنصر في مصفوفة outputs[] على السمات التالية:
-
id: معرّف فريد لمتغيّر الناتج. -
description: وصف لمتغيّر الناتج سيتم عرضه للمستخدمين النهائيين. cardinality: عدد القيم المسموح بها القيم المحتمَلة هي:"SINGLE": يُسمح بقيمة واحدة فقط.
-
dataType: نوع القيم المقبولة تحتويdataTypeعلى السمةbasicTypeالتي تحدّد نوع البيانات. تشمل القيم الصالحة ما يلي:-
"STRING": سلسلة أبجدية رقمية -
"INTEGER": رقم -
"TIMESTAMP": طابع زمني بالتنسيق ISO 8601. على سبيل المثال، في معيار ISO 8601، يتم تمثيل 15 مارس 2025 بالتنسيق 2025-03-15. -
"BOOLEAN": إما true أو false. -
"EMAIL_ADDRESS": عنوان بريد إلكتروني بالتنسيقdana@example.com
-
يحدّد المثال التالي متغيّر إخراج لخطوة آلة حاسبة. متغيّر الإخراج هو عدد صحيح.
JSON
{
"timeZone": "America/Los_Angeles",
"exceptionLogging": "STACKDRIVER",
"runtimeVersion": "V8",
"addOns": {
"common": {
"name": "Calculator",
"logoUrl": "https://www.gstatic.com/images/branding/productlogos/calculator_search/v1/web-24dp/logo_calculator_search_color_1x_web_24dp.png",
"useLocaleFromApp": true
},
"flows": {
"workflowElements": [
{
"id": "actionElement",
"state": "ACTIVE",
"name": "Calculate",
"description": "Asks the user for two values and a math operation, then performs the math operation on the values and outputs the result.",
"workflowAction": {
"inputs": [
{
"id": "value1",
"description": "value1",
"cardinality": "SINGLE",
"dataType": {
"basicType": "INTEGER"
}
},
{
"id": "value2",
"description": "value2",
"cardinality": "SINGLE",
"dataType": {
"basicType": "INTEGER"
}
},
{
"id": "operation",
"description": "operation",
"cardinality": "SINGLE",
"dataType": {
"basicType": "STRING"
}
}
],
"outputs": [
{
"id": "result",
"description": "Calculated result",
"cardinality": "SINGLE",
"dataType": {
"basicType": "INTEGER"
}
}
],
"onConfigFunction": "onConfigCalculate",
"onExecuteFunction": "onExecuteCalculate"
}
}
]
}
}
}
تحديد متغيّر الإخراج في الرمز
يتضمّن رمز الخطوة دالة باسم onExecuteCalculate()، وهي onExecuteFunction المحدّدة في ملف البيان. تُجري هذه الدالة عمليات حسابية على قيمتين يُدخلهما المستخدم، وتعرض النتيجة كمتغير إخراج باستخدام دالة تُسمى outputVariables().
لعرض متغيّر ناتج، يجب عرض JSON مع المتطلبات التالية:
- يجب أن يتطابق
variableIdلكل متغيّر إخراج معidلمتغيّر الإخراج المقابل في ملف البيان. - يجب أن يتطابق
variableDataلمتغيّر الناتج معdataTypeوcardinalityلمتغيّر الناتج المقابل في ملف البيان.
يعرض المثال التالي متغيّر إخراج يمثّل القيمة الحسابية لرقمَين من أرقام الإدخال:
برمجة التطبيقات
/**
* Executes the calculation step based on the inputs from a flow event.
*
* This function retrieves input values and the operation from the flow event,
* performs the calculation, and returns the result as an output variable.
* The function logs the event for debugging purposes.
*/
function onExecuteCalculateFunction(event) {
console.log("output: " + JSON.stringify(event));
var calculatedValue = 0;
var value1 = event.workflow.actionInvocation.inputs["value1"];
var value2 = event.workflow.actionInvocation.inputs["value2"];
var operation = event.workflow.actionInvocation.inputs["operation"].stringValues[0];
if (operation == "+") {
calculatedValue = value1 + value2;
} else if (operation == "-") {
calculatedValue = value1 - value2;
} else if (operation == "x") {
calculatedValue = value1 * value2;
} else if (operation == "/") {
calculatedValue = value1 / value2;
}
var renderAction = {
"hostAppAction" : {
"workflowAction" : {
"returnOutputVariablesAction" : {
"variableValues" : [
{
"variableId": "result",
"integerValues": [
calculatedValue
]
}
]
}
}
}
};
console.log("renderAction: " + JSON.stringify(renderAction));
return renderAction;
}