javascript - 用于将迭代值(例如数组元素)插入 HTML 的简单 JavaScript 模板文字

标签 javascript html arrays templates template-literals

我想使用模板文字(即反引号)将数组中的元素插入到 HTML 中。本质上,我想创建自己的极其简单的模板系统。

我希望 forEach 能够工作,每个迭代回调只插入返回的文本。但是,它只返回 undefined,例如:

const myArray = ['square', 'triangle', 'circle'];
document.querySelector('div').innerHTML = `
  <p>Some shapes:<\p>
  <ul>
    ${myArray.forEach(elmt => `
      <li>${elmt}</li>
    `)}
  </ul>
`;
<div></div>

那么,我该怎么做呢?

最佳答案

使用myArray.map(...).join('')而不是myArray.forEach(...)

在模板文字中,占位符内的代码结果(即 ${...} 内)在插入之前被强制转换为字符串。 forEach(...) 循环仅返回 undefined根据定义。相反,map(...) 返回一个可用值,即 array 。但是,当数组被强制转换为字符串时,默认情况下会在元素之间插入逗号。这会导致在预期插入之间出现不需要的文本节点,每个节点都包含一个逗号。但是,可以通过使用 .join('') 将数组元素与空字符串显式连接来更改此默认值:

const myArray = ['square', 'triangle', 'circle'];
document.querySelector('div').innerHTML = `
  <p>Some shapes:<\p>
  <ul>
    ${myArray.map(elmt => `
      <li>${elmt}</li>
    `).join('')}
  </ul>
`;
<div></div>

请注意,此策略可以轻松地与其他可迭代对象一起使用,只需首先将它们强制转换为数组即可,例如使用 [...mySet].map... 而不是 myArray.map...

关于javascript - 用于将迭代值(例如数组元素)插入 HTML 的简单 JavaScript 模板文字,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50574786/

相关文章:

c++ - 用 char* 增加数组 [C++]

javascript - var at 循环的最佳用法

javascript - 检查页面是否使用 JavaScript 中的 asp.net ajax

javascript - 展开多个 div 以适应屏幕的水平宽度

html - IE 与表单 css 样式不兼容

c - 在C中的函数中打印数组中的字符串

javascript - 使用 Jquery 可拖动和调整大小的文本区域 - 无法使用左键单击输入文本

javascript - 套接字 IO 不发送数组

html - 为什么 ✓ 符号有时会被替换为“一个”?

c++ - 在对象数组中查找最后使用的元素