Chrome 117 版新功能

以下是一些注意事項:

我是 Adriana Jara一起來深入探索 Chrome 117 為開發人員推出的新功能。

新增用於進入及離開動畫的 CSS 功能。

透過這三項新的 CSS 功能,你可以輕鬆新增進入及離開動畫。 並流暢地與頂層可關閉元素 (例如對話方塊和彈出式視窗) 之間建立動畫效果。

第一項功能是 transition-behavior。如要轉換離散屬性 (例如 display),請使用 transition-behaviorallow-discrete 值。

.card {
  transition: opacity 0.25s, display 0.25s;
  transition-behavior: allow-discrete; /* Note: be sure to write this after the shorthand */
}

.card.fade-out {
  opacity: 0;
  display: none;
}

然後,使用 @starting-style 規則為 display: none 和頂層的進入效果建立動畫。請使用 @starting-style 套用樣式,讓瀏覽器在開啟該元素前可先查詢樣式。

/*  0. BEFORE-OPEN STATE   */
/*  Starting point for the transition */
@starting-style {
  .item {
    opacity: 0;
    height: 0;
  }
}

/*  1. IS-OPEN STATE   */
/*  The state at which the element is open + transition logic */
.item {
  height: 3rem;
  display: grid;
  overflow: hidden;
  transition: opacity 0.5s, transform 0.5s, height 0.5s, display 0.5s allow-discrete;
}

/*  2. EXITING STATE   */
/*  While it is deleting, before DOM removal in JS, apply this
    transformation for height, opacity, and a transform which
    skews the element and moves it to the left before setting
    it to display: none */
.is-deleting {
  opacity: 0;
  height: 0;
  display: none;
  transform: skewX(50deg) translateX(-25vw);
}

最後,如要從頂層淡出 popoverdialog,請將 overlay 屬性新增至轉場效果清單。在轉場效果或動畫中加入重疊元素,以動畫呈現其餘地圖項目,並在動畫播放時保持在頂層圖層。這樣看起來會更順暢。

[open] {
  transition: opacity 1s, display 1s allow-discrete;
}
[open] {
  transition: opacity 1s, display 1s allow-discrete, overlay 1s allow-discrete;
}

請參閱四個 CSS 功能新增流暢的進入及離開動畫,進一步瞭解如何使用這些功能改善透過動態效果的使用者體驗。

陣列分組

在程式設計中,陣列分組是非常常見的作業,當我們使用 SQL 的 GROUP BY 子句和 MapReduce 程式設計 (較想寫成 map-group-reduce 來說),是最常見的作業。

將資料編入群組的功能,可讓開發人員計算順序較高的資料集。 例如同類群組的平均年齡或網頁的每日 LCP 值。

陣列分組功能可新增 Object.groupByMap.groupBy 靜態方法,來支援這些情境。

groupBy 會為可疊代項目中的每個元素呼叫一次提供的回呼函式。回呼函式應傳回一個字串或符號,指出相關元素的群組。

在下方示例中,MDN 說明文件顯示了包含 groupBy 方法的一系列產品,用來傳回按照類型分組的產品。

const inventory = [
  { name: "asparagus", type: "vegetables", quantity: 5 },
  { name: "bananas", type: "fruit", quantity: 0 },
  { name: "goat", type: "meat", quantity: 23 },
  { name: "cherries", type: "fruit", quantity: 5 },
  { name: "fish", type: "meat", quantity: 22 },
];

const result = Object.groupBy(inventory, ({ type }) => type);

/* Result is:
{
  vegetables: [
    { name: 'asparagus', type: 'vegetables', quantity: 5 },
  ],
  fruit: [
    { name: "bananas", type: "fruit", quantity: 0 },
    { name: "cherries", type: "fruit", quantity: 5 }
  ],
  meat: [
    { name: "goat", type: "meat", quantity: 23 },
    { name: "fish", type: "meat", quantity: 22 }
  ]
}
*/

詳情請參閱 groupBy 說明文件

開發人員工具中的本機覆寫設定已簡化。

本機覆寫功能現已簡化,因此您不必存取這些資源,就能輕鬆從「網路」面板中模擬回應標頭和遠端資源的網路內容。

如要覆寫網路內容,請開啟「網路」面板,在要求上按一下滑鼠右鍵,然後選取「覆寫內容」

要求下拉式選單中的覆寫選項。

如果您已設定本機覆寫功能但已停用,開發人員工具就會啟用。如果尚未設定,開發人員工具會在頂端的動作列中顯示提示。選取要儲存覆寫值的資料夾,並允許開發人員工具存取該資料夾。

選取資料夾,並在頂端的動作列中授予該資料夾的存取權。

覆寫值設定完成後,開發人員工具就會將您導向「來源」>覆寫值 >編輯器可讓您覆寫網頁內容

請注意,在「網路」面板中,遭覆寫的資源會以 已儲存。 表示。將滑鼠遊標懸停在圖示上,即可查看遭到覆寫的項目。

在「網路」面板中的要求旁邊顯示覆寫圖示。

如要瞭解 Chrome 開發人員工具第 117 版有哪些詳情和更多資訊,請查看開發人員工具的新功能

還有更多獎品等著您!

當然,還有許多其他功能

延伸閱讀

這只涵蓋部分重要亮點。請點選下方連結查看 Chrome 117 的其他變更。

訂閱

歡迎訂閱 Chrome Developers YouTube 頻道, 每次推出新影片時,您都會收到電子郵件通知。

Yo soy Adriana Jara 等 Chrome 117 推出後,立即向各位說明 Chrome 的新功能!