javascript - Node.js 中的 Jquery 错误 '$ is not a function'

标签 javascript jquery node.js jsdom

在将 Jquery 与 Jsdom 结合使用时,我收到控制台错误“$ is not a function”。我正在使用最新的 Jquery 版本 3.3.1 和 Jsdom 13.2.0。我也在使用 Browserify 以利用 require。

主要.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>

最佳答案

require('jquery') 之后去掉 (window),所以它应该是:

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

你写的是重新定义 $jQuery 就好像你已经完成了一样:

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

顺便说一句,您不能像那样通过链接assignments 来声明两个变量。只有第一个变量在本地声明,第二个是没有声明的赋值。如果要声明两个变量并赋予它们相同的值,请分两步进行:

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

关于javascript - Node.js 中的 Jquery 错误 '$ is not a function',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54936246/

相关文章:

javascript - 使用javascript在表格中显示信息

javascript - SignalR owin 启动没有受到影响。获取 "Object doesn' t 支持属性或方法“javascript 错误

mysql - 重试mysql中的死锁

javascript - 为什么 npm install 没有更新我的 package.json?

javascript - 调用 History.back() 后未命中 Chrome 调试器语句

javascript - Axios:在 POST 请求正文中发送变量而不是参数

javascript - Sum Checked 单选按钮值不起作用

node.js - 如何使用 gitlab runners 在 ec2 上自动部署?

javascript - 在 Javascript 中使用 alert() 处理一个奇怪的问题

javascript - 使用 jquery 最接近的替换文本