पहले से मौजूद Google सेवाएं

Google Apps Script में, उपयोगकर्ता के डेटा, Google के अन्य सिस्टम, और बाहरी सिस्टम के साथ इंटरैक्ट करने के लिए, 30 से ज़्यादा सेवाएं पहले से मौजूद होती हैं. ये सेवाएं, JavaScript के स्टैंडर्ड Math ऑब्जेक्ट की तरह ग्लोबल ऑब्जेक्ट के तौर पर उपलब्ध कराई जाती हैं. उदाहरण के लिए, जिस तरह Math में random() जैसे तरीके और PI जैसे कॉन्स्टेंट होते हैं उसी तरह Apps Script की स्प्रेडशीट सेवा में openById(id) जैसे तरीके, Range जैसी क्लास (चाइल्ड ऑब्जेक्ट), और DataValidationCriteria जैसे एनम होते हैं.

प्रॉडक्ट को कंट्रोल करने वाली सेवाओं के लिए रेफ़रंस दस्तावेज़, इस साइट के साइडबार में "रेफ़रंस" हेडर के नीचे मौजूद " सेवाएं" सेक्शन में इकट्ठा किए जाते हैं. यूज़र इंटरफ़ेस बनाने, एक्सएमएल को पार्स करने या लॉग डेटा लिखने जैसी कामों के लिए, "स्क्रिप्ट सेवाएं" सेक्शन में उपयोगिता सेवाएं इकट्ठा की जाती हैं.

JavaScript की नई सुविधाएं

Apps Script में दो JavaScript रनटाइम काम करते हैं: आधुनिक V8 रनटाइम और Mozilla के Rhino JavaScript इंटरप्रिटर से चलने वाला पुराना रनटाइम.

V8 रनटाइम, आधुनिक ECMAScript सिंटैक्स और सुविधाओं के साथ काम करता है. Rhino रनटाइम, JavaScript 1.6 स्टैंडर्ड के साथ-साथ 1.7 और 1.8 की कुछ सुविधाओं पर आधारित है. अपनी स्क्रिप्ट के साथ इस्तेमाल करने के लिए, आपके पास रनटाइम चुनने का विकल्प होता है. हालांकि, हमारा सुझाव है कि आप V8 रनटाइम का इस्तेमाल करें.

हर रनटाइम, आपकी स्क्रिप्ट के लिए उपलब्ध JavaScript क्लास और ऑब्जेक्ट के साथ-साथ, पहले से मौजूद और Google की बेहतर सेवाओं के साथ काम करता है. आपकी स्क्रिप्ट में, Array, Date, RegExp, वगैरह जैसे सामान्य ऑब्जेक्ट के साथ-साथ, Math और Object जैसे ग्लोबल ऑब्जेक्ट का इस्तेमाल किया जा सकता है.

ऑटोकंप्लीट की सुविधा का इस्तेमाल करना

स्क्रिप्ट एडिटर में "कॉन्टेंट असिस्ट" सुविधा होती है. इसे आम तौर पर "अपने-आप पूरा होने की सुविधा" कहा जाता है. इस सुविधा से, स्क्रिप्ट के मौजूदा कॉन्टेक्स्ट में मान्य वैश्विक ऑब्जेक्ट के साथ-साथ, ऐसे तरीके और एन्सम (एक से ज़्यादा वैल्यू वाले वैरिएबल) भी दिखते हैं. अपने-आप पूरा होने वाले सुझाव तब अपने-आप दिखते हैं, जब किसी ग्लोबल ऑब्जेक्ट, एनम या ऐसे मेथड कॉल के बाद पीरियड लिखा जाता है जो Apps Script क्लास दिखाता है. उदाहरण के लिए:

  • किसी ग्लोबल ऑब्जेक्ट का पूरा नाम टाइप करने या अपने-आप पूरा होने वाले विकल्पों में से कोई एक चुनने के बाद, . (पॉइंट) टाइप करें. ऐसा करने पर, आपको उस क्लास के सभी तरीके और एनम दिखेंगे.
  • कुछ वर्ण टाइप करने पर, आपको उन वर्णों से शुरू होने वाले सभी मान्य सुझाव दिखेंगे.

ग्लोबल ऑब्जेक्ट के बारे में जानकारी

हर सेवा में कम से कम एक ग्लोबल (टॉप-लेवल) ऑब्जेक्ट होता है. उदाहरण के लिए, Gmail सेवा को सिर्फ़ GmailApp ऑब्जेक्ट से ऐक्सेस किया जाता है. कुछ सेवाएं कई ग्लोबल ऑब्जेक्ट उपलब्ध कराती हैं. उदाहरण के लिए, बेस सेवा में चार ग्लोबल ऑब्जेक्ट शामिल हैं: Browser, Logger, MimeType, और Session.

कॉल करने के तरीके

पहले से मौजूद या बेहतर सेवाओं के ग्लोबल ऑब्जेक्ट में ऐसे तरीके शामिल होते हैं जो डेटा या Apps Script क्लास दिखाते हैं. स्क्रिप्ट, इस फ़ॉर्मैट में मेथड कॉल करती हैं:

GlobalObjectName.methodName(argument1, argument2, ..., argumentN);

उदाहरण के लिए, कोई स्क्रिप्ट Gmail सेवा के sendEmail(recipient, subject, body) तरीके को कॉल करके ईमेल भेज सकती है. इसके लिए, यह तरीका अपनाएं:

GmailApp.sendEmail('claire@example.com', 'Subject line', 'This is the body.');

अगर कोई तरीका किसी अन्य Apps Script क्लास को दिखाता है, तो एक लाइन पर तरीकों को चेन किया जा सकता है. (रिटर्न टाइप, अपने-आप पूरा होने वाले टेक्स्ट और किसी तरीके के रेफ़रंस दस्तावेज़, दोनों में दिखते हैं.) उदाहरण के लिए, DocumentApp.create() तरीका, Document दिखाता है. इसलिए, कोड के ये दो सेक्शन एक जैसे हैं:

var doc = DocumentApp.create('New document');
var body = doc.getTab('t.0').asDocumentTab().getBody();
body.appendParagraph('New paragraph.');

// Same result as above.
DocumentApp.create('New document').getTab('t.0').asDocumentTab().getBody()
    .appendParagraph('New paragraph.');

बच्चों की क्लास ऐक्सेस करना

हर सेवा में एक या उससे ज़्यादा चाइल्ड क्लास शामिल होती हैं. इन्हें टॉप लेवल से ऐक्सेस नहीं किया जा सकता, जैसा कि ग्लोबल ऑब्जेक्ट को किया जा सकता है. इन क्लास को बनाने के लिए, new कीवर्ड का इस्तेमाल नहीं किया जा सकता. ऐसा Date जैसी स्टैंडर्ड JavaScript क्लास के लिए किया जा सकता है. किसी चाइल्ड क्लास को सिर्फ़ उस तरीके को कॉल करके ऐक्सेस किया जा सकता है जो उसे दिखाता है. अगर आपको किसी क्लास को ऐक्सेस करने का तरीका नहीं पता है, तो सेवा के रेफ़रंस दस्तावेज़ के रूट पेज पर जाएं और वह तरीका ढूंढें जिससे आपको अपनी पसंद की क्लास मिल सके.

इंटरफ़ेस से जुड़ी समस्याओं को हल करना

कुछ सेवाओं में खास क्लास शामिल होती हैं, जिन्हें रेफ़रंस दस्तावेज़ में "इंटरफ़ेस" के तौर पर लेबल किया जाता है. ये सामान्य क्लास हैं, जिनका इस्तेमाल उन तरीकों के लिए रिटर्न टाइप के तौर पर किया जाता है जिनके लिए पहले से सटीक टाइप तय नहीं किया जा सकता. उदाहरण के लिए, दस्तावेज़ सेवा का तरीका, Body.getChild(childIndex) एक सामान्य Element ऑब्जेक्ट दिखाता है. Element एक ऐसा इंटरफ़ेस है जो किसी दूसरी क्लास को दिखाता है. यह क्लास, हो सकता है कि Paragraph या Table हो. इंटरफ़ेस ऑब्जेक्ट, आम तौर पर अपने-आप काम के नहीं होते. इसके बजाय, आम तौर पर ऑब्जेक्ट को किसी खास क्लास में वापस कास्ट करने के लिए, Element.asParagraph() जैसे किसी तरीके को कॉल करना होता है.

एनम के साथ काम करना

ज़्यादातर सेवाओं में, नाम वाली वैल्यू के कुछ एनम (एनोटेट किए गए टाइप) शामिल होते हैं. उदाहरण के लिए, Drive सेवा यह तय करने के लिए कि किन उपयोगकर्ताओं के पास फ़ाइल या फ़ोल्डर का ऐक्सेस है, सूची Access और सूची Permission का इस्तेमाल करती है. ज़्यादातर मामलों में, इन एन्सम को ग्लोबल ऑब्जेक्ट से ऐक्सेस किया जाता है. उदाहरण के लिए, Folder.setSharing(accessType, permissionType) के लिए कॉल कुछ ऐसा दिखता है:

// Creates a folder that anyone on the Internet can read from and write to. (Domain administrators can
// prohibit this setting for  users.)
var folder = DriveApp.createFolder('Shared Folder');
folder.setSharing(DriveApp.Access.ANYONE, DriveApp.Permission.EDIT);