Показать новый столбец в таблице

Цель:
Добавьте новый столбец, содержащий URL-ссылку. Содержимое нового столбца должно быть именем и фамилией. Ссылка должна быть www.google.com во всей ячейке.

Проблема:
Я не привык к реактивной таблице, и как мне это сделать?

Кодыпесочницы:
https://codesandbox.io/s/exciting-ganguly-7w2d84

Информация:
*новичок в реагирующей таблице

Благодарю вас!


app.js

    import React from 'react'
    import styled from 'styled-components'
    import { useTable } from 'react-table'
    
    import makeData from './makeData'
    
    const Styles = styled.div`
      padding: 1rem;
    
      table {
        border-spacing: 0;
        border: 1px solid black;
    
        tr {
          :last-child {
            td {
              border-bottom: 0;
            }
          }
        }
    
        th,
        td {
          margin: 0;
          padding: 0.5rem;
          border-bottom: 1px solid black;
          border-right: 1px solid black;
    
          :last-child {
            border-right: 0;
          }
        }
      }
    `
    
    function Table({ columns, data }) {
      // Use the state and functions returned from useTable to build your UI
      const {
        getTableProps,
        getTableBodyProps,
        headerGroups,
        rows,
        prepareRow,
      } = useTable({
        columns,
        data,
      })
    
      // Render the UI for your table
      return (
        <table {...getTableProps()}>
          <thead>
            {headerGroups.map(headerGroup => (
              <tr {...headerGroup.getHeaderGroupProps()}>
                {headerGroup.headers.map(column => (
                  <th {...column.getHeaderProps()}>{column.render('Header')}</th>
                ))}
              </tr>
            ))}
          </thead>
          <tbody {...getTableBodyProps()}>
            {rows.map((row, i) => {
              prepareRow(row)
              return (
                <tr {...row.getRowProps()}>
                  {row.cells.map(cell => {
                    return <td {...cell.getCellProps()}>{cell.render('Cell')}</td>
                  })}
                </tr>
              )
            })}
          </tbody>
        </table>
      )
    }
    
    function App() {
      const columns = React.useMemo(
        () => [
          {
            Header: 'Name',
            columns: [
              {
                Header: 'First Name',
                accessor: 'firstName',
              },
              {
                Header: 'Last Name',
                accessor: 'lastName',
              },
            ],
          },
          {
            Header: 'Info',
            columns: [
              {
                Header: 'Age',
                accessor: 'age',
              },
              {
                Header: 'Visits',
                accessor: 'visits',
              },
              {
                Header: 'Status',
                accessor: 'status',
              },
              {
                Header: 'Profile Progress',
                accessor: 'progress',
              },
              {
                Header: 'Profile Progress1',
                accessor: 'progress2',
              },          
            ],
          },
        ],
        []
      )
    
      const data = React.useMemo(() => makeData(20), [])
    
      return (
        <Styles>
          <Table columns = {columns} data = {data} />
        </Styles>
      )
    }
    
    export default App


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

    makeData.js


import namor from 'namor'

const range = len => {
  const arr = []
  for (let i = 0; i < len; i++) {
    arr.push(i)
  }
  return arr
}

const newPerson = () => {
  const statusChance = Math.random()
  return {
    firstName: namor.generate({ words: 1, numbers: 0 }),
    lastName: namor.generate({ words: 1, numbers: 0 }),
    age: Math.floor(Math.random() * 30),
    visits: Math.floor(Math.random() * 100),
    progress: Math.floor(Math.random() * 100),
    status:
      statusChance > 0.66
        ? 'relationship'
        : statusChance > 0.33
        ? 'complicated'
        : 'single',
  }
}

export default function makeData(...lens) {
  const makeDataLevel = (depth = 0) => {
    const len = lens[depth]
    return range(len).map(d => {
      return {
        ...newPerson(),
        subRows: lens[depth + 1] ? makeDataLevel(depth + 1) : undefined,
      }
    })
  }

  return makeDataLevel()
}
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Навигация по приложениям React: Исчерпывающее руководство по React Router
Навигация по приложениям React: Исчерпывающее руководство по React Router
React Router стала незаменимой библиотекой для создания одностраничных приложений с навигацией в React. В этой статье блога мы подробно рассмотрим...
Массив зависимостей в React
Массив зависимостей в React
Все о массиве Dependency и его связи с useEffect.
0
0
35
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Прежде всего нам нужно отредактировать то, что мы хотим вернуть из функции makeData, для этого мы должны отредактировать newPerson и добавить url, firstNameUrl и lastNameUrl. Это устанавливает нам три новых средства доступа

const newPerson = () => {
  const statusChance = Math.random();
  return {
    firstName: namor.generate({ words: 1, numbers: 0 }),
    lastName: namor.generate({ words: 1, numbers: 0 }),
    age: Math.floor(Math.random() * 30),
    visits: Math.floor(Math.random() * 100),
    progress: Math.floor(Math.random() * 100),
    url: " www.google.com",
    firstNameUrl: namor.generate({ words: 1, numbers: 0 }),
    lastNameUrl: namor.generate({ words: 1, numbers: 0 }),
    status:
      statusChance > 0.66
        ? "relationship"
        : statusChance > 0.33
        ? "complicated"
        : "single"
  };
};

Теперь, когда у нас есть новые ключи данных, мы можем просто указать react-table, что отображать, отредактировав столбец useMemo.

const columns = React.useMemo(
    () => [
      {
        Header: "Name",
        columns: [
          {
            Header: "First Name",
            accessor: "firstName"
          },
          {
            Header: "Last Name",
            accessor: "lastName"
          }
        ]
      },
      {
        Header: "Info",
        columns: [
          {
            Header: "Age",
            accessor: "age"
          },
          {
            Header: "Visits",
            accessor: "visits"
          },
          {
            Header: "Status",
            accessor: "status"
          },
          {
            Header: "Profile Progress",
            accessor: "progress"
          }
        ]
      },
      {
        Header: "Url",
        columns: [
          {
            Header: "First Name",
            accessor: "firstNameUrl"
          },
          {
            Header: "Last Name",
            accessor: "lastNameUrl"
          },
          {
            Header: "Url",
            accessor: "url"
          }
        ]
      }
    ],
    []
  );

Я отредактировал codepen, вы можете найти его здесь

@Редактировать

Если вы хотите отобразить пользовательский компонент, вы можете сделать это, как показано ниже:

      {
        Header: "Last Name",
        accessor: "lastNameUrl",
        Cell: (e) => <a href = "https://google.com"> {e.value} </a>
      }

Это будет отображаться как элемент ссылки со значением аксессуар — я также обновил codepen.

Спасибо за помощь! Я, возможно, не ясно объяснил со своей стороны. Есть одна вещь, которой не хватает. Когда я нажимаю www.google.com, он должен перейти на страницу. Столбец url i является ссылкой

What'sUP 19.03.2022 17:34

Другими словами, столбец URL — это ссылка, по которой можно щелкнуть.

What'sUP 19.03.2022 17:34

Отображение должно быть именем и фамилией, но не www.google.com. Когда вы нажимаете полное имя в качестве ссылки, вы переходите на google.com

What'sUP 19.03.2022 17:35

@ What'sUP ах, надеюсь, я правильно понял, я обновил свой ответ!

Damian Busz 19.03.2022 20:47

Другие вопросы по теме

Локальное состояние дочернего компонента изменяется, когда изменения происходят внутри родительского компонента: ReactJS
Запретить сброс дочернего состояния после изменения состояния родительского компонента, а также получить значения всех дочерних компонентов: ReactJS+ Typescript
Нужно получить все значения всех экземпляров дочерних компонентов и использовать их в родительском методе: ReactJS
Как перейти на другую страницу, нажав на строку таблицы из реагирующей таблицы?
Как включить URL-адрес в ячейку таблицы реакции
Фильтр поиска не работает в таблице реагирования на setState: React JS
Фильтр не применяется при изменении входного текста: ReactJS
Внедрение глобального фильтра поиска по реагирующей таблице: React+ реагирующая таблица
React-Table повторно отображает всю таблицу при выборе
Ширина столбца в таблице реагирования не корректируется после манипулирования его свойством show