React 将 JQuery 代码应用于组件内的元素

IT技术 jquery twitter-bootstrap reactjs bootstrap-wysiwyg
2021-04-29 23:37:04

我有一个使用 React 的应用程序。我现在在尝试实现bootstrap-wysiwyg/bootstrap3-wysiwyg包时遇到了问题

为了让我<textarea>作为ootstrap-wysiwyg/bootstrap3-wysiwyg文本编辑器工作,我需要文本编辑器上运行以下 JQuery 函数:

$(".textarea").wysihtml5()

这是我的组件:

import React, { Component } from 'react'

export class MyTextEditor extends Component {
    render() {
        return (
            <div className="form-group">
                <textarea className="textarea"></textarea>
            </div>
        )
    }
}

如何将该 JQuery 函数应用到我<textarea>的 React 组件中?

我知道混合 React 和 JQuery 不是很好的做法,但我真的需要它来工作。如果有另一种方法可以使包正常工作,我将不胜感激。

否则,如果有人能帮助我让它工作,我将不胜感激!

更新:( 仍在寻找)

感谢所有的建议。我已经尝试了很多,但它们都导致了问题:

  1. <ReactQuill> 只是根本不显示,按钮是巨大的。
  2. <EditableDiv> 给我: Uncaught Error: addComponentAsRefTo(...): Only a ReactOwner can have refs.
  3. Syam Mohan 的回答给了我: Uncaught TypeError: Cannot read property 'font-styles' of undefined at f

仍在寻找有用的东西,感谢您迄今为止的所有努力!

2个回答

试试这个:

import React, { Component } from 'react';
import $ from 'jquery'; 

export class MyTextEditor extends Component {

  componentDidMount() {
    $(".textarea").wysihtml5()
  }

  render() {
    return (
        <div className="form-group">
            <textarea className="textarea"></textarea>
        </div>
     )
  }
}

注意:不要忘记添加 JQuery 库

添加和导入 JQuery 是第一部分

1)使用webpack我看到的最好的方法是在你的webpack.config.js

var webpack = require('webpack');

module.exports = {
    plugins: [
        new webpack.ProvidePlugin({
            '$': 'jquery',
            'jQuery': 'jquery',
            'window.jQuery': 'jquery'
        })
    ]
};

所有这些不同的拼写错误都是为了使 JQuery 可用性与所有类型的module兼容。当然,您需要npm install jquery和您的插件 ( wysihtml5)。

2)或者你可以在你的index.html<script src="jquery-3.1.1.min.js"></script>

编辑:3)我使用了meteor meteor add jquery,并且成功了。

然后,第二部分是在 React 中使用它。

要在元素上使用 jquery 插件,您需要先渲染它,这就是为什么您需要将代码放入componentDidMount(在第一次渲染后运行)。我会建议你(基于我的不同搜索,当我不得不和你做同样的事情但使用bootstrapTable)使渲染部分最简单(通过删除)并ReactDOM.findDOMNode(this)用作 JQuery 的选择器:

import React, { Component } from 'react'
import ReactDOM from 'react-dom'

export class MyTextEditor extends Component {

    componentDidMount() {
        $(ReactDOM.findDOMNode(this)).wysihtml5()
    }

    render() {
        return (
            <textarea className="textarea"></textarea>
        )
    }
}

编辑:或者使用 React 的 refs

import React, { Component } from 'react'

export class MyTextEditor extends Component {

    componentDidMount() {
        $(this.refs.textareaIWantToUse).wysihtml5()
    }

    render() {
        return (
            <div className="form-group">
                <textarea className="textarea" ref="textareaIWantToUse"></textarea>
            </div>
        )
    }
}