این سند بهترین روشهایی را فهرست میکند که به شما در بهبود عملکرد اسکریپتهایتان کمک میکند.
تماس با سایر خدمات را به حداقل برسانید
استفاده از عملیات جاوا اسکریپت در اسکریپت شما بسیار سریعتر از فراخوانی سایر خدمات است. هر کاری که میتوانید در خود Google Apps Script انجام دهید، بسیار سریعتر از برقراری تماسهایی است که نیاز به واکشی دادهها از سرورهای Google یا یک سرور خارجی دارند، مانند درخواستها به Sheets، Docs، Sites، Translate، UrlFetch و غیره. اگر بتوانید راههایی برای به حداقل رساندن تماسهایی که اسکریپتها با آن سرویسها برقرار میکنند پیدا کنید، اسکریپتهای شما سریعتر اجرا میشوند.
همکاری با درایوهای مشترک را در نظر بگیرید
اگر روی یک پروژه اسکریپت با توسعه دهندگان دیگر کار می کنید، می توانید در پروژه های Apps Script با درایوهای مشترک همکاری کنید . فایلهای موجود در درایو مشترک به جای افراد متعلق به گروه است. این امر توسعه و نگهداری پروژه را آسان تر می کند.
از عملیات دسته ای استفاده کنید
اسکریپت ها معمولاً نیاز به خواندن داده ها از یک صفحه گسترده، انجام محاسبات و سپس نوشتن نتایج داده ها در یک صفحه گسترده دارند. Google Apps Script قبلاً دارای برخی بهینهسازیهای داخلی است، مانند استفاده از حافظه پنهان برای بازیابی آنچه که یک اسکریپت احتمالاً دریافت میکند و نوشتن ذخیرهسازی برای ذخیره مواردی که احتمالاً تنظیم میشود.
میتوانید با به حداقل رساندن تعداد خواندن و نوشتن، اسکریپتهایی بنویسید تا از حافظه پنهان داخلی حداکثر بهره را ببرید. دستورات متناوب خواندن و نوشتن کند است. برای سرعت بخشیدن به یک اسکریپت، تمام داده ها را در یک آرایه با یک دستور بخوانید، هر عملیاتی را روی داده های آرایه انجام دهید و داده ها را با یک دستور بنویسید.
در اینجا یک مثال است - مثالی که نباید از آن پیروی کنید یا استفاده کنید. یک اسکریپت از کد زیر برای تنظیم رنگهای پسزمینه هر سلول در یک شبکه صفحهگسترده 100×100 استفاده میکند. از تابعی به نام getColorFromCoordinates()
(در اینجا نشان داده نشده است) استفاده می کند تا مشخص کند چه رنگی برای هر سلول استفاده شود:
// DO NOT USE THIS CODE. It is an example of SLOW, INEFFICIENT code.
// FOR DEMONSTRATION ONLY
var cell = sheet.getRange('a1');
for (var y = 0; y < 100; y++) {
xcoord = xmin;
for (var x = 0; x < 100; x++) {
var c = getColorFromCoordinates(xcoord, ycoord);
cell.offset(y, x).setBackgroundColor(c);
xcoord += xincrement;
}
ycoord -= yincrement;
SpreadsheetApp.flush();
}
اسکریپت ناکارآمد است: از طریق 100 سطر و 100 ستون حلقه می زند و به طور متوالی در 10000 سلول می نویسد. حافظه پنهان بازنویسی اسکریپت Google Apps کمک می کند، زیرا با استفاده از flush در انتهای هر خط، بازنویسی را وادار می کند. به دلیل حافظه پنهان، تنها 100 تماس با صفحه گسترده وجود دارد.
اما کد را می توان با دسته بندی تماس ها بسیار کارآمدتر کرد. در اینجا یک بازنویسی وجود دارد که در آن محدوده سلول به آرایه ای به نام رنگ ها خوانده می شود، عملیات تخصیص رنگ روی داده های آرایه انجام می شود و مقادیر موجود در آرایه در صفحه گسترده نوشته می شوند:
// OKAY TO USE THIS EXAMPLE or code based on it.
var cell = sheet.getRange('a1');
var colors = new Array(100);
for (var y = 0; y < 100; y++) {
xcoord = xmin;
colors[y] = new Array(100);
for (var x = 0; x < 100; x++) {
colors[y][x] = getColorFromCoordinates(xcoord, ycoord);
xcoord += xincrement;
}
ycoord -= yincrement;
}
sheet.getRange(1, 1, 100, 100).setBackgrounds(colors);
کد ناکارآمد حدود 70 ثانیه طول می کشد تا اجرا شود. کد کارآمد فقط در 1 ثانیه اجرا می شود!
از کتابخانه های موجود در اسکریپت های سنگین UI اجتناب کنید
کتابخانه ها روشی مناسب برای استفاده مجدد از کد هستند، اما زمان شروع اسکریپت را اندکی افزایش می دهند. این تاخیر برای اسکریپت های نسبتا طولانی مدت (مانند اسکریپت ابزاری برای پاک کردن فایل های Google Drive) قابل توجه نیست، اما برای رابط های کاربری سرویس HTML سمت سرویس گیرنده که تماس های مکرر و کوتاه مدت google.script.run
را انجام می دهند، تأخیر بر هر تماس تأثیر می گذارد. به دلیل این مشکل، کتابخانهها باید به مقدار کم در افزونهها استفاده شوند، و ممکن است بخواهید از آنها در اسکریپتهای غیرافزونهای که تماسهای زیادی google.script.run
برقرار میکنند، اجتناب کنید.
از سرویس Cache استفاده کنید
می توانید از سرویس کش برای ذخیره منابع بین اجرای اسکریپت استفاده کنید. با کش کردن داده ها، می توانید تعداد دفعات یا دفعات واکشی داده ها را کاهش دهید. سناریویی را در نظر بگیرید که در آن یک فید RSS در example.com دارید که واکشی آن 20 ثانیه طول میکشد و میخواهید با درخواست متوسط سرعت دسترسی را افزایش دهید. مثال زیر نحوه استفاده از سرویس کش برای افزایش سرعت دسترسی به این داده ها را نشان می دهد.
function getRssFeed() {
var cache = CacheService.getScriptCache();
var cached = cache.get("rss-feed-contents");
if (cached != null) {
return cached;
}
// This fetch takes 20 seconds:
var result = UrlFetchApp.fetch("http://example.com/my-slow-rss-feed.xml");
var contents = result.getContentText();
cache.put("rss-feed-contents", contents, 1500); // cache for 25 minutes
return contents;
}
اکنون، در حالی که اگر آیتم در حافظه نهان نباشد، باید 20 ثانیه صبر کنید، دسترسی های بعدی بسیار سریع خواهد بود تا زمانی که آیتم در 25 دقیقه از حافظه پنهان منقضی شود.