Ошибка Jquery «$ не является функцией» в Node.js - PullRequest
0 голосов
/ 01 марта 2019

Я получаю консольную ошибку '$ is not function' при использовании Jquery с Jsdom.Я использую последнюю версию Jquery 3.3.1 и Jsdom 13.2.0.Я также использую Browserify, чтобы использовать require.

main.js

var jsdom = require('jsdom');
const { JSDOM } = jsdom;
const { window } = new JSDOM();
const { document } = (new JSDOM('')).window;
global.document = document;

var $ = jQuery = require('jquery')(window);

$("body").click(function() {
  $("#name-tag").fadeOut("slow", function() {
    // Animation complete.
  });
});

index.html

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta
      name="viewport"
      content="width=device-width, initial-scale = 1.0, maximum-scale=1.0, user-scalable=no"
    />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <link rel="stylesheet" href="scss/styles.css" />
    <script src="js/bundle.js"></script>
  </head>
  <body>
    <div id="name-tag">
    <h1>Hello World</h1>
    </div>
  </body>
</html>

1 Ответ

0 голосов
/ 01 марта 2019

Избавьтесь от (window) после require('jquery'), поэтому оно должно быть просто:

var $ = jQuery = require('jquery');

То, что вы написали, переопределяет $ и jQuery, как если бы вы сделали:

jQuery = require('jquery');
var $ = jQuery = jQuery(window);

Кстати, вы не можете объявить две переменные с помощью цепочки assignments таким образом.Только первая переменная объявляется локально, вторая является присваиванием без объявления.Если вы хотите объявить две переменные и присвоить им одинаковое значение, сделайте это в два шага:

var $, jQuery;
$ = jQuery = require('jquery');
...