let http = require("http");
let fs = require("fs");
let path = require("path");
let cheerio = require("cheerio");
let iconv = require("iconv-lite");
let EventEmitter = require("events");
let targetUrl = "http://www.27270.com/ent/meinvtupian/"
//定義一個類繼承由events導出的EventEmitter
class myEmitter extends EventEmitter{
? ? init(){
? ? ? ? //注冊downHtmlSuccess,當觸發(fā)這個事件時伐憾,調(diào)用里面的方法this.parseHtml(result)
? ? ? ? this.on("downHtmlSuccess",(result)=>{
? ? ? ? ? ? this.parseHtml(result)
? ? ? ? })
? ? ? ? //parseHtmlSuccess偿乖,當觸發(fā)這個事件時,調(diào)用里面的方法this.downImages(result)
? ? ? ? this.on("parseHtmlSuccess",(result)=>{
? ? ? ? ? ? this.downImages(result)
? ? ? ? })
? ? ? ? //最開始運行的是下面這個方法
? ? ? ? this.downHtml(targetUrl)
? ? }
? ? downHtml(targetUrl) {
? ? ? ? let chunks = []
? ? ? ? http.get(targetUrl,(response)=>{
? ? ? ? ? ? response.on("data",(chunk)=>{
? ? ? ? ? ? ? ? chunks.push(chunk)
? ? ? ? ? ? })
? ? ? ? ? ? response.on("end",()=>{
? ? ? ? ? ? ? ? //重新編碼原h(huán)tml的源代碼,下面是死操作
? ? ? ? ? ? ? ? let htmlTar = iconv.decode(Buffer.concat(chunks),"gb2312");
? ? ? ? ? ? ? ? this.emit("downHtmlSuccess",htmlTar)
? ? ? ? ? ? })
? ? ? ? })
? ? }
? ? parseHtml(htmlTar){
? ? ? ? let $ = cheerio.load(htmlTar);
? ? ? ? let result = []
? ? ? ? let imgTags = $("div.MeinvTuPianBox>ul>li>a>i>img").toArray();
? ? ? ? for (let i = 0; i < imgTags.length; i++) {
? ? ? ? ? ? /*★★★尤其要注意鞠值,這里要把每個元素轉成DOM對象再取attr值矿辽,所以下面兩行是錯的*/
? ? ? ? ? ? /*let src = imgTags[i].src
? ? ? ? ? ? let imgName = imgTags[i].alt*/
? ? ? ? ? ? let src = $(imgTags[i]).attr("src")
? ? ? ? ? ? let imgName = $(imgTags[i]).attr("alt")
? ? ? ? ? ? result.push({
? ? ? ? ? ? ? ? src,
? ? ? ? ? ? ? ? imgName
? ? ? ? ? ? })
? ? ? ? }
? ? ? ? this.emit("parseHtmlSuccess",result)
? ? }
? ? downImages(result){
? ? ? ? let targetDir = "images"
? ? ? ? for (let i = 0; i < result.length; i++) {
? ? ? ? ? ? let src = result[i].src
? ? ? ? ? ? let imgName = result[i].imgName
? ? ? ? ? ? http.get(src,(response)=>{
? ? ? ? ? ? ? ? let filePath = path.join(targetDir,imgName+path.extname(src));
? ? ? ? ? ? ? ? let writeStream = fs.createWriteStream(filePath);
? ? ? ? ? ? ? ? response.pipe(writeStream)
? ? ? ? ? ? })
? ? ? ? }
? ? }
}
//創(chuàng)建一個類并調(diào)用其init()方法
let emitter = new myEmitter();
emitter.init()
用監(jiān)聽事件來爬蟲某網(wǎng)站的某一類型的美女圖片
最后編輯于 :
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
- 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來逮京,“玉大人卿堂,你說我怎么就攤上這事±撩蓿” “怎么了草描?”我有些...
- 文/不壞的土叔 我叫張陵,是天一觀的道長策严。 經(jīng)常有香客問我穗慕,道長,這世上最難降的妖魔是什么妻导? 我笑而不...
- 正文 為了忘掉前任逛绵,我火速辦了婚禮怀各,結果婚禮上,老公的妹妹穿的比我還像新娘术浪。我一直安慰自己瓢对,他們只是感情好,可當我...
- 文/花漫 我一把揭開白布胰苏。 她就那樣靜靜地躺著硕蛹,像睡著了一般。 火紅的嫁衣襯著肌膚如雪硕并。 梳的紋絲不亂的頭發(fā)上法焰,一...
- 文/蒼蘭香墨 我猛地睜開眼凯正,長吁一口氣:“原來是場噩夢啊……” “哼毙玻!你這毒婦竟也來了?” 一聲冷哼從身側響起廊散,我...
- 正文 年R本政府宣布,位于F島的核電站喂分,受9級特大地震影響锦庸,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜蒲祈,卻給世界環(huán)境...
- 文/蒙蒙 一甘萧、第九天 我趴在偏房一處隱蔽的房頂上張望萝嘁。 院中可真熱鬧,春花似錦幔嗦、人聲如沸酿愧。這莊子的主人今日做“春日...
- 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至钝鸽,卻和暖如春汇恤,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背拔恰。 一陣腳步聲響...
推薦閱讀更多精彩內(nèi)容
- //導入require包let http = require("http");let fs = require("...
- 1 Webpack 1.1 概念簡介 1.1.1 WebPack是什么 1、一個打包工具 2咸这、一個模塊加載工具 3...
- Correctness AdapterViewChildren Summary: AdapterViews can...
- 【本周作業(yè)3】 [主題]:知識體系[片段來源]:拆解片段來自《這樣讀書就夠了》P.188-189 【R:原文片段】...