javascript - nodejs抓取網頁的問題
問題描述
我準備抓用nodejs抓取下面這個網站的所有新聞, 按照一般的思路,是首先取得每頁新聞的URL,然后取得每個新聞的URL按照使用request把每個網址的內容取下來就OK了.
但是下面的這個網址的所有分頁信息, 還有每個新聞點擊進去URL都沒有任何變化, 貌似都是在后臺通過js實現的.用chrome的F12的newwork的tab也查看不到有什么請求,有哪位大神能指導一下我怎么來抓取嗎?
http://www.xxxxxxxxx.com/glob...
問題解答
回答1:1.從上一篇與下一篇的地方可以看到,click綁定的函數:boardView(1);
2.通過boadrview在頁面中找到對應的函數:
function boardView(idx){ var listNum = 10; // ?? ? ?? var resultLenplistNum = Math.floor(idx/listNum); // ?? ??? ??? var resultLenRestlistNum = Math.floor(idx%listNum); // ?? ??? ??? if (resultLenRestlistNum == 0){ pageNum = resultLenplistNum; } else { pageNum = resultLenplistNum + 1; } cmsView.style.display = ’block’; cmsList.style.display = ’none’; resultViewStr = ’<p class='news_view'><p class='news_hd'>’; resultViewStr = resultViewStr + ’<strong>’+list.artCatTitles[resultSearch[idx]] +’</strong>’; resultViewStr = resultViewStr + ’<p>’+list.artTitles[resultSearch[idx]]+’</p>’; resultViewStr = resultViewStr + ’<span>’+list.artTimes[resultSearch[idx]]+’</span></p>’; resultViewStr = resultViewStr + ’<p class='news_bd'>’+list.artTexts[resultSearch[idx]]; resultViewStr = resultViewStr + list.artFiles[resultSearch[idx]]+’</p>’; resultViewStr = resultViewStr + ’<p class='news_link'><ul>’; resultViewStr = resultViewStr + ’<li><strong><span></span>’;
.........
3.看到數據來自于list這個變量,再尋找list
4.在1739行看到:
var artId = '';var catId = 'se14_24';var tplId = '';list = new jsList();list.cmsInit(catId, artId, tplId, new data()); // list ?? ??
5.調用了一個構造函數:jsList()找到相應的代碼在這里:http://www.samsungsem.com/js/...
6 看回第2步的代碼:list.artTitles-->這些數據是通過jsList的cmsInit方法設置的,而cmsInit中:
function cmsInit(catId, artId, tplId, data) { this.artIds = data.artIds; this.artCatTitles = data.artCatTitles; this.artTitles = data.artTitles; this.artUrls = data.artUrls; this.artTimes = data.artTimes; this.artImgs = data.artImgs; this.artTexts = data.artTexts; this.artTexts2 = data.artTexts2; this.artKeywords = data.artKeywords; this.artFiles = data.artFiles;
...的數據來自第四個參數data
7.再看第4步的傳的data是new data()于是,我們找到data這個函數定義的地方。往上找,找到了:<script src='http://www.cgvv.com.cn/global/news/data.js.jsp'></script>
8.打開后看一下:http://www.samsungsem.com/glo... 好奇怪的感覺,怎么樣式那么奇怪?
再右鍵查看源代碼:view-source:http://www.samsungsem.com/glo...可以看到data函數是在這里定義的,而你看到的數據也在這個頁面里。
回答2:多謝回答,我先去看看去.....
基本看明白了,還有一點不是很懂的地方再慢慢去看,多謝了..
相關文章:
1. javascript - 在top.jsp點擊退出按鈕后,right.jsp進行頁面跳轉,跳轉到login.jsp2. android - 哪位大神知道java后臺的api接口的對象傳到前端后輸入日期報錯,是什么情況?求大神指點3. java - spring-data Jpa 不需要執行save 語句,Set字段就可以自動執行保存的方法?求解4. css3 - 在sublime text里, 如何讓emmet生成的帶前綴css屬性垂直對齊?5. mac連接阿里云docker集群,已經卡了2天了,求問?6. [前端求職必看]前端開發面試題與答案精選_擴展問題7. javascript - js 有什么優雅的辦法實現在同時打開的兩個標簽頁間相互通信?8. javascript - jquery怎么給select option一個點擊時觸發的事件,如圖 如果選擇自定義觸發一個時間?9. css3 - Typecho 后臺部分表單按鈕在 Chrome 下出現靈異動畫問題,求解決10. html - CSS如何處理圖片縮放問題?
