使用jQuery开发一个响应式超酷整合RSS信息阅读杂志
如果大家喜欢阅读博客文章的话,可能都会使用RSS阅读器,今天这里我们将使用jQuery来开发一个响应式的RSS信息阅读应用,使用它你可以将你喜欢的RSS文章以聚合的方式显示在同一个页面,类似一本在线的杂志或者刊物,你也可以自定义配置用来设定需要访问的RSS源,希望大家喜欢!
使用的js类库和jQuery插件:
HTML代码
HTML代码非常简单,由显示内容,RSS设置窗口及其遮盖层组成
生成RSS阅读信息内容的html代码如下:
- <div id="title">
- <h1 style="padding:10px;font-size:50px;">gbin1 rss feed magazine</h1>
- <div id="config"><a id="setting" href="#"></a></div>
- </div>
- <div id="content"></div>
生成RSS配置弹出窗口及其遮盖层html代码如下:
- <div id="modelwrapper"></div>
- <div id="model">
- <h2>add new feed</h2>
- <div>
- RSS url: <input id="rssvalue"type="text" placeholder="eg. http://feed.feedsky.com/GBin1" /><input type="button" value="save" id="saverss"/><input type="button" value="+" id="addrss"/>
- </div>
- <ul id="rsslist">
- </ul>
- </div>
Javascript代码
从Cookie中取得当前的RSS内容,这里使用sociallist插件来取得RSS信息内容,并且使用cufon来美化字体:
- $(document).ready(function () {
- $('#setting').animate({opacity:0.4}).animate({opacity:1})
- Cufon.replace('body').CSS.ready(function() {
- if (cookie.enabled()) {
- } else {
- alert('you need to enable the cookie, thanks!');
- }
- var rsslinks = cookie.get('gbin1-rsslinks');
- if(rsslinks==null){
- cookie.set('gbin1-rsslinks', 'http://feed.feedsky.com/GBin1');
- rsslinks = 'http://feed.feedsky.com/GBin1';
- }
- var rsslinklist = rsslinks.split('|');
- var rsslistarray = new Array();
- for(a=0;a<rsslinklist.length;a++){
- if(rsslinklist[a].trim()!==''){
- rsslistarray.push({name:'rss', id:rsslinklist[a]});
- }
- }
- $('#content').socialist({
- networks: rsslistarray,
- isotope:true,
- random:false,
- textLength: 800,
- theme: 'none',
- maxResults: 50,
- fields:['source','heading','text','date','image','followers','likes']
- });
- });
- });

下面代码控制弹出的RSS配置对话框,并且保存RSS到用户当前浏览器的cookie中:
- $(function(){
- $('#config').on('click', function(){
- console.log('config');
- var model = $('#model');
- var w = $(window).width();
- var h = $(window).height();
- var left = w/2 - model.outerWidth()/2;
- var top = h/2 - model.outerHeight()/2;
- $('#modelwrapper').fadeIn();
- $('#model').animate({left:left, top:top}).fadeIn();
- var rssliststr = '';
- var rsslinks = cookie.get('gbin1-rsslinks');
- var rsslinklist = rsslinks.split('|');
- for(a=0;a<rsslinklist.length;a++){
- if(rsslinklist[a].trim()!==''){
- rssliststr += '<li><a style="color:red" class="deleteit" href="#">[x]</a> <span>' + rsslinklist[a] + '</span></li>';
- }
- }
- $('#rsslist').html(rssliststr);
- Cufon.refresh();
- });
- var addcxt = $('#addrss').on('click', function(){
- var url = $('#rssvalue').val(),
- rss = '<span>' + url + '</span>',
- addbutton = $('#addrss');
- $(this).val('add...');
- $.getFeed({
- url: url,
- success: function(feed) {
- console.log(feed.title);
- $('#rsslist').append('<li><a style="color:red" class="deleteit" href="#">[x]</a> ' + rss + '</li>');
- Cufon.refresh();
- addbutton.val('+');
- },
- error: function(){
- alert('Please ensure it is a valid RSS url');
- addbutton.val('+');
- }
- });
- });
- $('#saverss').on('click', function(){
- var rsslinks='';
- $('#model').fadeOut(400);
- $('#modelwrapper').fadeOut(600);
- $('#rsslist li').each(function(){
- rsslinks = rsslinks + '|' + $(this).find('span').text();
- });
- cookie.set('gbin1-rsslinks', rsslinks, {
- expires: 30
- });
- location.reload();
- });
- $('#rsslist').on('click', '#rsslist .deleteit', function(){
- $(this).closest('li').remove();
- });
- });
注意以上代码我们自己实现了一个遮盖层来突显对话框效果,并且在用户保存RSS前判断RSS地址是否正确。
在线演示
我们添加一个新的RSS地址: http://www.leiphone.com/feed (雷锋网)


保存RSS地址后返回主界面显示所有的RSS内容:

大家可以看到列出了gbin1和雷锋网的所有最新的RSS文章种子。如果你缩放浏览器窗口,可以看到内容随着窗口大小自适应显示,是不是很不错?
希望大家喜欢这个在线整合RSS阅读杂志,如果你有任何问题,请给我们留言,谢谢!
使用jQuery开发一个响应式超酷整合RSS信息阅读杂志的更多相关文章
- Bootstrap3.1开发的响应式个人简历模板
在线演示 使用bootstrap3快速开发一个响应式的个人简历,如果有兴趣了解如何开发,请访问GB课程库,地址如下: Bootstrap3构建响应式前端设计师简历模板 http://www.gbtag ...
- AudioPlayer.js,一个响应式且支持触摸操作的jquery音频插件
AudioPlayer.js是一个响应式.支持触摸操作的HTML5 的音乐播放器.本文是对其官网的说用说明文档得翻译,博主第一次翻译外文.不到之处还请谅解.之处. JS文件地址:http://osva ...
- Web移动前端开发-——bootstarp响应式框架
移动端WEB开发之响应式布局 1.0 响应式开发原理 1.1 响应式开发原理 就是使用媒体查询针对不同宽度的设备进行布局和样式的设置,从而适配不同设备的目的. 设备的划分情况: 小于768的为超小屏幕 ...
- 一个响应式框架——agera
Google在上周开源了一个响应式框架——agera,相信它会慢慢地被广大程序员所熟知.我个人对这样的技术是很感兴趣的,在这之前也研究过RxJava,所以在得知Google开源了这样的框架之后第一时间 ...
- 一个响应式数据库框架SQLBrite,完美解决数据库和UI的同步更新!
相信小伙伴们在开发中或多或少都可能遇到过这样的问题:打开一个应用后,为了快速响应,先将数据库中的数据呈现给用户,然后再去网络上请求数据,请求成功之后将数据缓存至数据库,同时更新UI,但是我们经常会这样 ...
- 使用media Queries实现一个响应式的菜单
Media queries是CSS3引入的一个特性,使用它可以方便的实现各种响应式效果.在这个示例中我们将会使用media queries实现一个响应式的菜单.这个菜单会根据当前浏览器屏幕的大小变化而 ...
- media Queries实现一个响应式的菜单
使用media Queries实现一个响应式的菜单 Media queries是CSS3引入的一个特性,使用它可以方便的实现各种响应式效果.在这个示例中我们将会使用media queries实现一 ...
- 纯css3开发的响应式设计动画菜单(支持ie8)
这是一个响应式设计的菜单.单击列表图标,当你显示屏大小可以完全水平放下所有菜单项时,菜单水平显示(如图1).当你的显示屏不能水平放置所有菜单项时,菜单垂直显示(如图2). 而且显示的时候是以动画的型式 ...
- 一款由css3和jquery实现的响应式设计导航
2014年响应式设计成为设计主流.今天要给大家带来一款由css3和jquery实现的响应式设计导航.当显示器为pc时,导航为横条.当客户端为移动端时,呈现坚形导航.我们一起看下效果图: 在线预览 ...
随机推荐
- linux下进度条的编写和实现
实现了一个简单的进度条,主要技术啥的算不上,但有几个需要注意的点 首先是回车符,回车符可不是\n,我们可以把\n看成是两个动作的合体,分别是,回车和换行,都有自己对应的符号,这利用回车符一直在同一个位 ...
- html及css常用的单词
string? 字符串 boolean? 布尔数学体系,1,0 node? 节点,结 log? ? 日志,记录 console? 控制台 alert? ? 警报 document? 文档 write? ...
- uploadify 上传遇到跨域问题
flash上传跨域,一般是加入crossdomain.xml 我用了别人的图片服务器,只能做此下策: //CURLFile 实现 $file = $_FILES['Filedata']['tmp_na ...
- 斯坦福第六课:逻辑回归(Logistic Regression)
6.1 分类问题 6.2 假说表示 6.3 判定边界 6.4 代价函数 6.5 简化的成本函数和梯度下降 6.6 高级优化 6.7 多类分类:一个对所有 6.1 分类问题 在分类问题中 ...
- 《Diagnostic use of facial image analysis software in endocrine and genetic disorders: review, current results and future perspectives》学习笔记
<使用面部图像分析软件诊断内分泌和遗传疾病:回顾,当前研究结果以及未来展望> Abstract 库欣综合征(CS)和肢端肥大症普遍是在发病后几年才能被诊断出的内分泌疾病.现在需要新的诊断方 ...
- css3写的实用表单美化
<!DOCTYPE html> <!--[if IE 7 ]> <html lang="en" class="ie7"> & ...
- CentOS下 pycharm开发环境搭建之无穷无尽的问题
在上一篇的环境搭建中,表面上以为已经升级好python,安装好pycharm,并且可以用上了django框架,谁知道,谁知道,又是一断被虐的经历,我都要快恼羞成怒了. 在些记录一下我的经历. 1.首先 ...
- Upstart 1.10 发布,系统初始化守护进程
Upstart 是一个用以替换 /sbin/init 守护进程的软件,基于事件机制开发.可用来处理启动过程中的任务和服务启动. Upstart 1.10 发布,改进记录: New bridges: u ...
- 了解linux下RAID(磁盘阵列)创建和管理
现在的操作系统,不论是windows 还是linux都具有raid的功能,RAID 分为硬件 RAID 和软件 RAID, 硬件 RAID 是通过 RAID 卡来实现的,软件RAID是通过软件实现的, ...
- [自娱自乐] 2、超声波测距模块DIY笔记(二)
前言 上一节我们已经大致浏览下目前销售的超声波测距模块同时设计了自己的分析电路,这次由于我买的电子元件都到了,所以就动手实验了下!至写该笔记时已经设计出超声波接收模块和超声波发射模块,同时存在超声波发 ...
