javascript - 为什么 Phantom.js 不评估我的 Backbone 应用程序的工作?

标签 javascript html node.js backbone.js phantomjs

page.open(My_url, function(status) {
                        page.evaluate(function() { 
                            var html = document.documentElement.outerHTML;
                            return html;
                        }, function(result){
                            res.send(result);
                        });
                    });

我有一个 Backbone 应用程序。 “My_url”指向那个主干页面。

当我运行这段代码时,outerHTML 不包含呈现的 View 。它只有基本的 css/脚本/容器持有者。

就像 Backbone 应用程序根本没有运行一样。如何让 evaluate() 返回完全呈现的 Backbone 应用程序(在所有 ajax 调用和其他东西之后)?

毕竟,这就是 Phantom.js 的意义所在

最佳答案

在页面加载后立即对其进行评估并不总是足够的。有时,由于 JavaScript 在页面上的编写方式,您将不得不等待页面的 JavaScript 执行。为此,我建议您在执行评估之前尝试添加等待时间。例如

function ( status ) {
  if ( status === 'fail' ) {
    phantom.exit( 1 );
    return; // essential, if you don't, below will be executed
  }

  window.setTimeout(
    function () {
      var result = page.evaluate(
        function () {
          var html = document.documentElement.outerHTML;
          return html;
        }
      );
      res.send( result );
    },
    1000 // wait 1,000ms (1s)
  );
}

如果您发现有必要等待,那么您可能想要等待某事。为此,请在 Internet 上寻找 waitFor 或类似函数,它们将允许您的脚本持续轮询,直到出现特定的 DOM 元素。

关于javascript - 为什么 Phantom.js 不评估我的 Backbone 应用程序的工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16707425/

相关文章:

javascript - <Audio> 通过 Javascript 回退

javascript - Webpack:无法解构 `curry` 或 'undefined' 的属性 'null'

javascript - 如何构建该数组,分离类别和产品

javascript - 在子焦点上更改父 css(不破坏父 :hover css rules)

javascript - Asual $.address - 如何摆脱主题标签

javascript - 如何同时滚动两个div?

javascript - jquery过滤器 "a"带有条件的标签

javascript html 高度与窗口高度

javascript - Passport.js 使用 LocalStrategy 抛出 "undefined is not a function"

javascript - 如何使用@default 和 degenerated() 在 prisma 中声明数据库默认值?