一、闲扯
有一天班长说了,同学们希望我开发一个可以共享位置的通讯录,于是自己简单设计了下功能。包括用户角色、发表微博、共享位置等等。这次也是有点私心的,为了锻炼最近看的angularjs,于是果断选择Node.js + MongoDB + angular.js的方案。当然,开发Node.js的体会越来越深刻。记得,去年leader告诉我说尽量让node的每一个服务只支撑一个业务功能,这样才能更方便的维护。当时特别想把一个Node服务做的特别强大。现在看来leader的做法是对的,我更加倾向于把node服务功能单一化...
二、直接上干货
数据库服务部署在阿里云;静态文件服务器采用的是Github page。
Github项目地址:https://github.com/vczero/OurTimes
线上体验地址:http://vczero.github.io/tuban/main.html#/
没图说个球啊,上图给大家看看2张截图:
(1)首页
(2)通讯录
....更多去线上体验...
三、项目
总项目: https://github.com/vczero/OurTimes
开发了所需要的服务:https://github.com/vczero/OurTimes/tree/master/server
开了web pc client: https://github.com/vczero/OurTimes/tree/master/client-web
开发了简易的后台管理系统:https://github.com/vczero/OurTimes/tree/master/client-admin
欢迎大家fork ,follow和共享代码,一起构建前端而努力。
四、附上web-pc端Angular的入口文件代码
var app = angular.module('app', ['ui.router', 'ngCookies']); var SERVER_BASE_URL = 'http://127.0.0.1:3000/'; //初始化配置 app.run(['$rootScope', function($rootScope) { $rootScope.appName = '图班网'; $rootScope.desc = '基于位置的通讯录'; $rootScope.author = '鬼谣'; $rootScope._email = 'wlhmyit@126.com'; }]);//调用的服务列表 app.constant('ServiceConfig', { wei_content: SERVER_BASE_URL + 'wei/get', wei_zan: SERVER_BASE_URL + 'wei/zan', wei_comment: SERVER_BASE_URL + 'wei/comment', wei_create: SERVER_BASE_URL + 'wei/create', user_get: SERVER_BASE_URL + 'user/get', user_login: SERVER_BASE_URL + 'user/login', user_register: SERVER_BASE_URL + 'user/register', user_common: SERVER_BASE_URL + 'user/getCommon', user_ben: SERVER_BASE_URL + 'user/getBen', user_self: SERVER_BASE_URL + 'user/getSelf', user_common_update: SERVER_BASE_URL + 'user/updateCommon', user_ben_update: SERVER_BASE_URL + 'user/updateBen', user_ben_get_name: SERVER_BASE_URL + 'user/singleBen/name', user_common_get_nickname: SERVER_BASE_URL + 'user/getCommon/name', user_ben_get_realname: SERVER_BASE_URL + 'user/singleBen/name', wei_get_token_page: SERVER_BASE_URL + 'wei/getByToken', wei_delete: SERVER_BASE_URL + 'wei/delete', user_update_password: SERVER_BASE_URL + 'user/updatePassword', article_get: SERVER_BASE_URL + 'article/get', article_detail: SERVER_BASE_URL + 'article/get/id', amap_url: 'http://webapi.amap.com/maps?v=1.3&key=ad925c5003760094713775d64748d872&callback=init' }); //JSON parse app.config(['$httpProvider', function($httpProvider) { $httpProvider.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=utf-8'; $httpProvider.defaults.headers.put['Content-Type'] = 'application/x-www-form-urlencoded;charset=utf-8'; $httpProvider.defaults.transformRequest = [function(data) { var obj = []; for (var key in data) { obj.push(key + '=' + data[key]); } return obj.join('&'); }]; }]); //路由配置 app.config(['$stateProvider', '$urlRouterProvider', function($stateProvider, $urlRouterProvider) { /*URL路由*/ $urlRouterProvider.otherwise("/"); /*状态配置*/ $stateProvider //首页 .state('index', { url: '/', views: { '': { templateUrl: 'views/index/index.html', }, 'header@index': { templateUrl: 'views/header.html', controller: 'HeaderController' }, 'footer@index': { templateUrl: 'views/footer.html', controller: '' }, 'weibo@index': { templateUrl: 'views/index/weibo.html', controller: 'WeiboController' }, 'article@index': { templateUrl: 'views/index/article.html', controller: 'ArticleController' }, 'post@index': { templateUrl: 'views/index/post.html', controller: 'PostWeiboController' } } }) .state('login', { url: '/login', views: { '': { templateUrl: 'views/login/login.html', controller: 'LoginController' } } }) .state('register', { url: '/register', views: { '': { templateUrl: 'views/register/register.html', controller: 'RegisterController' } } }) .state('contacts', { url: '/contacts', views: { '': { templateUrl: 'views/contacts/contacts.html', controller: '' }, 'header@contacts': { templateUrl: 'views/header.html', controller: 'HeaderController' }, 'userinfo@contacts': { templateUrl: 'views/contacts/userinfo.html', controller: 'UserInfoController' }, 'map@contacts': { templateUrl: 'views/contacts/map.html', controller: 'MapController' }, 'search@contacts': { templateUrl: 'views/contacts/search.html', controller: 'SearchUserController' } } }) .state('ucenter', { url: '/ucenter', views: { '': { templateUrl: 'views/ucenter/ucenter.html', controller: '' }, 'header@ucenter': { templateUrl: 'views/header.html', controller: 'HeaderController' }, 'userWeibo@ucenter': { templateUrl: 'views/ucenter/weibo.html', controller: 'UcWeiboController' }, 'userDetailInfo@ucenter': { templateUrl: 'views/ucenter/user.html', controller: 'UcUserController' }, 'footer@ucenter': { templateUrl: 'views/footer.html', controller: '' } } }) .state('article', { url: '/article/:id', views: { '': { templateUrl: 'views/article/article.html', controller: '' }, 'header@article': { templateUrl: 'views/header.html', controller: 'HeaderController' }, 'article_content@article': { templateUrl: 'views/article/article_content.html', controller: 'ArticleDetailController' }, 'footer@article': { templateUrl: 'views/footer.html', controller: '' } } }) .state('article_index', { url: '/article', views: { '': { templateUrl: 'views/article/article.html', controller: '' }, 'header@article_index': { templateUrl: 'views/header.html', controller: 'HeaderController' }, 'article_content@article_index': { templateUrl: 'views/article/article_content.html', controller: 'ArticleDetailController' }, 'footer@article_index': { templateUrl: 'views/footer.html', controller: '' } } });
}]);
本文向大家介绍关于Android高德地图的简单开发实例代码(DEMO),包括了关于Android高德地图的简单开发实例代码(DEMO)的使用技巧和注意事项,需要的朋友参考一下 废话不多说了,直接给大家上干货了。 以下为初次接触时 ,练手的DEMO 以上所述是小编给大家介绍的关于Android高德地图的简单开发实例代码(DEMO),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家
本文向大家介绍Android调用高德地图定位的方法,包括了Android调用高德地图定位的方法的使用技巧和注意事项,需要的朋友参考一下 在App中使用地图定位十分常见,购物功能的可以直接定位当前位置,发动态功能可以定位当前位置发出,社交功能可以定位周边用户等等。这里我使用高德地图定位当前位置并显示地址和经纬度。 github代码传送门 先上效果图: 实现步骤: 1. 创建应用获取key: 接入第三
实习拷打 高德地图打车输入起终点后,展示路线这个界面,需要关注哪些测试点 算法:给定一个字符串S,检查是否能重新排布其中的字母,使得两相邻的字符不同。 若可行,输出任意可行的结果。若不可行,返回空字符串。 你需要绕过平台的监控,假设你有10个账号,想要爬取360个城市的数据,你需要怎么处理,才能保证最大程度的绕过平台的监控去获取数据,以及账号肯定不够用,如何处理这个调度,如何保证所有账号处理的城市
问题内容: 我们正在寻找一种快速准确的方法来根据访问者的IP获取访问者的位置。 我们已经尝试过ipinfodb.com,但在调用API时,其API使我们的网站严重滞后。 您还建议其他哪些服务? 问题答案: 获取Geo-IP信息 请求地理IP服务器(netip.de)进行检查,并返回IP所在的位置(主机,州,国家/地区,城镇)。
Spring data提供了各种用于CRUD、分页和mongob排序的存储库。当我们需要来自mongob的使用各种属性的文档时,我们倾向于编写方法或编写带有显式查询的方法,并用注释。但是如果我的文档有许多属性并且我需要各种获取文档的方法,Spring是否提供了一种“存储库方法”来接收属性和值的Map?编写各种可能很麻烦。使用QueryDSL似乎是一种选择,但需要代码生成和build.gradle更
本文向大家介绍基于JavaScript定位当前的地理位置,包括了基于JavaScript定位当前的地理位置的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了js定位当前地理位置的具体代码,供大家参考,具体内容如下 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。