這段代碼是與老師的一模一樣,但是為什么在命令行運行后什么都不顯示不加載呢?
var http=require('http')
var cheerio=require('cheerio')
var url='http://www.xianlaiwan.cn/learn/348'
function filterChapters(html){
var $=cheerio.load(html)
var chapters=$('.learnchapter')
// [{
// chapterTitle:'',
// videos:[
// title:'',
// id:''
// ]
// }]
//?
var courseData=[]
chapters.each(function(item){
var chapter= $(this)
var chapterTitle=chapter.find('strong').text()
var videos=chapter.find('.video').children('li')
var chapterData={
chapterTitle:chapterTitle,
videos:[]
}
videos.each(function(item){
var video=$(this).find('.studyvideo')
var videoTitle = video.text()
var id=video.attr('href').split('video/')[1]
// console.log('sssss')
chapterData.videos.push({
title:videoTitle,
id:id
})
})
courseData.push(chapterData)
})
return courseData
}
function printCourseInfo(courseData){
courseData.forEach(function(item){
var chapterTitle = item.chapterTitle
console.log(chapterTitle + '\n')
item.videos.forEach(function(video){
console.log(' 【' + videos.id + '】 ' + videos.title + '\n')
})
})
}
http.get(url,function(res){
var html=''
res.on('data',function(data){
html += data
})
res.on('end',function(){
var courseData = filterChapters(html)
printCourseInfo(courseData)
})
}).on('error',function(){
console.log('獲取出錯')
})
2016-10-14
那是因為現在慕課網的html頁面元素的class名更改了。
1、var chapters=$('.learnchapter') ?修改為 ? ??var chapters=$('.chapter')
2、var video=$(this).find('.studyvideo') ?修改為 ?var video=$(this).find('.J-media-item')
2016-10-21
66666666666
2016-10-17
666,謝謝!