搜尋
首頁後端開發Python教學Python 化 JavaScript

Python 化 JavaScript

Jan 14, 2025 pm 10:19 PM

Pythonizing JavaScript

Python 擁有許多強大的實用函數,例如 rangeenumeratezip 等,這些函數基於可迭代物件和迭代器協定建構。結合生成器函數,這些協議自 2016 年左右起就在所有 Evergreen 瀏覽器和 Node.js 中可用,但在我看來,它們的使用率卻低得令人吃驚。在這篇文章中,我將使用 TypeScript 實作其中一些輔助函數,希望能改變這個現狀。

迭代器、可迭代物件和生成器函數

迭代器協定

迭代器協定是一種產生值序列的標準方法。要使一個物件成為迭代器,它必須透過實作 next 方法來遵守迭代器協議,例如:

const iterator = {
  i: 0,
  next() {
    return { done: false, value: this.i++ };
  }
};

然後,我們可以重複呼叫 next 方法來取得值:

console.log(iterator.next().value); // → 0
console.log(iterator.next().value); // → 1
console.log(iterator.next().value); // → 2
console.log(iterator.next().value); // → 3
console.log(iterator.next().value); // → 4

next 方法應該傳回一個對象,該物件包含一個 value 屬性(包含實際值)和一個 done 屬性(指定迭代器是否已耗盡,即是否無法再產生值)。根據 MDN 的說法,這兩個屬性都不是嚴格必需的,如果兩者都缺失,則傳回值被視為 { done: false, value: undefined }

可迭代物件協定

可迭代物件協定允許物件定義其自身的迭代行為。要遵守可迭代物件協議,物件必須使用 Symbol.iterator 鍵定義一個方法,該方法傳回一個迭代器。許多內建物件(如 ArrayTypedArraySetMap)都實現了此協議,因此可以使用 for...of 循環對其進行迭代。

例如,對於數組,values 方法被指定為數組的 Symbol.iterator 方法:

console.log(Array.prototype.values === Array.prototype[Symbol.iterator]); // → true

我們可以結合迭代器和可迭代物件協定來建立一個可迭代的迭代器,如下所示:

const iterable = {
  i: 0,
  [Symbol.iterator]() {
    const iterable = this;
    return {
      next() {
        return { done: false, value: iterable.i++ };
      }
    };
  }
};

這兩個協議的名稱不幸地非常相似,至今仍然讓我感到困惑。

正如您可能猜到的那樣,我們的迭代器和可迭代物件範例是無限的,這意味著它們可以永遠生成值。這是一個非常強大的特性,但也容易成為一個陷阱。例如,如果我們要在一個for...of 循環中使用可迭代對象,則循環將永遠持續下去;或者用作Array.from 的參數,JS 最終會拋出一個RangeError,因為數組會變得太大:

// 将无限循环:
for (const value of iterable) {
  console.log(value);
}

// 将抛出 RangeError
const arr = Array.from(iterable);

迭代器和可迭代物件甚至可以無限的原因是它們是惰性求值的,即只有在使用時才會產生值。

生成器函數

雖然迭代器和可迭代物件是寶貴的工具,但編寫起來有點麻煩。作為替代方案,引入了生成器函數。

產生器函數使用function* (或function *,星號可以在function 關鍵字和函數名稱之間任意位置)指定,允許我們中斷函數的執行,使用yield 關鍵字傳回值,並在稍後繼續中斷的地方繼續執行,同時保持其內部狀態:

const iterator = {
  i: 0,
  next() {
    return { done: false, value: this.i++ };
  }
};

Python 實用程式

如引言中所述,Python 有一些非常有用的內建實用程序,它們基於上述協定。 JavaScript 最近也為迭代器增加了一些輔助方法,例如 .drop().filter(),但(也許還沒有)擁有 Python 中一些更有趣的實用程式。

讓我們動手實踐吧!

現在理論部分已經結束,讓我們開始實作一些 Python 函數吧!

注意:此處顯示的這些實作都不應原樣用於生產環境。 它們缺乏錯誤處理和邊界條件檢查。

enumerate(iterable [,start])

Python 中的 enumerate 為輸入序列或可迭代物件中的每個項目傳回一系列元組,其中第一個位置包含計數,第二個位置包含項目:

console.log(iterator.next().value); // → 0
console.log(iterator.next().value); // → 1
console.log(iterator.next().value); // → 2
console.log(iterator.next().value); // → 3
console.log(iterator.next().value); // → 4

enumerate 也接受一個可選的 start 參數,指示計數器應從何處開始:

console.log(Array.prototype.values === Array.prototype[Symbol.iterator]); // → true

讓我們使用生成器函數在 TypeScript 中實現它。我們可以使用 python 文件中概述的實作作為指導

const iterable = {
  i: 0,
  [Symbol.iterator]() {
    const iterable = this;
    return {
      next() {
        return { done: false, value: iterable.i++ };
      }
    };
  }
};

由於 JavaScript 中的字串實現了可迭代物件協議,我們可以簡單地將字串傳遞給我們的 enumerate 函數並像這樣調用它:

// 将无限循环:
for (const value of iterable) {
  console.log(value);
}

// 将抛出 RangeError
const arr = Array.from(iterable);

repeat(elem [,n])

repeat 是內建 itertools 函式庫的一部分,它重複給定的輸入 elem n 次,如果未指定 n,則無限重複。我們再次可以將 python 文件中的實作作為起點。

function* sequence() {
  let i = 0;
  while (true) {
    yield i++;
  }
}

const seq = sequence();
console.log(seq.next().value); // → 0;
console.log(seq.next().value); // → 1;
console.log(seq.next().value); // → 2;

// 将无限循环,从 3 开始
for (const value of seq) {
  console.log(value);
}

(此處省略了 cyclerange 函數的實現,因為篇幅過長,但其邏輯與原文相同,只是將程式碼用 TypeScript 重寫)

結論

這是我的第一篇部落格文章,我希望您覺得它有趣,也許您會在未來的專案中使用迭代器、可迭代物件和生成器。如果您有任何疑問或需要澄清,請留下評論,我很樂意提供更多資訊。

要注意的是,與使用計數器的原始 for 循環相比,效能相差甚遠。這在許多情況下可能無關緊要,但在高性能場景中絕對很重要。當我將 PCM 資料繪製到畫布上並使用迭代器和生成器時,發現幀丟失了,這讓我很苦惱。事後看來這可能是顯而易見的,但當時對我來說卻並非如此 :D

乾杯!

以上是Python 化 JavaScript的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
Python:自動化,腳本和任務管理Python:自動化,腳本和任務管理Apr 16, 2025 am 12:14 AM

Python在自動化、腳本編寫和任務管理中表現出色。 1)自動化:通過標準庫如os、shutil實現文件備份。 2)腳本編寫:使用psutil庫監控系統資源。 3)任務管理:利用schedule庫調度任務。 Python的易用性和豐富庫支持使其在這些領域中成為首選工具。

Python和時間:充分利用您的學習時間Python和時間:充分利用您的學習時間Apr 14, 2025 am 12:02 AM

要在有限的時間內最大化學習Python的效率,可以使用Python的datetime、time和schedule模塊。 1.datetime模塊用於記錄和規劃學習時間。 2.time模塊幫助設置學習和休息時間。 3.schedule模塊自動化安排每週學習任務。

Python:遊戲,Guis等Python:遊戲,Guis等Apr 13, 2025 am 12:14 AM

Python在遊戲和GUI開發中表現出色。 1)遊戲開發使用Pygame,提供繪圖、音頻等功能,適合創建2D遊戲。 2)GUI開發可選擇Tkinter或PyQt,Tkinter簡單易用,PyQt功能豐富,適合專業開發。

Python vs.C:申請和用例Python vs.C:申請和用例Apr 12, 2025 am 12:01 AM

Python适合数据科学、Web开发和自动化任务,而C 适用于系统编程、游戏开发和嵌入式系统。Python以简洁和强大的生态系统著称,C 则以高性能和底层控制能力闻名。

2小時的Python計劃:一種現實的方法2小時的Python計劃:一種現實的方法Apr 11, 2025 am 12:04 AM

2小時內可以學會Python的基本編程概念和技能。 1.學習變量和數據類型,2.掌握控制流(條件語句和循環),3.理解函數的定義和使用,4.通過簡單示例和代碼片段快速上手Python編程。

Python:探索其主要應用程序Python:探索其主要應用程序Apr 10, 2025 am 09:41 AM

Python在web開發、數據科學、機器學習、自動化和腳本編寫等領域有廣泛應用。 1)在web開發中,Django和Flask框架簡化了開發過程。 2)數據科學和機器學習領域,NumPy、Pandas、Scikit-learn和TensorFlow庫提供了強大支持。 3)自動化和腳本編寫方面,Python適用於自動化測試和系統管理等任務。

您可以在2小時內學到多少python?您可以在2小時內學到多少python?Apr 09, 2025 pm 04:33 PM

兩小時內可以學到Python的基礎知識。 1.學習變量和數據類型,2.掌握控制結構如if語句和循環,3.了解函數的定義和使用。這些將幫助你開始編寫簡單的Python程序。

如何在10小時內通過項目和問題驅動的方式教計算機小白編程基礎?如何在10小時內通過項目和問題驅動的方式教計算機小白編程基礎?Apr 02, 2025 am 07:18 AM

如何在10小時內教計算機小白編程基礎?如果你只有10個小時來教計算機小白一些編程知識,你會選擇教些什麼�...

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具