如何在 {{#each}} 循环中为元素添加分隔符,但不在最后一个元素后添加?

AI 编程助手,豆包旗下的编程助手,提供智能补全、智能预测、智能问答等能力,节省开发时间,释放脑海中的创造力,支持 VSCode,点击体验 AI

在前端开发中,我们经常需要通过模板引擎来渲染列表。对于这种情况,我们通常使用 Handlebars.js 来处理模板渲染。其中,我们可能会遇到一些问题,例如如何在 {{#each}} 循环中为元素添加分隔符,但不在最后一个元素后添加。

解决方案

方法1:使用 CSS 伪类

我们可以使用 CSS 中的伪类 :not(:last-child) 来选择所有不是最后一个子元素的元素,并在其后添加分隔符。

HTML:

--- -------------
  ------- -------
    -----------------
  ---------
-----

CSS:

----- -------------------------- -
  -------- -- --
-

此方法简单易行,只需要少量的 CSS 即可轻松解决问题。但是,它可能会导致以下问题:

  • 在最后一个元素后仍然会产生逗号。虽然不会影响页面显示,但这可能会影响一些程序员的完美主义。
  • 当分隔符不是逗号时,例如短横线或竖线,这个方法就不能使用了。

方法2:使用 Handlebars Helper

我们可以编写一个 Handlebars Helper 来动态生成分隔符。这种方法可以解决在最后一个元素后添加分隔符的问题。

JavaScript:

--------------------------------- --------------- -------- -
  --- --------- - ----------------- -- -- --
  --- ------ - ---
  ------- ---- --------------- ---- -
    ---- - -- ------ -- ----------
    ------ -- ---------------------
  -
  ------ -------
---

使用 Helper:

--- -------------
  ------- ----- ------------ ---
    -----------------
  ---------
-----

这种方法能够解决所有问题,但是需要编写一些 JavaScript 代码,稍微有点复杂。

总结

在 Handlebars.js 中,我们可以通过 CSS 伪类或者编写 Handlebars Helper 来为循环中的元素添加分隔符。使用哪种方法取决于你的具体需求。如果你只需要简单的逗号分隔符,并不关心最后一个元素的问题,那么使用 CSS 伪类就好了。但是如果你还需要更灵活的分隔符控制,那么编写 Handlebars Helper 是个不错的选择。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/605434cd8d846479e750ad6a


猜你喜欢

  • npm 包 nxus-pipeliner 使用教程

    在前端开发中,我们经常需要处理复杂的数据和业务逻辑。为了更加高效、优雅地完成这些任务,我们可以使用 nxus-pipeliner 这个 NPM 包。它提供了一种流水线式的数据处理方式,可以有效地简化前...

    4 年前
  • npm 包 oauth-url 使用教程

    随着互联网的发展,越来越多的网站和应用需要用户授权登录。OAuth 是一种开放标准,可以让用户授权第三方应用访问他们的数据。在前端开发中,使用 OAuth 可以快速地实现用户授权登录,提高用户体验。

    4 年前
  • npm 包 oauth-wrap 使用教程

    什么是 oauth-wrap? oauth-wrap 是一个 npm 包,它提供了一个简单且高效的方法来使用 OAuth 包装器来进行身份验证和授权。OAuth-wrap 是为 Javascript ...

    4 年前
  • npm 包 oauth-zero-legged 使用教程

    以现代化的 Web 应用为例,几乎所有的应用都支持第三方登录,最常见的是使用 Google、Facebook、Twitter 或 GitHub 等帐户进行认证。开发人员需要在自己的应用中实现 OAut...

    4 年前
  • npm 包 oauth2-auth 使用教程

    前言 在前端开发中,经常需要使用 OAuth2 来实现用户授权登录等功能。在这个过程中,oauth2-auth 包就成了一个不可或缺的利器。本文将为大家介绍 oauth2-auth 包的使用教程,帮助...

    4 年前
  • npm 包 nutra-jspm 使用教程

    简介 在前端开发中,随着项目规模的扩大,依赖关系也变得愈发复杂。为了便于管理依赖以及提高项目的可维护性,出现了一系列的 package manager,npm 是其中最流行的一个。

    4 年前
  • npm 包 nutjar 使用教程

    简介 nutjar 是一个 npm 包,它可以帮助前端开发人员更轻松地处理和管理复杂的业务逻辑。该包提供了一组工具函数和类,用于处理数据,打印日志,以及管理错误等。

    4 年前
  • git status 返回“fatal: Not a git repository but .git exists and HEAD has proper permissions”错误的解决方法

    在使用 Git 进行版本控制时,有时候我们会遇到 “fatal: Not a git repository but .git exists and HEAD has proper permission...

    4 年前
  • NPM 包 Nutritionix 使用教程

    在当今互联网时代,人们对于健康饮食的需求越来越高,而对于开发者,我们也需要提供一些帮助用户更加方便地获取食品营养成分信息的解决方案。Nutritionix 就是一个提供有关食品营养成分数据的API,本...

    4 年前
  • npm 包 nuts-scss 使用教程

    什么是 nuts-scss nuts-scss 是一个可以帮助前端开发者更加便捷地使用 SCSS 的 npm 包。它提供了丰富的 mixin、变量和函数,可以极大地提高前端开发效率。

    4 年前
  • npm 包 nutshell-api-client 使用教程

    简介 nutshell-api-client 是一款前端类 npm 包,用于与 nutshell API 进行交互,提供了完整的 API 接口并支持扩展。本文将详细介绍该包的使用方法和核心功能。

    4 年前
  • npm 包 nutty 使用教程

    npm 是前端开发者必不可少的工具之一,它为我们提供了大量的包和工具,帮助我们快速开发。其中一个非常好用的包就是 nutty,本文将详细介绍 nutty 的使用教程。

    4 年前
  • npm 包 nxus-renderer 使用教程

    在现代 web 开发中,前端技术已经成为开发过程中不可或缺的一部分。而 npm 是前端技术中的重要组成部分之一,它提供了很多有用的 npm 包,可以快速实现开发过程中的需求。

    4 年前
  • npm 包 nxus-rest-api 使用教程

    介绍 nxus-rest-api 是一个开源的 Node.js 包,它可以帮助前端开发者快速搭建 RESTful 风格的 API 接口。它的核心理念是简单和灵活,允许你根据自己的需求设计并构建 API...

    4 年前
  • npm 包 nxus-static-site 使用教程

    nxus-static-site 是一个基于 Node.js 平台的静态网站生成器,它使用了 Nxus 框架和 Handlebars 模板引擎,提供了一种快速简单的方式生成静态网站。

    4 年前
  • npm 包 nxus-stripe 使用教程

    简介 nxus-stripe 是一个使用 Node.js 开发的 Stripe 插件,可用于前端项目中处理 Stripe 支付。它简化了开发过程,提高了代码效率和可读性。

    4 年前
  • npm 包 oauth2-client-js 使用教程

    在前端开发中,使用 OAuth2 可以实现授权认证、单点登录等功能,但是 OAuth2 的实现并不简单。为了方便开发者的使用,社区中涌现出了许多可供选择的 npm 包。

    4 年前
  • npm 包 oauth2-errorhandlers 使用教程

    在前端开发中,我们经常会用到第三方登录授权功能,如使用 GitHub、Google、Facebook 等账户登录网站。其中,OAuth2 作为一种通用授权标准,成为了很多服务提供商实现授权的前置条件。

    4 年前
  • npm 包 nutra-mock 使用教程

    Nutra-mock 是一个基于 Node.js 的 mock 数据生成工具,可以帮助我们快速、方便地生成测试数据以及模拟接口返回数据。在前端开发中,mock 数据经常用于前后端分离开发时,前端团队可...

    4 年前
  • npm 包 nutra-plugin 使用教程

    介绍 nutra-plugin 是一个前端 npm 包,提供了一些有用的工具函数和模块,可以帮助我们更高效、更简洁地开发前端项目。 安装和使用 安装 使用 npm 安装: --- ------- -...

    4 年前

相关推荐

    暂无文章