使用 angular js 按日期排序 rss 新闻
sort rss news by date with angular js
我指的是 JavaScript 中的 答案,但我无法在 angular js 中处理它。
根据日期(最新的在最上面)对 rss 提要 进行排序的 javascript 答案 如下
data.query.results.rss.sort(function(item1, item2) {
var d1 = new Date(item1.channel.item.pubDate)
var d2 = new Date(item2.channel.item.pubDate)
return d2.getTime() - d1.getTime()
})
我的angular js(离子框架)如下:
$webServicesFactory.get(
"https://www.google.com/finance/company_news",
{},
{
output: "rss",
q: stock.e +":"+ stock.t
}
).then(
function success(xmlData) {
var x2js = new X2JS();
$globalFactory.personalStockNews = x2js.xml_str2json(xmlData).rss.channel.item;
$globalFactory.personalStockNews.sort(function(item1, item2) {
var d1 = new Date(item1.channel.item.pubDate);
var d2 = new Date(item2.channel.item.pubDate);
return d2.getTime() - d1.getTime();
})
console.info($globalFactory.personalStockNews);
$ionicLoading.hide();
$state.go("app.home");
},
function error(error) {
$globalFactory.personalStockNews = null;
$ionicLoading.hide();
$state.go("app.home");
}
);
},
function error(error) {
$ionicLoading.hide();
}
);
但是,它没有按预期排序。
我应该如何修改 javascript 到 angular js?
您可以使用下面的 rss 提要
'https://www.google.com/finance/company_news?q=SGX:533&ei=EeiDWaGGMpXUuATxloPgAw&output=rss' 根据日期对 rss 进行排序。
在html中,代码如下:
<a class="item item-icon-right" ng-if='showmore' ng-repeat="item in rssNews| orderBy: 'pubDate':true" ng-click="openitems(item.link)">
<h2>{{item.title}}</h2>
<h6>{{item.pubDate}}</h6>
<p {{story.description | htmlToPlaintext}}</p>
</div>
</a>
我认为您的排序函数应该类似于:
function(item1, item2) {
var d1 = new Date(item1.channel.item.pubDate)
var d2 = new Date(item2.channel.item.pubDate)
if (d1>d2) return -1
if (d2>d1) return 1
return 0
}
当然,如果您在问题中说明期望的结果是什么,那将会有所帮助。 :)
同时删除 ng-repeat 上的 orderby。这将覆盖您在控制器中进行的数组排序。
我指的是 JavaScript 中的
根据日期(最新的在最上面)对 rss 提要 进行排序的 javascript 答案 如下
data.query.results.rss.sort(function(item1, item2) {
var d1 = new Date(item1.channel.item.pubDate)
var d2 = new Date(item2.channel.item.pubDate)
return d2.getTime() - d1.getTime()
})
我的angular js(离子框架)如下:
$webServicesFactory.get(
"https://www.google.com/finance/company_news",
{},
{
output: "rss",
q: stock.e +":"+ stock.t
}
).then(
function success(xmlData) {
var x2js = new X2JS();
$globalFactory.personalStockNews = x2js.xml_str2json(xmlData).rss.channel.item;
$globalFactory.personalStockNews.sort(function(item1, item2) {
var d1 = new Date(item1.channel.item.pubDate);
var d2 = new Date(item2.channel.item.pubDate);
return d2.getTime() - d1.getTime();
})
console.info($globalFactory.personalStockNews);
$ionicLoading.hide();
$state.go("app.home");
},
function error(error) {
$globalFactory.personalStockNews = null;
$ionicLoading.hide();
$state.go("app.home");
}
);
},
function error(error) {
$ionicLoading.hide();
}
);
但是,它没有按预期排序。 我应该如何修改 javascript 到 angular js?
您可以使用下面的 rss 提要 'https://www.google.com/finance/company_news?q=SGX:533&ei=EeiDWaGGMpXUuATxloPgAw&output=rss' 根据日期对 rss 进行排序。
在html中,代码如下:
<a class="item item-icon-right" ng-if='showmore' ng-repeat="item in rssNews| orderBy: 'pubDate':true" ng-click="openitems(item.link)">
<h2>{{item.title}}</h2>
<h6>{{item.pubDate}}</h6>
<p {{story.description | htmlToPlaintext}}</p>
</div>
</a>
我认为您的排序函数应该类似于:
function(item1, item2) {
var d1 = new Date(item1.channel.item.pubDate)
var d2 = new Date(item2.channel.item.pubDate)
if (d1>d2) return -1
if (d2>d1) return 1
return 0
}
当然,如果您在问题中说明期望的结果是什么,那将会有所帮助。 :)
同时删除 ng-repeat 上的 orderby。这将覆盖您在控制器中进行的数组排序。