Uncaught Ошибка: цель отсутствует.Поппер должен получить цель от менеджера Поппера, - PullRequest
0 голосов
/ 11 мая 2018

Я пытаюсь настроить кнопку реагирующей ленты, используя этот ответ .Но я получаю эту ошибку в консоли, и выпадающий список не работает

Popper.js: 39 Uncaught Ошибка: цель отсутствует.Поппер должен получить цель от менеджера Поппера или в качестве опоры.в Popper._this._getTargetNode (Popper.js: 39) в Popper._createPopper (Popper.js: 150) в Popper._this._handlePopperRef (Popper.js: 93) в attachRef (ReactRef.js: 20) в Object.webpackJsonp…close (ReactReconcileTransaction.js: 80) в ReactReconcileTransaction.closeAll (Transaction.js: 206) в ReactReconcileTransaction.perform (Transaction.js: 153)

Вот мой компонент:

import React from 'react'
import { Dropdown, DropdownToggle, DropdownMenu, DropdownItem } from 'reactstrap'
import FontAwesome from 'react-fontawesome'
import './ComponentStyle.scss'

export default class DropdownIs extends React.Component {
    constructor (props) {
        super(props)
        this.toggle = this.toggle.bind(this)
        this.state = {
            value: 3,
            dropdownOpen: false,
            dropdownOptions: []
        }
    }

    toggle () {
        console.log('called')
        this.setState(prevState => ({
            dropdownOpen: !prevState.dropdownOpen
        }))
    }

    handleChange = (event, index, value) => this.setState({ value });

    render () {
        return (
          <Dropdown className='dropdown-is' isOpen={this.state.dropdownOpen} toggle={this.toggle}>
            <span className='dropdown-shown' onClick={this.toggle}
              data-toggle='dropdown'
              aria-haspopup='true'
              aria-expanded={this.state.dropdownOpen}
            >
              <FontAwesome
                className='super-crazy-colors icon'
                name='chevron-down'
                style={{ textShadow: '0 1px 0 rgba(0, 0, 0, 0.1)' }}
                />
            </span>
            <DropdownMenu>
              <DropdownItem header>Header</DropdownItem>
              <DropdownItem disabled>Action</DropdownItem>
              <DropdownItem>Another Action</DropdownItem>
              <DropdownItem divider />
              <DropdownItem>Another Action</DropdownItem>
            </DropdownMenu>
          </Dropdown>
        )
    }
}

Обновление Я исправил вышеуказанную ошибку, используя:

<DropdownToggle
              tag='span'
              className='dropdown-shown'
              onClick={this.toggle}
              data-toggle='dropdown'
              aria-expanded={this.state.dropdownOpen}
            >
              <FontAwesome
                className='super-crazy-colors icon'
                name='chevron-down'
                style={{ textShadow: '0 1px 0 rgba(0, 0, 0, 0.1)' }}
                    />
            </DropdownToggle>

Вместо диапазона, но я не могу заставить его работать даже после того, как простой пример работает отличноесли оставить без изменений.

1 Ответ

0 голосов
/ 11 мая 2018

Причиной ошибки были мои поспешные решения, которые смешали некоторые вещи: При переходе от Dropdowns к Custom я пропустил следующие части:

toggle() {
    this.setState(prevState => ({
      dropdownOpen: !prevState.dropdownOpen
    }));
  }

К

toggle() {
this.setState({
  dropdownOpen: !this.state.dropdownOpen
});

}

И используя:

 <DropdownToggle
          tag="span"
          onClick={this.toggle}
          data-toggle="dropdown"
          aria-expanded={this.state.dropdownOpen}
        >
          Custom Dropdown Content
        </DropdownToggle>

Вместо пользовательских тегов

...