You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Copy file name to clipboardExpand all lines: 1-js/11-async/06-promisify/article.md
+29-29
Original file line number
Diff line number
Diff line change
@@ -1,12 +1,12 @@
1
-
# Promisification
1
+
# پرومیسسازی (Promisification)
2
2
3
-
"Promisification" is a long word for a simple transformation. It's the conversion of a function that accepts a callback into a function that returns a promise.
3
+
«Promisification» (پرومیسسازی) یک واژهی طولانی برای یک تبدیل ساده است. این تبدیل به معنای تبدیل تابعی است که از callback استفاده میکند، به تابعی که یک Promise برمیگرداند.
4
4
5
-
Such transformations are often required in real-life, as many functions and libraries are callback-based. But promises are more convenient, so it makes sense to promisify them.
5
+
چنین تبدیلاتی در دنیای واقعی بسیار موردنیاز هستند، چرا که بسیاری از توابع و کتابخانهها بر پایهی callback طراحی شدهاند. اما Promiseها راحتتر و خواناتر هستند، بنابراین منطقی است که آنها را جایگزین کنیم.
6
6
7
-
For better understanding, let's see an example.
7
+
برای درک بهتر، بیایید یک مثال ببینیم.
8
8
9
-
For instance, we have `loadScript(src, callback)` from the chapter <info:callbacks>.
9
+
برای نمونه، تابعی به نام loadScript(src, callback) را داریم که در فصل مربوط به callbackها معرفی شده بود.
10
10
11
11
```js run
12
12
functionloadScript(src, callback) {
@@ -23,15 +23,16 @@ function loadScript(src, callback) {
The function loads a script with the given `src`, and then calls `callback(err)` in case of an error, or `callback(null, script)` in case of successful loading. That's a widespread agreement for using callbacks, we saw it before.
26
+
این تابع یک اسکریپت را با آدرس src مشخصشده بارگذاری میکند، و سپس در صورت بروز خطا، callback(err) را صدا میزند، یا در صورت بارگذاری موفق، callback(null, script) را فراخوانی میکند. این یک قرارداد رایج در استفاده از callbackهاست که قبلاً هم آن را دیدهایم.
27
27
28
-
Let's promisify it.
28
+
حالا بیایید آن را promisify (پرومیسسازی) کنیم.
29
29
30
-
We'll make a new function `loadScriptPromise(src)`, that does the same (loads the script), but returns a promise instead of using callbacks.
30
+
ما یک تابع جدید به نام loadScriptPromise(src) میسازیم که همان کار را انجام میدهد (اسکریپت را بارگذاری میکند)، اما بهجای استفاده از callback، یک Promise برمیگرداند.
31
31
32
-
In other words, we pass it only `src` (no `callback`) and get a promise in return, that resolves with `script` when the load is successful, and rejects with the error otherwise.
32
+
بهعبارت دیگر، فقط src را به آن میدهیم (بدون callback) و یک Promise دریافت میکنیم که در صورت بارگذاری موفق، با script حل (resolve) میشود، و در غیر این صورت، با خطا رد (reject) میشود.
33
+
34
+
اینجا نمونهی آن را میبینید:
33
35
34
-
Here it is:
35
36
```js
36
37
letloadScriptPromise=function(src) {
37
38
returnnewPromise((resolve, reject) => {
@@ -46,13 +47,13 @@ let loadScriptPromise = function(src) {
46
47
// loadScriptPromise('path/script.js').then(...)
47
48
```
48
49
49
-
As we can see, the new function is a wrapper around the original `loadScript` function. It calls it providing its own callback that translates to promise `resolve/reject`.
50
+
همانطور که میبینیم، تابع جدید یک لفاف (wrapper) دور تابع اصلی loadScript است. این تابع، loadScript را صدا میزند و callback مخصوص خودش را به آن میدهد، که این callback، نتیجه را به صورت resolve یا reject به Promise تبدیل میکند.
50
51
51
-
Now `loadScriptPromise` fits well in promise-based code. If we like promises more than callbacks (and soon we'll see more reasons for that), then we will use it instead.
52
+
اکنون loadScriptPromise بهخوبی با کدهای مبتنی بر Promise سازگار است. اگر Promiseها را بیشتر از callbackها دوست داریم (و بهزودی دلایل بیشتری برای آن خواهیم دید)، از این نسخه استفاده خواهیم کرد.
52
53
53
-
In practice we may need to promisify more than one function, so it makes sense to use a helper.
54
+
در عمل، ممکن است بخواهیم بیش از یک تابع را promisify کنیم، بنابراین منطقی است که از یک تابع کمکی (helper) استفاده کنیم.
54
55
55
-
We'll call it `promisify(f)`: it accepts a to-promisify function `f` and returns a wrapper function.
56
+
ما این تابع کمکی را promisify(f) مینامیم: این تابع، یک تابع f که قرار است promisify شود را میگیرد و یک تابع wrapper برمیگرداند.
56
57
57
58
```js
58
59
functionpromisify(f) {
@@ -77,19 +78,18 @@ function promisify(f) {
77
78
let loadScriptPromise =promisify(loadScript);
78
79
loadScriptPromise(...).then(...);
79
80
```
81
+
ممکن است کد کمی پیچیده به نظر برسد، اما در اصل همان چیزی است که قبلاً برای promisify کردن تابع loadScript نوشتیم.
80
82
81
-
The code may look a bit complex, but it's essentially the same that we wrote above, while promisifying `loadScript` function.
82
-
83
-
A call to `promisify(f)` returns a wrapper around `f``(*)`. That wrapper returns a promise and forwards the call to the original `f`, tracking the result in the custom callback `(**)`.
83
+
یک فراخوانی به promisify(f)، یک wrapper (لفاف) دور تابع f برمیگرداند (*). این لفاف، یک Promise بازمیگرداند و تابع اصلی f را با یک callback سفارشی که نتیجه را پیگیری میکند، صدا میزند (**).
84
84
85
-
Here, `promisify` assumes that the original function expects a callback with exactly two arguments `(err, result)`. That's what we encounter most often. Then our custom callback is in exactly the right format, and `promisify` works great for such a case.
85
+
در اینجا، promisify فرض میکند که تابع اصلی، یک callback با دقیقاً دو آرگومان (err, result) انتظار دارد. این همان الگویی است که معمولاً با آن مواجه هستیم. در چنین حالتی، callback سفارشی ما دقیقاً با همین فرمت تعریف شده و promisify بهخوبی کار میکند.
86
86
87
-
But what if the original `f` expects a callback with more arguments `callback(err, res1, res2, ...)`?
87
+
اما اگر تابع f اصلی، یک callback با آرگومانهای بیشتری بخواهد؟ مثل callback(err, res1, res2, ...)؟
88
88
89
-
We can improve our helper. Let's make a more advanced version of `promisify`.
89
+
ما میتوانیم تابع کمکی خود را بهبود دهیم. بیایید یک نسخهی پیشرفتهتر از promisify بسازیم.
90
90
91
-
- When called as `promisify(f)` it should work similar to the version above.
92
-
- When called as `promisify(f, true)`, it should return the promise that resolves with the array of callback results. That's exactly for callbacks with many arguments.
91
+
وقتی به صورت promisify(f) فراخوانی میشود، باید مانند نسخهی قبلی کار کند.
92
+
اما وقتی به صورت promisify(f, true) فراخوانی شود، باید یک Promise بازگرداند که با آرایهای از نتایج callback حل (resolve) میشود. این دقیقاً مناسب callbackهایی است که چند آرگومان بازگشتی دارند.
93
93
94
94
```js
95
95
// promisify(f, true) to get array of results
@@ -116,17 +116,17 @@ function promisify(f, manyArgs = false) {
116
116
f =promisify(f, true);
117
117
f(...).then(arrayOfResults=>..., err=>...);
118
118
```
119
+
همانطور که میبینید، این نسخه در اصل همان نسخهی قبلی است، با این تفاوت که resolve بسته به اینکه manyArgs مقدار truthy داشته باشد یا نه، یا فقط با یک آرگومان صدا زده میشود یا با همهی آرگومانها.
119
120
120
-
As you can see it's essentially the same as above, but `resolve` is called with only one or all arguments depending on whether `manyArgs` is truthy.
121
-
122
-
For more exotic callback formats, like those without `err` at all: `callback(result)`, we can promisify such functions manually without using the helper.
121
+
برای فرمتهای خاصتر callbackها — مثلاً آنهایی که اصلاً err ندارند و فقط به شکل callback(result) هستند — میتوانیم آنها را بهصورت دستی promisify کنیم، بدون استفاده از تابع کمکی.
123
122
124
-
There are also modules with a bit more flexible promisification functions, e.g. [es6-promisify](https://github.com/digitaldesignlabs/es6-promisify). In Node.js, there's a built-in `util.promisify` function for that.
123
+
همچنین ماژولهایی هم وجود دارند که توابع promisify انعطافپذیرتری ارائه میدهند، مثلاً ماژولی به نام es6-promisify.
124
+
در Node.js نیز یک تابع داخلی به نام util.promisify برای این کار وجود دارد.
125
125
126
126
```smart
127
-
Promisification is a great approach, especially when you use `async/await` (covered later in the chapter <info:async-await>), but not a total replacement for callbacks.
127
+
پرومیسسازی (Promisification) یک روش عالی است، بهویژه زمانی که از async/await استفاده میکنید (که در ادامهی فصل info:async-await به آن پرداخته خواهد شد)، اما جایگزین کامل callbackها نیست.
128
128
129
-
Remember, a promise may have only one result, but a callback may technically be called many times.
129
+
به خاطر داشته باشید که یک Promise فقط میتواند یک نتیجه داشته باشد، اما از نظر فنی، یک callback ممکن است چندین بار فراخوانی شود.
130
130
131
-
So promisification is only meant for functions that call the callback once. Further calls will be ignored.
131
+
بنابراین، پرومیسسازی فقط برای توابعی مناسب است که callback را فقط یک بار فراخوانی میکنند. فراخوانیهای بعدی نادیده گرفته خواهند شد.
0 commit comments