javascript - React 找不到我包含的第三方脚本

标签 javascript jquery node.js reactjs

我正在尝试解决 React Tutorial并遇到了绊脚石。我有以下 HTML

<html lang="en">
  <head>
    <meta charset="utf-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <link rel="shortcut icon" href="./src/favicon.ico" />
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/materialize/0.97.7/css/materialize.min.css" />
    <script src="https://npmcdn.com/react@15.3.1/dist/react.js"></script>
    <script src="https://npmcdn.com/react-dom@15.3.1/dist/react-dom.js"></script>
    <script src="https://npmcdn.com/babel-core@5.8.38/browser.min.js"></script>
    <script src="https://npmcdn.com/jquery@3.1.0/dist/jquery.min.js"></script>
    <script src="https://npmcdn.com/remarkable@1.6.2/dist/remarkable.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/materialize/0.97.7/js/materialize.min.js"></script>
    <script type="text/babel" src="src/index.js"></script>
    <title>React App</title>
  </head>
  <body>
    <div class="container">
      <div class="row">
        <div id="sidebar" class="col s3">
        </div>
        <div id="content" class="col s9">
        </div>
      </div>
    </div>
    <script type="text/babel">

    </script>
  </body>
</html>

使用以下 JavaScript 文件。

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';

var data = [
  { id: 1, author: "Pete Hunt", text: "This is the 1st comment" },
  { id: 2, author: "Jordan Walke", text: "This is *the 3rd* comment." },
  { id: 3, author: "John Doe", text: "This comment is stupid." }
];

var CommentBox = React.createClass({
  getInitialState: function() {
    return { data: [] };
  },
  componentDidMount: function() {
    $.ajax({
      url: this.props.url,
      dataType: 'json',
      cache: false,
      success: function(data) {
        this.setState({ data: data });
      }.bind(this),
      error: function(xhr, status, err) {
        console.error(this.props.url, status, err.toString());
      }.bind(this)
    });
  },
  render: function() {
    return (
      <div className="commentBox">
        <h1>Comments</h1>
        <CommentList data={this.state.data} />
        <CommentForm />
      </div>
    );
  }
});

var CommentList = React.createClass({
  render: function() {
    var commentNodes = this.props.data.map(function(comment) {
      return (
        <Comment author={comment.author} key={comment.id}>
          {comment.text}
        </Comment>
      );
    });
    return (
      <div className="commentList">
        {commentNodes}
      </div>
    );
  }
});

var CommentForm = React.createClass({
  render: function() {
    return (
      <div className="commentForm">
        I'm a Form.
      </div>
    );
  }
});

var Comment = React.createClass({
  rawMarkup: function() {
    var markdown = new Remarkable();
    var rawMarkup = markdown.render(this.props.children.toString());
    return { __html: rawMarkup };
  },
  render: function() {
    return (
      <div className="comment">
        <h2 className="commentAuthor">
          {this.props.author}
        </h2>
        <span dangerouslySetInnerHTML={this.rawMarkup()} />
      </div>
    );
  }
});

ReactDOM.render(
  <CommentBox data={data} />,
  document.getElementById('content')
);

我正在使用从 Create React App 创建的内容NPM 模块。当我运行该应用程序时,系统告诉我:

  • 卓越尚未定义
  • $ 未定义

JQuery 和 Remarkable 都包含在我的 HTML 文件中,并且我确保将它们放在我的 index.js 脚本之前。为什么应用程序找不到类型?这是 React 问题,还是 Node、js 问题?我对网络开发有点陌生,所以我不确定哪个组件出了问题或者我做错了什么。

最佳答案

似乎您的脚本正在异步加载。正在等待使用 jQuery 加载所有脚本...


(function($){$(function(){

  // your react app code here...

})})(jQuery);

关于javascript - React 找不到我包含的第三方脚本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39325088/

相关文章:

javascript - 如何递归调用 JQuery .each() 迭代

javascript - 使用 mongodb/mongoose 有条件地将 5-20k 文档的输入批处理处理为包含多达一百万个文档的集合的有效方法是什么?

javascript - 如何使用 jQuery 单击 div 中的文本

javascript - 原型(prototype)继承共享属性和方法

javascript - CSS 选择器允许一件事但不允许另一件事?

jquery - jQuery 中巧妙的下一个和上一个按钮

node.js - Express 中间件未在子路径上调用

ios - 我如何使用 Alamofire 进行基于 token 的身份验证?

javascript - 在 JavaScript 中检索 XML 文档的所有值

javascript - 了解返回具有变量值的函数的 crockford 函数