」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > JavaScript 中基本物件和函數連結的原則是什麼?

JavaScript 中基本物件和函數連結的原則是什麼?

發佈於2024-11-08
瀏覽:187

What Are the Principles of Basic Object and Function Chaining in JavaScript?

了解 JavaScript 中的基本物件/函數鏈

函數鍊是一種程式設計技術,可讓開發人員建立按特定順序執行的操作序列。在 JavaScript 中,這是透過傳回函數本身和使用 this 關鍵字結合來實現的。

要了解連結的原理,讓我們來看一個工作範例:

var one = function(num) {
    this.oldnum = num;

    this.add = function() {
        this.oldnum  ;
        return this;
    }

    if (this instanceof one) {
        return this.one;
    } else {
        return new one(num);
    }
}
var test = one(1).add().add();

在此範例中,one 函數是用數字建構的。它定義了一個 add 函數,該函數增加 oldnum 屬性並傳回它。 if 語句檢查函數是否被當作建構函式呼叫(使用 new),如果不是,則傳回 one 的新實例。

表達式 one(1).add().add() 先建立一個new 一個對象,初始值為 1。然後,在此物件上呼叫 add 函數兩次,每次都會遞增 oldnum 屬性。最後,變數 test 保存結果,即 oldnum 設定為 3 的一個物件。

相較之下,以下範例沒有正確連結:

var gmap = function() {

    this.add = function() {
        alert('add');

        return this;
    }

    if (this instanceof gmap) {
        return this.gmap;
    } else {
        return new gmap();
    }

}
var test = gmap.add();

在這裡,gmap 函數不會在其方法中傳回 this,因此連結被破壞。表達式 gmap.add() 試圖呼叫 gmap 建構函數本身的 add 方法,這並不能如預期般運作。

成功連結的關鍵是 this 關鍵字的使用,它指的是當前物件。透過從方法傳回此值,呼叫者可以再次存取該物件並繼續操作序列。

連結是在 JavaScript 中編寫簡潔且富有表現力的程式碼的強大技術。透過理解上述原則,開發人員可以有效地利用連結來增強其應用程式功能。

版本聲明 本文轉載於:1729726477如有侵犯,請洽[email protected]刪除
最新教學 更多>
  • 您可以使用 Matplotlib 根據 Pandas 中的特定列值繪製彩色散佈圖嗎?
    您可以使用 Matplotlib 根據 Pandas 中的特定列值繪製彩色散佈圖嗎?
    使用 Pandas 和 Matplotlib 按列值對散點圖著色Matplotlib 是一個流行的 Python 庫,用於在Python。本文探討使用 Matplotlib 根據 Pandas DataFrame 特定列中的值對散佈圖進行著色。 導入和資料首先,我們導入必要的函式庫,包括 Matpl...
    程式設計 發佈於2024-11-08
  • 如何設定 PHP 上傳大檔案(最多 100MB)?
    如何設定 PHP 上傳大檔案(最多 100MB)?
    配置PHP 進行大檔案上傳上傳大檔案可能具有挑戰性,但使用正確的方法可以處理最多100 MB 的上傳PHP 配置。本文探討了 php.ini 檔案中啟用此類大檔案傳輸所需的變更。 要調整的主要設定與檔案上傳大小限制和請求處理時間相關:upload_max_filesize: 此值指定允許上傳的最大檔...
    程式設計 發佈於2024-11-08
  • 使用 Quarkus 和 GraalVM 本機映像增強 Java 微服務
    使用 Quarkus 和 GraalVM 本機映像增強 Java 微服務
    在现代软件开发的动态格局中,微服务已成为最受欢迎的架构方法。虽然这种方法提供了许多优点,但它也并非没有挑战。传统的基于 JVM 的服务经常会出现内存占用过大、启动时间过长以及 CPU 使用率过高等问题。这些挑战不仅影响技术方面,还会产生财务影响,从而显着影响运行和维护软件解决方案的总体成本。 ...
    程式設計 發佈於2024-11-08
  • 如何確定 C/C++ 編譯器中的行號?
    如何確定 C/C++ 編譯器中的行號?
    在C/C 編譯器中取得行號調試C/C 程式碼時,確定某一行所在的行號非常有用發生錯誤。常見的解決方案是手動為程式碼新增行號,但更有效的方法是使用內建預處理器巨集。 行號的標準預處理器宏C/C 標準定義了兩個預處理器巨集:__LINE__:提供文件中的目前行號。 __FILE__:提供目前檔案名稱。 ...
    程式設計 發佈於2024-11-08
  • 如何在 C++ 中安全地啟動執行檔:為什麼 CreateProcess() 是您的最佳選擇?
    如何在 C++ 中安全地啟動執行檔:為什麼 CreateProcess() 是您的最佳選擇?
    利用CreateProcess() 啟動可執行檔在本指南中,我們將探討如何從另一個C 執行檔中開啟執行檔(.exe )。 使用 system() 的陷阱在深入研究解決方案之前,強調使用 system() 函數的危險至關重要。 System() 有幾個缺點:它很糟糕,可能會減慢程式速度。 它會破壞安全...
    程式設計 發佈於2024-11-08
  • 如何用PHP和jQuery實現高效率的多檔案上傳?
    如何用PHP和jQuery實現高效率的多檔案上傳?
    使用PHP 和jQuery 有效上傳多個檔案在使用PHP 時,您可能會遇到需要同時上傳多個檔案的情況。讓我們探討如何使用 PHP 和 jQuery 實作多個檔案上傳功能。 PHP 和 HTML 配置在您的 HTML 表單中,您將有一個輸入字段,其中包含多個屬性設定允許多項選擇。 JavaScript...
    程式設計 發佈於2024-11-08
  • 如何在 JavaScript 中有效產生不重複隨機數?
    如何在 JavaScript 中有效產生不重複隨機數?
    在JS中產生不重複的隨機數在JS中產生不重複的隨機數可以使用多種技術來實現。最初,該方法是透過將新產生的數字新增至陣列並與其進行比較來檢查是否已建立新產生的數字。但是,由於過多的遞歸調用,這可能會導致“超出最大調用堆疊大小”錯誤。 一個有效的解決方案是產生一次隨機數字列表,然後按順序處理它。這種方法...
    程式設計 發佈於2024-11-08
  • 如何在共享託管平台上安裝 Composer?
    如何在共享託管平台上安裝 Composer?
    在共享託管平台上訪問Composer在共享託管環境上安裝Composer 面臨著獨特的挑戰,但只要採取正確的方法,這是可能的。讓我們探索一種行之有效的方法,在共享主機上取得 Composer,為您提供必要的可存取性。 首先,在您的系統上找到下載的composer.phar 檔案。找到後,繼續執行以下...
    程式設計 發佈於2024-11-08
  • 了解 MySQL 中的十進位資料類型
    了解 MySQL 中的十進位資料類型
    MySQL 中的 Decimal 資料類型對於金融相關專案至關重要,其中數值的精確度至關重要。最近,我在 Ruby on Rails 專案之一中使用此資料類型時遇到了問題。讓我分享一下我的經驗和學到的東西。 挑戰:超出範圍的數值錯誤 在我的專案期間,我在遷移文件中定義了 Decim...
    程式設計 發佈於2024-11-08
  • Filament 如何使用 Trait(建立、更新)後重新導向到清單頁面
    Filament 如何使用 Trait(建立、更新)後重新導向到清單頁面
    要在 Filament v3 中建立或更新資源後重定向到清單頁面,您可以在資源類別中使用自訂特徵。 建立自訂特徵 <?php namespace App\Traits; trait RedirectIndex { protected function getRedirectUrl()...
    程式設計 發佈於2024-11-08
  • 在閱讀本文之前,請勿使用 Prisma ORM!
    在閱讀本文之前,請勿使用 Prisma ORM!
    想像混亂情況,您在NeonDB 中創建一個具有0.5GB 存儲空間的免費數據庫,然後想,“很好,我將使用免費套餐進行測試” 。然後,幾個小時後,收到了致命的電子郵件:「您的儲存空間已被消耗!」。哇,你什麼意思?連椅子都沒有熱起來!答案是什麼呢?我使用了輝煌的 Prisma ORM,為了改進,我全天運...
    程式設計 發佈於2024-11-08
  • Net 套件如何影響 Go 程式中的死鎖偵測?
    Net 套件如何影響 Go 程式中的死鎖偵測?
    網路包導入和死鎖檢測的相互作用在Go 程序中,如果程式運行時通道操作阻塞,則程序最終會收到「死鎖」錯誤。但是,當導入 net 套件時,行為會改變。 有問題的程式碼片段:package main import ( "fmt" "net/http"...
    程式設計 發佈於2024-11-08
  • 如何從 MySQL 列資料建構 PHP 數組?
    如何從 MySQL 列資料建構 PHP 數組?
    從 MySQL 列資料建構 PHP 陣列使用 mysql_fetch_array 從 MySQL 列檢索資料會產生一個表示單行的陣列。要建立一個由特定列中所有行的值組成的數組,一種有效的方法是迭代該數組並組裝一個新數組:$column = array(); while ($row = mysql_f...
    程式設計 發佈於2024-11-08
  • Go中如何實現禁用語句的高效日誌記錄?
    Go中如何實現禁用語句的高效日誌記錄?
    Go 中禁用語句的高效日誌記錄在關鍵路徑中,嵌入可以動態切換的調試/跟踪日誌記錄語句是有益的運轉時。這種做法非常適合調試離線生產系統或測試鏡像生產環境的系統。 但是,這種類型的日誌記錄有一個關鍵要求:禁用的語句必須對效能影響最小。在 C/C 中,這是透過 LOG 巨集實現的,該巨集抑制參數求值,直到...
    程式設計 發佈於2024-11-08
  • 如何使用 JavaScript 正規表示式從 HTML 中提取多行文字?
    如何使用 JavaScript 正規表示式從 HTML 中提取多行文字?
    使用JavaScript 正規表示式從HTML 中提取多行文字當嘗試使用JavaScript 中的正規表示式從HTML 檢索字串時,這一點至關重要考慮修飾符的兼容性。在您的場景中,您遇到了多行標誌 (/m) 的問題。 Dotall 修飾符與JavaScript此問題源自於JavaScript 不支援...
    程式設計 發佈於2024-11-08

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3