2

这是 JavaScript 对象中的代码

const AlbumDetails = [
{
    name: '<i class="fas fa-check">Basic</i>',
    price: '',
    details: [],
},
{ name: '<i class="fas fa-check">Intermediate</i>', price: '', details: [] },
{ name: '<i class="fas fa-check">Pro</i>', price: '', details: [] },
{ name: '<i class="fas fa-check">Ultimate</i>', price: '', details: [] },
];

export default AlbumDetails;

我想像这样使用这个对象

const PriceCard = (props) => {
<div className="p-box">
                    
    <div className="p-content">
        <h2>{props.AlbumDetails[0].name}</h2>
        <h4>{props.AlbumDetails[0].price}</h4>
        
        
    </div>
</div>
}

很快。在浏览器中,它显示<i class="fas fa-check">Basic</i>,但我只想要图标和名称“基本”。那么怎么可能做到。

4

3 回答 3

1

与其将整个 JSX 保存在数组中,不如只将单词保存在数组中

const AlbumDetails = [
{
    name: 'Basic',
    price: '',
    details: [],
},
{ name: 'Intermediate', price: '', details: [] },
{ name: 'Pro', price: '', details: [] },
{ name: 'Ultimate', price: '', details: [] },

并将 JSX 保留在组件中,而只访问这样的内容

const PriceCard = (props) => {
<div className="p-box">
                    
    <div className="p-content">
        <h2><i class="fas fa-check">{props.AlbumDetails[0].name}</i></h2>
        <h4>{props.AlbumDetails[0].price}</h4>
    </div>
</div>
于 2021-06-03T11:29:55.733 回答
1

可以使用dangerouslySetInnerHTML插入 HTML 字符串:

<h2 dangerouslySetInnerHTML={{ __html: props.AlbumDetails[0].name }} />

注意:您需要确保 HTML 是安全的(即不是由用户输入形成的),否则您可能会对 XSS 开放。

于 2021-06-03T11:27:46.407 回答
1

从您的示例中,我看到您正在尝试显示同一数据源的多个元素。您可以使用 JavaScript map() 函数,这样您就不必使用索引来引用它们并避免重复的代码行。请参考以下代码。

const AlbumDetails = [
  {
    name: '<i class="fas fa-check">Basic</i>',
    price: "",
    details: []
  },
  { name: '<i class="fas fa-check">Intermediate</i>', price: "", details: [] },
  { name: '<i class="fas fa-check">Pro</i>', price: "", details: [] },
  { name: '<i class="fas fa-check">Ultimate</i>', price: "", details: [] }
];

const PriceCard = (props) => (
  <div className="p-box">
    <div className="p-content">
      {props.AlbumDetails.map((album) => (
        <div key={album.name}>
          <h2>{album.name}</h2>
          <h4>{album.price}</h4>
        </div>
      ))}
    </div>
  </div>
);

您可以在此处阅读有关此内容的更多信息

于 2021-06-03T11:41:14.743 回答