AngularJS + Node.js + MongoDB开发的基于高德地图位置的通讯录

  一、闲扯

  有一天班长说了,同学们希望我开发一个可以共享位置的通讯录,于是自己简单设计了下功能。包括用户角色、发表微博、共享位置等等。这次也是有点私心的,为了锻炼最近看的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)首页

AngularJS + Node.js + MongoDB开发的基于高德地图位置的通讯录

  (2)通讯录

AngularJS + Node.js + MongoDB开发的基于高德地图位置的通讯录

  ....更多去线上体验...

  三、项目

  总项目: 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 = '[email protected]';

  }]);

  //调用的服务列表

  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: ''

  }

  }

  });

  }]);