javascript - Bootstrap 选择元素未使用 React-router 渲染

标签 javascript jquery reactjs bootstrap-4 react-router

我正在用reactjs制作一个基本的应用程序。我已经为 3 个组件设置了路线。 问题是渲染组件时不会出现选择字段。我正在使用 bootstrap-select 库来选择字段。

className 为“selectpicker”的选择字段不会呈现,它们只是不存在。当我从类名中删除“selectpicker”时,它们出现了。 使用“selectpicker”时,它们会在浏览器页面重新加载时显示。

下面是我的代码片段: https://codesandbox.io/s/determined-panini-2mmv3 所有三个组件几乎相似。

import React from 'react'
import A from "./A"
import B from "./B"
import C from "./C"
import {BrowserRouter as Router, Switch, Link, Route} from "react-router-dom"

class App extends React.Component{
  constructor(){
    super()
  }
    render(){
      return(
        <div>
          <Router>
            <ul>
              <li><Link to="/">TO A</Link></li>
              <li><Link to="/page1">TO B</Link></li>
              <li><Link to="/page2">TO C</Link></li>
            </ul> 
            <Switch>
              <Route exact path='/' component={A}/>
              <Route path='/page1' component={B}/>   {/* components B and C have select field with selectpicker class*/}
              <Route path="/page2" component={C}/>
            </Switch>
          </Router>
        </div>
      )
    }
}

export default App
{/*Component A*/}

import React from "react"

class A extends React.component{
  constructor(){
    super()
    this.state={
      componentA: ""
    }
    this.handleChange = this.handleChange.bind(this)
  }

  handleChange(event){
    const {name, value, type, checked} = event.target
    type === "checkbox" ? this.setState({ [name]: checked }) : this.setState({ [name]: value })
  }

  render(){
    return(
      <div className="form-group row">
        <label htmlFor="tempid" className="col-sm-2 col-form-label">Choose an option</label>
        <div className="col-sm-10">
            <select 
              className="form-control custom-select selectpicker"
              name = "componentA" 
              id = "tempid"
              value = {this.state.componentA}
              onChange = {this.handleChange} 
              required
            >
              <option value="" style={{display:"none"}} disabled selected>Choose one</option>
              <option value="p">P</option>
              <option value="q">Q</option>
              <option value="r">R</option>
              <option value="s">S</option> 
            </select>
        </div>
      </div>
    )
  }
}
export default A

以下是我的index.html 文件,我已正确包含 Bootstrap 和 Bootstrap 选择。单独渲染组件时它工作正常。当我开始使用路由时,问题就出现了。

<!DOCTYPE html>
<html lang="en"><head>
  <meta charset="utf-8">

  <meta name="viewport" content="width=device-width, initial-scale=1">
  <meta name="theme-color" content="#000000">
  <meta name="description" content="Web site created using create-react-app">

  <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous">
  <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.13.10/css/bootstrap-select.min.css">


  <title>React App</title>

</head>
<body>
  <noscript>You need to enable JavaScript to run this app.</noscript>
  <div id="root"></div>

  <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js" integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1" crossorigin="anonymous"></script>
  <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js" integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/bootstrap-select/1.13.10/js/bootstrap-select.min.js" type="text/javascript"></script>

</body></html>

这是我的问题的codesandbox https://codesandbox.io/s/determined-panini-2mmv3 的链接

实际输出:具有“selectpicker”类的选择输入字段根本不显示。只有标签和其他文本输入可见。当“selectpicker”类名被删除时,它会按预期工作。我得到以下输出: My output

预期:要呈现的选择输入字段。预期应该如下: enter image description here

最佳答案

我尝试按照该问题的评论之一的建议,在我的 componentDidMount() 中添加 $('select').selectpicker() 。但它并没有按预期工作。相反,我遇到了错误 __WEBPACK_IMPORTED_MODULE_8_jquery___default(…)(…).selectpicker 不是函数。 经过几天的努力后,我能够使用 React Error : __WEBPACK_IMPORTED_MODULE_4_jquery___default(...)(...).modal is not a function 的答案解决这个问题。 .

导入 import $ from 'jquery' 在模块内创建一个名为 $ 的局部变量,然后由 $('.selectpicker') 使用.selectpicker() (而不是您想要的全局 $)。

最快的解决方法是在全局上下文中显式使用 jQuery $ (它已使用 $.selectpicker() 进行了扩展,因为您在脚本标签。

window.$('.selectpicker').selectpicker()

关于javascript - Bootstrap 选择元素未使用 React-router 渲染,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58116697/

相关文章:

javascript - 将 jQuery 自动完成数据附加到 textarea 内容而不是覆盖它

javascript - Javascript 如何知道何时执行通过引用隐式传递的函数? react 示例

javascript - 点击事件中断提交事件

javascript - 选择选项的格式错误 - JQuery

javascript - 我怎样才能得到这个论点?

javascript - 三.js 纹理加载器多张图片

java - JSP 中的级联下拉列表

javascript - 如何排除特定元素的 Jquery mouseup

css - 使用 Tailwind CSS react 过渡组

javascript - ReactJS onClick 不触发