微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript – jsdom不处理网页内的脚本

我是nodejs的新手.我想使用jsdom来解析一些可能包含脚本代码的网页.但我得到错误表示函数或变量未定义.任何人都可以给出一些指示.

我的代码

var jsdom = require('jsdom');

jsdom.env({
  html: 'http://10.200.0.10:8080/test/a.html',scripts: [
    'http://code.jquery.com/jquery-1.5.min.js'
  ],done: function(errors,window) {
    var $= window.$;
    window.onload();
    console.log(window.a);
  }
});

和HTML页面在这里

并在下面收到错误消息

dfddddfdf
undefined:1: ReferenceError: loads is not defined
loads()
^
ReferenceError: loads is not defined
    at unkNown source
    at /root/node_modules/jsdom/node_modules/contextify/lib/contextify.js:10:24
    at /root/node_modules/jsdom/lib/jsdom/level1/core.js:1024:50
    at /root/testnode.js:18:12
    at Array.0 (/root/node_modules/jsdom/lib/jsdom.js:199:39)
    at EventEmitter._tickCallback (node.js:192:40)

node.js:201
        throw e; // process.nextTick error,or 'error' event on first tick
              ^
ReferenceError: loads is not defined
    at unkNown source
    at /root/node_modules/jsdom/node_modules/contextify/lib/contextify.js:10:24
    at /root/node_modules/jsdom/lib/jsdom/level1/core.js:1024:50
    at /root/testnode.js:18:12
    at Array.0 (/root/node_modules/jsdom/lib/jsdom.js:199:39)
    at EventEmitter._tickCallback (node.js:192:40)

它报告未定义加载函数,但它实际上是在网页中声明的.

任何人都可以给出一些建议,或者只是告诉我jsdom无法处理页面中嵌入的脚本.

最佳答案
这是您想要的代码

var fs = require('fs');
var jsdom = require('jsdom');
var doc   = jsdom.jsdom(fs.readFileSync("a.html"),null,{
          features: {
            FetchExternalResources   : ['script'],ProcessExternalResources : ['script'],MutationEvents           : '2.0',}
    });

var window = doc.createWindow();
jsdom.jQueryify(window,"http://code.jquery.com/jquery-1.5.min.js",function() {
    console.log(window.a);
    console.log(window.$().jquery); //jquery version
});

您的代码将无法运行,因为jsdom.env方法不处理脚本.

原文地址:https://www.jb51.cc/html/426395.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐