搜尋

首頁  >  問答  >  主體

java - 用Jsoup抓取36氪网站的数据返回null

一、问题描述
用Jsoup抓取36氪网站的这部分数据(下图),也就是<p id="app">里面的数据,总是返回null。

二、我的尝试
1、用id查找

2、用其中的一个类查找

3、打印整个document,结果如下图,好像这是一个空标签。

三、我的思考
当我点击<p id="app">这行代码时(谷歌的“检查”),发现右边的小窗口styles里面有句p{display:block;}。然后我在网站上找到类似的(下图:class="top_swing"),发现获取到的element也是空的。经过查阅,display:block代表元素以块状显示。所以我猜想是不是块状元素要用另外的方法获取,还是其它原因??用Jsoup怎么解决??

PHP中文网PHP中文网2766 天前614

全部回覆(2)我來回復

  • 怪我咯

    怪我咯2017-04-18 10:25:55

    那些內容是Javascript動態產生的,不要看Google開發者工具,而是右鍵網頁,查看原始碼。
    可以看到

    <p id="app"></p>

    你用Jsoup之類的,只能抓取到html內容,js產生的內容是無法抓取的。

    回覆
    0
  • PHPz

    PHPz2017-04-18 10:25:55

    js動態產生的,可能是Angular.js

    回覆
    0
  • 取消回覆