搜尋
首頁web前端css教學過濾數據客戶端:比較CSS,jQuery和React

Filtering Data Client-Side: Comparing CSS, jQuery, and React

假設您有一個包含100個名稱的列表:

<code></code>
  • Randy Hilpert
  • Peggie Jacobi
  • Ethelyn Nolan Sr.

……或者文件名、電話號碼等等。您想在客戶端對它們進行過濾,這意味著您不會發出服務器端請求來搜索數據並返回結果。您只想鍵入“rand”,並讓它過濾列表以包含“Randy Hilpert”和“Danika Randall”,因為它們都包含該字符串。其他所有內容都不包含在結果中。

讓我們看看如何使用不同的技術來實現這一點。

CSS 可以做到,但需要一點幫助。

CSS 無法根據其包含的內容來選擇項目,但它可以根據屬性及其值進行選擇。因此,讓我們也將名稱移入屬性中。

<code></code>
  • Randy Hilpert
  • Peggie Jacobi
  • Ethelyn Nolan Sr. ...

現在,要過濾包含“rand”的名稱列表,非常容易:

 li {
  display: none;
}
li[data-name*="rand" i] {
  display: list-item;
}

請注意第4 行的i。這意味著“不區分大小寫”,在這裡非常有用。

為了使這個過濾器能夠動態工作,我們需要使用JavaScript 不僅要響應過濾器的輸入,還要生成與搜索內容匹配的CSS。

假設我們在頁面上有一個塊:

<style id="cssFilter">
  /* 动态生成的 CSS 将放在这里 */
  </style>

我們可以監視過濾器輸入的變化並生成該CSS:

 filterElement.addEventListener("input", e => {
  let filter = e.target.value;
  let css = filter ? `
    li {
      display: none;
    }
    li[data-name*="${filter}" i] {
      display: list-item;
    }
  ` : ``;
  window.cssFilter.innerHTML = css;
});

請注意,當過濾器為空時,我們清空樣式塊,因此顯示所有結果。

我承認利用CSS 來實現這一點有點奇怪,但如果您對這個概念感興趣,Tim Carry 曾將其進一步發展。

jQuery 使其變得更容易。

由於我們無論如何都需要JavaScript,因此jQuery 可能是一個可接受的工具。這裡有兩個值得注意的變化:

  • jQuery可以根據其包含的內容選擇項目。它有一個專門用於此的selector API。我們不再需要額外的屬性。
  • 這將所有過濾操作都保留在單一技術中。

我們仍然監視輸入的鍵入,然後如果我們有一個過濾器術語,我們隱藏所有列表項並顯示包含我們的過濾器術語的列表項。否則,我們再次顯示所有列表項:

 const listItems = $("li");

$("#filter").on("input", function() {
  let filter = $(this).val();
  if (filter) {
    listItems.hide();
    $(`li:contains('${filter}')`).show();
  } else {
    listItems.show();
  }
});

與CSS 相比,使過濾器不區分大小寫需要更多操作,但我們可以通過覆蓋默認方法來實現:

 jQuery.expr[':'].contains = function(a, i, m) {
  return jQuery(a).text().toUpperCase()
      .indexOf(m[3].toUpperCase()) >= 0;
};

React 可以使用狀態和渲染來僅渲染它需要的內容。

在React 中沒有一種正確的方法來實現這一點,但我認為將名稱列表作為數據(如數組)保留,遍歷它們,並且只渲染您需要的內容是React 式的。輸入中的更改會過濾數據本身,React 會根據需要重新渲染。

如果我們有names = [array, of, names],我們可以很容易地過濾它:

 filteredNames = names.filter(name => {
  return name.includes(filter);
});

這次,不區分大小寫可以這樣完成:

 filteredNames = names.filter(name => {
  return name.toUpperCase().includes(filter.toUpperCase());
});

然後,我們將在JSX 中執行典型的.map() 操作來遍歷我們的數組並輸出名稱。

我沒有任何特別的偏好

這不是您選擇技術的那種事情。您可以在您已經擁有的任何技術中完成它。我認為就技術債務而言,任何一種方法都不比其他方法更重。

以上是過濾數據客戶端:比較CSS,jQuery和React的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
'訂閱播客”鏈接應在哪裡?'訂閱播客”鏈接應在哪裡?Apr 16, 2025 pm 12:04 PM

有一段時間,iTunes是播客中的大狗,因此,如果您將“訂閱播客”鏈接到喜歡:

瀏覽器引擎多樣性瀏覽器引擎多樣性Apr 16, 2025 pm 12:02 PM

當他們在2013年去Chrome時,我們失去了歌劇。與Edge今年早些時候也進行了同樣的交易。邁克·泰勒(Mike Taylor)稱這些變化為“減少

網絡共享的UX注意事項網絡共享的UX注意事項Apr 16, 2025 am 11:59 AM

從垃圾點擊誘餌網站到大多數出版物的最多,共享按鈕長期以來一直無處不在。然而,這些

每周平台新聞:Apple部署網絡組件,漸進的HTML渲染,自託管關鍵資源每周平台新聞:Apple部署網絡組件,漸進的HTML渲染,自託管關鍵資源Apr 16, 2025 am 11:55 AM

在本週的綜述中,Apple進入Web組件,Instagram如何插入腳本以及一些思考的食物,以進行自託管關鍵資源。

git Pathspecs以及如何使用它們git Pathspecs以及如何使用它們Apr 16, 2025 am 11:53 AM

當我查看GIT命令的文檔時,我注意到其中許多人都有選擇。我最初以為這只是一個

產品圖像的彩色拾取器產品圖像的彩色拾取器Apr 16, 2025 am 11:49 AM

聽起來有點像一個困難的問題,不是嗎?我們經常沒有成千上萬種顏色的產品鏡頭,以便我們可以隨身攜帶。我們也不是

黑暗模式與React和Themeprovider切換黑暗模式與React和Themeprovider切換Apr 16, 2025 am 11:46 AM

我喜歡網站具有“暗模式”選項時。黑暗模式使我更容易閱讀網頁,並幫助我的眼睛更放鬆。許多網站,包括

帶有HTML對話框元素的一些動手帶有HTML對話框元素的一些動手Apr 16, 2025 am 11:33 AM

這是我第一次查看HTML元素。我已經意識到了一段時間,但是尚未將其旋轉。它很酷,

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.如果您聽不到任何人,如何修復音頻
1 個月前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

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

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境