首页 > 解决方案 > 开玩笑 - ReferenceError:未定义导入的函数

问题描述

我已经在这里待了 2 个小时,但无法弄清楚我做错了什么。我有以下 jest+puppeteer 测试:

import {convert} from '../__helpers__/number';

const getAmount = async (page) => {
  const element = await page.waitForSelector('.my-element');

  return element.evaluate((node) => convert(node.innerText));
}

这非常简单直接。但它一直失败并出现以下错误:

Error: Evaluation failed: ReferenceError: _number is not defined
          at __puppeteer_evaluation_script__:2:15
          at ExecutionContext._evaluateInternal (node_modules/puppeteer/lib/ExecutionContext.js:122:13)
        -- ASYNC --
          at ExecutionContext.<anonymous> (node_modules/puppeteer/lib/helper.js:111:15)
          at ElementHandle.evaluate (node_modules/puppeteer/lib/JSHandle.js:55:42)
          at ElementHandle.evaluate (node_modules/puppeteer/lib/helper.js:112:23)
          at _callee$ (__tests__/e2e/test.spec.js:13:27)
          at tryCatch (node_modules/@babel/polyfill/node_modules/regenerator-runtime/runtime.js:45:40)
          at Generator.invoke [as _invoke] (node_modules/@babel/polyfill/node_modules/regenerator-runtime/runtime.js:271:22)
          at Generator.prototype.(anonymous function) [as next] (node_modules/@babel/polyfill/node_modules/regenerator-runtime/runtime.js:97:21)
          at asyncGeneratorStep (__tests__/e2e/test.spec.js:30:103)
          at _next (__tests__/e2e/test.spec.js:32:194)

上面的行号与源代码不匹配.. 从错误来看,它看起来像是从转译代码中失败了。所以我去那个jest-transform-cache地方看了看文件,行号也不匹配;它们都减 1。转译的代码也有更新的输出,并有以下行:

var _number = require('../__helpers__/number');

我尝试了所有我能想到的方式进行调试:

也试过这个:

// import {convert} from '../__helpers__/number';

const convert = (text) => magic(text); // for simplicity's sake

const getAmount = async (page) => {
  const element = await page.waitForSelector('.my-element');

  return element.evaluate((node) => convert(node.innerText));
}

现在它失败并出现以下错误:

Evaluation failed: ReferenceError: convert is not defined

      at __puppeteer_evaluation_script__:2:15
      at ExecutionContext._evaluateInternal (node_modules/puppeteer/lib/ExecutionContext.js:122:13)
.
:

以为我会把它扔在这里,看看是否有其他人遇到这种奇怪现象。它不应该以任何规范失败,我根本无法弄清楚。请帮我!任何想法/方向将不胜感激。

谢谢!

标签: javascriptnode.jsjestjspuppeteerreferenceerror

解决方案


您需要将转换函数作为elementHandle.evaluate(pageFunction[, ...args])的参数传递,如下所示:

import {convert} from '../__helpers__/number';

const getAmount = async (page) => {
  const element = await page.waitForSelector('.my-element');

return element.evaluate((node, convert) => convert(node.innerText), convert);
}

推荐阅读