当前位置: 首页 > 编程笔记 >

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

谷善
2023-03-14
本文向大家介绍AngularJS + Node.js + MongoDB开发的基于高德地图位置的通讯录,包括了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)首页

(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: 接入第三

  • 问题内容: 我们正在寻找一种快速准确的方法来根据访问者的IP获取访问者的位置。 我们已经尝试过ipinfodb.com,但在调用API时,其API使我们的网站严重滞后。 您还建议其他哪些服务? 问题答案: 获取Geo-IP信息 请求地理IP服务器(netip.de)进行检查,并返回IP所在的位置(主机,州,国家/地区,城镇)。

  • uniapp如何通过“经纬度”调用“高德”、“腾讯”地图? uniapp目前使用的是“天地图” 如果打包成app,则判断用户手机是否安装“高德”、“腾讯”,如果有,则调用,否则提示没有“地图软件”,如果发布成H5,则打开“高德”、“腾讯”的网页版导航

  • 本文向大家介绍iOS开发项目- 基于WebSocket的聊天通讯(2),包括了iOS开发项目- 基于WebSocket的聊天通讯(2)的使用技巧和注意事项,需要的朋友参考一下 公司项目需要开发一个类似QQ、微信的即时IM聊天功能,做到实时监控消息,需要用的技术是websocket,今天整理下语言聊天这块;其实语言聊天,包含两部分,录音和音乐播放,关于简单语言聊天功能如下图: 录音 在AVFound

  • 高德地图使用的原生,突然之间加载不出来是为什么?做了一下marker标记,然后就加载不出来,回退代码之后还是加载不出来。有做过原生高德地图的朋友吗?麻烦指导一下,谢谢。我要的效果很简单,就是在地图上标记设备位置,然后在标记上绑定一个点击事件,点击获取在线设备的状态。 另外有做过物联网的哥们吗?就是这个获取设备状态信息是服务端做还是前端做的?