javascript - 根据react中对象的索引渲染不同的html

标签 javascript html reactjs meteor collections

在我的 meteor 项目中,我有一个名为拍卖的集合。我希望使用 React 来渲染此拍卖的 3 列,行数不受限制。为了实现这一点,我认为可以发送对象的索引,但我不知道如何做到这一点。另一个问题是它显示 html 代码错误,因为我没有关闭“div”标签。

这是我的 App.js:

            import React, { Component } from 'react';
            import ReactDOM from 'react-dom';
            import { withTracker } from 'meteor/react-meteor-data';

            import { Auctions } from '../api/auctions.js';

            import Auction from './Auction.js';

            //App component - represents the whole app
            class App extends Component {
                renderAuctions() {
                    return this.props.auctions.map((auction, index) => (
                        <Auction key={auction._id} auction={auction} index={index} />
                    ));
                }

                render() {
                    return (
                        <div className="container section">
                            <div className="row">
                                {this.renderAuctions()}
                            </div>
                        </div>
                    );
                }
            }

            export default withTracker(() => {
                return {
                    auctions: Auctions.find({}).fetch(),
                };
            })(App);

还有我的 Auction.js:

            import React, { Component } from 'react';

            //Task component - resepresnts a single todo item

            export default class Auction extends Component {
                render() {
                    if(index % 3 === 0) {
                        return (
                            </div> /* Shows an erros here because of closing tag*/
                            <div className="row">
                                <div className="col s4 ">
                                    <div className="card">
                                        <div className="card-image">
                                            <img src="images/logo.png" />
                                        </div>
                                        <div className="card-content">
                                            <span className="card-title">
                                                {this.props.auction.auctionName}
                                            </span>
                                            <p>
                                                I am a very simple card. I am good at containing small bits of information.
                                                I am convenient because I require little markup to use effectively.
                                            </p>
                                        </div>
                                        <div className="card-action">
                                            <a href="#">This is a link</a>
                                        </div>
                                    </div>
                                </div>
                        );
                    } else {
                        <div className="col s4">
                            <h1>Brincoooo</h1>
                            <div className="card">
                                <div className="card-image">
                                    <img src="images/logo.png" />
                                </div>
                                <div className="card-content">
                                    <span className="card-title">
                                        {this.props.auction.auctionName}
                                    </span>
                                    <p>
                                        I am a very simple card. I am good at containing small bits of information.
                                        I am convenient because I require little markup to use effectively.
                                    </p>
                                </div>
                                <div className="card-action">
                                    <a href="#">This is a link</a>
                                </div>
                            </div>
                        </div>
                    }

                }
            }

最佳答案

任何时候从渲染函数返回 HTML 时,它都需要是独立的并且具有平衡的标签。这就是 React 的工作方式,以及为什么它会给你一个错误。

您可以考虑使用 Flexbox,而不是尝试一次对 3 个拍卖进行分组。使用 Flexbox,您只需渲染所有拍卖,它会自动为您处理包装。屏幕较宽的用户将看到超过 3 列,移动设备上的用户在纵向模式下可能会看到一列。

如果你想了解 Flexbox,这里有一个可爱的教程:https://flexboxfroggy.com/如果您不喜欢该教程,可以找到很多教程,例如:https://scotch.io/tutorials/a-visual-guide-to-css3-flexbox-properties

我会让你从这里开始工作

关于javascript - 根据react中对象的索引渲染不同的html,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49785439/

相关文章:

javascript - 嵌套路由错误(react-router)

javascript - Reactjs(功能组件)使用OR语句进行条件渲染

javascript - 一屏显示图片的CSS/Javascript框架

javascript - 分割逗号分隔值并将它们添加到数组中

javascript - 如何从ISO8601标准日期格式中提取时间?

html - Firefox 中的 HTTP 内容类型视频/mp4 警告

javascript - 用户如何在 session 期间调整 html 表格列宽

reactjs - Sinon 不会对 react 组件的 getter 进行 stub

javascript - 使用 Javascript 拆分字符串而不使用 for 循环

jquery - 使用 knockout 切换 css 类