如何将 Chosen 合并到我的 React 项目中?

IT技术 javascript node.js reactjs jquery-chosen
2021-05-16 19:24:35

我想在我的项目中使用选择的 jquery 插件我通过 npm 安装了 jQuery 和 Chosen:

npm i jquery chosen-js -S

这两个库现在都在我的 node_modules 文件夹中。不幸的是,我不断收到错误消息:ReferenceError: jQuery is not defined当应用程序尝试编译时。

这是我调用 Chosen 库的地方:

import React from "react";
import ReactDom from "react-dom";
import $ from "jquery";
import "chosen-js/chosen.css";
import "chosen-js/chosen.jquery.js";

class App extends React.Component {
  componentDidMount() {
    $(this.refs.list).chosen();
  }

  render() {
    return (
      <select ref="list">
        <option>vanilla</option>
        <option>chocolate</option>
        <option>strawberry</option>
      </select>
    );
  }
}

ReactDom.render(, document.getElementById("app"));

这是错误的图片: 在此处输入图片说明

2个回答

我也在 Udemy 上回答了你的问题。如果你真的想认真对待你的 React 事业,你最终需要停止使用 jQuery。

我使用 react-select 制作了非常复杂的选择组件,甚至使用来自 API 的数据的组件。我建议使用 React Select 来满足您所有的选择需求,它是一个强大的组件,将改变您的生活。

如果您仍然发现必须使用 selected.js,那么编辑 'chosen-js/chosen.jquery.js' 并添加 import 语句或 require 语句,例如

import jQuery from 'jquery' // or
const jQuery = require('jquery');

以便参考错误消失。然而,如果你考虑一个严肃的前端职业,你需要明白 jQuery 已经死了,严肃的应用程序不会同时使用 react 和 jquery 来解决臃肿和冗余的简单问题

不要改变来源,最好写在你的组件中

window.jQuery = require('jquery');

在 selected-js 导入之前