爱搜索,爱生活,基于豆瓣API & Angular开发的web App(by vczero)

一、扯淡的说

name:【豆瓣搜索】

最近关注了下豆瓣的API,发现豆瓣开放平台需要加强API文档撰写啊....但是有个可喜的发现豆瓣V2接口提供了搜索接口。最近在用phantom弄些爬虫,想想,真是美丽极了!有个豆瓣的接口,我都不用去爬数据,不用数据存储,丢给github page直接完事。豆瓣,Nice!最近也在看angular,于是就萌生了使用Angular + 豆瓣API 做一个web app。于是...网上回家就折腾了。

体验地址:http://vczero.github.io/t/html/index.html#/

项目地址https://github.com/vczero/search  (欢迎大家fork,任意修改,继续增加功能;欢迎拍砖,一起进步。)

二、直接上图

(1)图书搜索

(2)音乐搜索界面

(3)图书详情

(4)电影搜索

三、项目结构和简介

三、几个注意点

(1)-webkit-tap-highlight-color:rgba(255,255,255,0);去除点击时的高亮阴影

(2)box-sizing:border-box的使用,包含padding的像素计算

(3)position fixed 和 搜索跳转的结合(虚拟键盘引起)

(4)angular-ui-router的多视图控制

(5)ios & android系统的各种细节

(6)压缩angularjs代码依赖注入的问题

...

我觉得比较重要的服务和状态路由的代码贴出来

  1 /*服务的URL配置*/
  2 app.constant(‘ServiceConfig‘, {
  3     book_search: ‘https://api.douban.com/v2/book/search‘,
  4     book_search_id: ‘https://api.douban.com/v2/book/‘,
  5
  6     music_search: ‘https://api.douban.com/v2/music/search‘,
  7     music_search_id: ‘https://api.douban.com/v2/music/‘,
  8
  9     movie_search: ‘https://api.douban.com/v2/movie/search‘,
 10     movie_search_id: ‘https://api.douban.com/v2/movie/subject/‘
 11 });
 12
 13 app.config([‘$stateProvider‘, ‘$urlRouterProvider‘,function($stateProvider, $urlRouterProvider){
 14     /*URL路由*/
 15     $urlRouterProvider.otherwise("/");
 16
 17     /*状态配置*/
 18     $stateProvider
 19         //首页
 20         .state(‘index‘,{
 21             url: ‘/‘,
 22             views:{
 23                 header:{
 24                     templateUrl: ‘../html/views/list_header.html‘,
 25                     controller: ‘SearchController‘
 26                 },
 27                 container:{
 28                     templateUrl: ‘../html/views/list_book.html‘,
 29                     controller: ‘BookListController‘
 30                 },
 31                 footer:{
 32                     templateUrl: ‘../html/views/list_footer.html‘,
 33                     controller: ‘‘
 34                 }
 35             }
 36         })
 37         //book list
 38         .state(‘book_list‘,{
 39             url: ‘/book‘,
 40             views:{
 41                 header:{
 42                     templateUrl: ‘../html/views/list_header.html‘,
 43                     controller: ‘SearchController‘
 44                 },
 45                 container:{
 46                     templateUrl: ‘../html/views/list_book.html‘,
 47                     controller: ‘BookListController‘
 48                 },
 49                 footer:{
 50                     templateUrl: ‘../html/views/list_footer.html‘,
 51                     controller: ‘‘
 52                 }
 53             }
 54         })
 55         // book detail
 56         .state(‘book_detail‘,{
 57             url: ‘/book/:id‘,
 58             views:{
 59                 header:{
 60                     templateUrl: ‘../html/views/list_header.html‘,
 61                     controller: ‘SearchController‘
 62                 },
 63                 container:{
 64                     templateUrl: ‘../html/views/detail_book.html‘,
 65                     controller: ‘BookDetailController‘
 66                 },
 67                 footer:{
 68                     templateUrl: ‘../html/views/list_footer.html‘,
 69                     controller: ‘‘
 70                 }
 71             }
 72         })
 73
 74         // music list
 75         .state(‘music_lsit‘,{
 76             url: ‘/music‘,
 77             views:{
 78                 header:{
 79                     templateUrl: ‘../html/views/list_header.html‘,
 80                     controller: ‘SearchController‘
 81                 },
 82                 container:{
 83                     templateUrl: ‘../html/views/list_music.html‘,
 84                     controller: ‘musicListController‘
 85                 },
 86                 footer:{
 87                     templateUrl: ‘../html/views/list_footer.html‘,
 88                     controller: ‘‘
 89                 }
 90             }
 91         })
 92
 93         // movie list
 94         .state(‘movie_lsit‘,{
 95             url: ‘/movie‘,
 96             views:{
 97                 header:{
 98                     templateUrl: ‘../html/views/list_header.html‘,
 99                     controller: ‘SearchController‘
100                 },
101                 container:{
102                     templateUrl: ‘../html/views/list_movie.html‘,
103                     controller: ‘movieListController‘
104                 },
105                 footer:{
106                     templateUrl: ‘../html/views/list_footer.html‘,
107                     controller: ‘‘
108                 }
109             }
110         })
111
112         .state(‘search‘,{
113             url: ‘/search/:type‘,
114             views:{
115                 header:{
116                     templateUrl: ‘../html/views/search.html‘,
117                     controller: ‘Search‘
118                 },
119                 container:{
120                     templateUrl: ‘‘,
121                     controller: ‘‘
122                 },
123                 footer:{
124                     templateUrl: ‘‘,
125                     controller: ‘‘
126                 }
127             }
128         });
129 }]);

时间: 2024-12-16 23:56:23

爱搜索,爱生活,基于豆瓣API & Angular开发的web App(by vczero)的相关文章

基于豆瓣API的APP

团队模式 我们团队选择的模式是功能团队模式,具备不同能力的同学们平等协作,共同完成一个功能.在这个功能完成之后,这些人又重新组织,和别的角色一起去完成下一个功能.他们之间没有管理和被管理的关系,小组内的交流也比较频繁. 团队人员:RXXTN.非职业天使.略略li.轻咏上邪.guantongxue 团队题目 ↑这是头号玩家电影里的一幕↑,在绿洲游戏创始人哈利迪的个人档案馆中,哈利迪按照时间记录了自己生平看过的所有电影.受到这一幕的启发,我们团队决定开发一款APP,但不仅仅是记录自己在何时看过什么,

豆瓣API接口开发,结合angularJS来做,感觉爽歪歪!

第一次做还是先说下API 是什么鬼? API : application program interface 应用程序编程接口: 有那些常见的API: webAPI : 通过WEB方式提供结构叫 WEBAOPI ; API : 所有有输入有输出的东西都可以称之为API  --- 都是函数: 例如:Math.random()  --- api 例如: 豆瓣API 开发平台: https://developers.douban.com/wiki/?title=guide 豆瓣API V2 (测试版)

Be Angular | Bootstrap Admin Web App with AngularJS

http://www.diystring.com/#/app/dashboard-v1

豆瓣api开发

前面有说过豆瓣API的开发,在做一些开源项目的时候,很多时候会用到豆瓣API接口,拿过来做测试,现在只是对豆瓣API开发做一些简单的梳理: 豆瓣API开发的接口: https://developers.douban.com/wiki/?title=api_v2 请求的参数: 返回: { "start" = 0, "count" = 10, "total" = 50, "targets" = [Target, ...] } 下面

爱加密拟开放云加密API,华为PowerApp将首批接入!!

2014年7月26日至27日,华为PowerApp能量之旅在成都举行,活动本着为开发者全过程服务的初衷,针对创业团队在融资成长方面的困惑,专门邀请了业内著名的投资人士和创业团队现场与开发者进行沟通交流. 华为PowerApp产品总监Mark介绍,PowerApp面向所有App开发者,致力联盟业内优秀的能力.应用及服务,着力建立PaaS+BaaS+App客户端的基础服务平台,做更开放的互联网生态圈.PowerApp在此次活动中还透露,后续将推出更多功能与服务,并将与爱加密(www.ijiami.c

一个豆瓣API的使用——拒绝思维定式

好久没写博客了,最近一直在用豆瓣API爬数据,不知道以前的是什么样,毕竟刚开始用没多久,就用最新的V2版本,以前的不更新了,可以参照https://developers.douban.com/wiki/?title=api_v2,但是在用某些API的时候会出一些问题,需要自己琢磨琢磨,因为网上关于API爬数据的资料并不多,今天就聊一些豆瓣同城V2的一个接口的调用——获取活动列表. 根据豆瓣同城V2提供的接口,获取活动列表:GET https://api.douban.com/v2/event/l

《云阅》一个仿网易云音乐UI,使用Gank.Io及豆瓣Api开发的开源项目

CloudReader 一款基于网易云音乐UI,使用GankIo及豆瓣api开发的符合Google Material Desgin阅读类的开源项目.项目采取的是Retrofit + RxJava + MVVM-DataBinding架构开发.开发中所遇到的各种问题已归纳在这里. github地址:CloudReader What can be learned about this project 那么,从本项目中你能学到哪些知识呢? 1.干货集中营内容与豆瓣电影书籍内容. 2.高仿网易云音乐歌单

基于百度风云榜开发的API数据接口-为APP资讯资讯服务

是基于百度搜索风云榜采集的新闻信息,,该资讯会更好的体现人们关注的人多事件与热词 通过数据采集,同时发布相信的数据开放API接口 1.取得热词信息列表 如:api.yi18.net/top/list 2.取得热词信息详细 如:api.yi18.net/top/show?id=1 更多的API文档 doc.yi18.net/topwendang 数据镜像网站:  top.yi18.net API数据接口的免费开放,希望为更多的APP开发者提供更专业的数据 接口.为APP开发提供更简单的新闻热点板块

你也可以玩转Skype -- 基于Skype API开发外壳程序入门

原文:你也可以玩转Skype -- 基于Skype API开发外壳程序入门 Skype是目前这个星球上最厉害的IM+VOIP软件,Skype现在已经改变了全球2.8亿人的生活方式.你,值得拥有! :) Skype中文官网:http://skype.tom.com/ Skype全球官网:http://www.skype.com/ Skype也是世界上最开放,最具创新意识的IM工具,他提供了Skype API, Skype4COM, Skype4Java几种形式的开发接口给Skype爱好者编写Sky