亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

探索JavaScript未來模式匹配的引入分析

 更新時間:2023年10月31日 08:58:46   作者:王大冶  
這篇文章主要來帶大家探索JavaScript的未來,關(guān)于模式匹配的引入為編程體驗帶來革命性變化分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

引言

今天,揭開一個令人興奮的功能的面紗,這個功能通常在 Elixir 這樣的函數(shù)式編程語言中看到,現(xiàn)在被提議用于 JavaScript ——模式匹配

"你好,JavaScript!"

動手試試。這里有一個超基礎的函數(shù)叫做 greet,它接受一個帶有'ID'和'role'的用戶,并根據(jù)用戶角色返回問候語。聽起來簡單嗎?

function greet({id, role}) {
    if (role == 'user'){
        return `Hello User ${id}`;
    }
    if (role == 'admin'){
        return `Hello Admin ${id}`;
    }
    if (role == 'owner'){
        return `Hello Owner ${id}`;
    }
    throw `Invalid role: ${role}`;
}

這很像一個 switch 語句,但我們很難說這完全準確——它笨拙,充斥著討厭的if 語句,對于一個未定義的角色還有一個錯誤陷阱。

function greet({id, role}) {
    switch (role){
        case 'user':
            return `Hello User ${id}`;
        case 'admin':
            return `Hello Admin ${id}`;
        case 'owner':
            return `Hello Owner ${id}`;
        default:
            throw `Invalid role: ${role}`;
    }
}

switch 還可以,但這里我們遇到了一個問題--如果不使用一些奇怪的黑客手段,例如在 true 上進行切換,它就無法完成足夠的工作。

簡化復雜性的模式匹配藝術(shù)

模式匹配可以結(jié)束這種復雜性。想象一個你有一個 when 子句可以救我們擺脫這種冗長的迷宮的世界。

簡單地說,模式匹配允許我們檢查一個輸入是否符合一個模式或一個特定的類型。

在繼續(xù)之前,需求注意的——現(xiàn)在看的是一個提議。所以,這可能還不是最終的語法。

let greet = match (input) {
  when { role: "user" }: `Hello User ${input.id}`,
  when { role: "admin" }: `Hello Admin ${input.id}`,
  when { role: "owner" }: `Hello Owner ${input.id}`,
  _: throw `Invalid role: ${input.role}`,
}

在這里,match函數(shù)接受輸入,when子句檢查 input 中的角色是否匹配指定的角色 - useradminowner

這樣更清晰,不是嗎?不再有 if或 switch clutter - 只有一個簡潔而干凈的表達式。這不僅允許更易讀和可維護的代碼,而且為基于輸入屬性的更簡單的“行內(nèi)”決策鋪平了道路,使條件、行為和結(jié)果非常容易同時閱讀。

這會改變JavaScript的未來嗎?

我真的相信模式匹配可以極大地改善JavaScript的未來。通過直接從Elixir這樣的其他語言中獲取關(guān)鍵的想法,并與JavaScript的強大靈活性結(jié)合,我們肯定可以為“JavaScript之家”增加一個頂石。

但是,我希望看到我們最喜歡的語言走得更遠,尤其是當模式匹配與函數(shù)定義結(jié)合使用時。這可能會讓我們走出舒適區(qū),但一旦你開始探索它,你就會意識到它所擁有的力量和它帶來的簡單性。

def greet(%{role: "user", id: id}), do: `Hello User #{id}`
def greet(%{role: "admin", id: id}), do: `Hello Admin #{id}`
def greet(%{role: "owner", id: id}), do: `Hello Owner #{id}`
def greet(%{role: _}), do: throw `Invalid role`

在這個 Elixir 代碼示例中,我們根據(jù)輸入重新定義了函數(shù)三次。除了它給予的直接清晰性外,解剖這一點,我們注意到它做了兩件事——它修剪了句法復雜性,顯著減少了理解代碼所需的心智負擔。

希望有一天JavaScript能夠?qū)崿F(xiàn)這種基于模式的函數(shù)重載,相信這將帶來一些最好的編程體驗。就JavaScript的未來而言,作者認為模式匹配是最令人興奮的前景之一。

以上就是JavaScript模式匹配的詳細內(nèi)容,更多關(guān)于JavaScript模式匹配的未來的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 學習筆記編寫vue的第一個程序

    學習筆記編寫vue的第一個程序

    這篇文章主要介紹了學習筆記vue的第一個程序,其中非常詳細的為大家講解了vue程序的創(chuàng)建步驟,有需要的朋友可以學習下,希望可以有所幫助
    2021-08-08
  • 微信小程序 Video API實例詳解

    微信小程序 Video API實例詳解

    這篇文章主要介紹了 微信小程序 Video API實例詳解,需要的朋友可以參考下
    2016-10-10
  • 使用HTTP?Referer實現(xiàn)圖片防盜圖文示例詳解

    使用HTTP?Referer實現(xiàn)圖片防盜圖文示例詳解

    這篇文章主要為大家介紹了使用HTTP?Referer實現(xiàn)圖片防盜圖文示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • 微信小程序 require機制詳解及實例代碼

    微信小程序 require機制詳解及實例代碼

    這篇文章主要介紹了微信小程序 require機制詳解及實例代碼的相關(guān)資料,需要的朋友可以參考下
    2016-12-12
  • 微信小程序 登錄實例詳解

    微信小程序 登錄實例詳解

    這篇文章主要介紹了微信小程序 登錄實例詳解的相關(guān)資料,需要的朋友可以參考下
    2017-01-01
  • JS前端宏任務微任務及Event Loop使用詳解

    JS前端宏任務微任務及Event Loop使用詳解

    這篇文章主要為大家介紹了JS前端宏任務微任務及Event Loop使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • 微信小程序 二維碼canvas繪制實例詳解

    微信小程序 二維碼canvas繪制實例詳解

    這篇文章主要介紹了微信小程序 二維碼canvas繪制實例詳解的相關(guān)資料,這里附有實例代碼,微信小程序 使用canvas 進行二維碼的繪制,需要的朋友可以參考下
    2017-01-01
  • electron?中?webview的使用示例解析

    electron?中?webview的使用示例解析

    這篇文章主要為大家介紹了electron?中?webview的使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • JavaScript的單線程和異步詳細

    JavaScript的單線程和異步詳細

    這篇文章要給大家分享的是JavaScript的單線程和異步,其實單線程和異步確實不能同時成為一個語言的特性,js選擇了成為單線程的語言,所以它本身不可能是異步的,但js宿主環(huán)境是多線程,宿主環(huán)境通過某種方式使js具備了異步屬性,下面就來具體介紹,需要的朋友可以參考一下
    2021-10-10
  • js 標簽語法使用詳情

    js 標簽語法使用詳情

    這篇文章主要介紹了js 標簽語法使用,在 JavaScript 中提供了標簽語句,用于標記指定的代碼塊,便于跳轉(zhuǎn)到指定的位置。本文來記錄一下標簽語句的使用方法,需要的朋友可以參考一下
    2021-10-10

最新評論