0

angular socket.io と nodejs を使用して Web アプリを構築しようとしています。特定のテンプレートが ng-view にロードされているときに、各 tym でサーバー ソケットに接続することは可能ですか? 私はいくつかの方法でそれを試しました。初めてのみ機能します。別のビューを読み込んで古いビューに戻ったときにページを更新する必要があります。そうしないと機能しません。よろしくお願いします!サーバー側コード:

io.on("connection", function(socket){
  Events.find().exec(function(err,existing_events){    
      if(err)
      {
          console.log(err);
          socket.emit('err',{message: "events can not be loaded now!"})
      }
      else
      {
        socket.emit('events',{events: existing_events});
      }
    });
}

クライアント側のコードは次のとおりです:角度構成:

window.app.config(['$routeProvider', '$locationProvider',
    function($routeProvider,$locationProvider) {
        $locationProvider.html5Mode(true);
        $locationProvider.hashPrefix('!');
        $routeProvider.
        when('/event', {
            templateUrl: '/views/eventsHome.html'            


        }).
        when('/', {
            templateUrl: 'views/index.html'
        }).
        otherwise({
            redirectTo: '/'
        });
    }
]);

eventsHome.html:

<div ng-controller="eventsCtrl">
  <label style="width:15%;float:left;">Current Events</label>
  <a style="float:left;" href="" id="create" ng-click="create()">Create Event</a>
  <div style="border:none; width:90%; max-height:200px; overflow:auto;overflow-x:hidden; clear:both; padding-left:2%; margin-top:5%;">


    <div id='events' ng-repeat="event in events">
            <a href="/event/{{event.name}}" ng-click="leave()">{{event.name}}</a>

    </div>
  </div>


</div>

イベントコントロール:

angular.module('myApp.system').controller('eventsCtrl', ['$scope', 'Global','$location', function ($scope, Global,$location) {
      var socket;
      var sessionId = '';
      var serverBaseUrl = document.domain;
      socket = io.connect(serverBaseUrl);
      $scope.events;
      socket.on('connect', function () {
        sessionId = socket.socket.sessionid;
        console.log('Connected ' + sessionId);
        //socket.emit('newUser', {id: sessionId, name: user_name});
      });
      socket.on('events',function(data){
        //updateEvents(data.events);
        $scope.$apply(function () {
          // body...
          $scope.events=data.events;
        });

      });

 }]);
4

1 に答える 1

0

あなたが望むことを行う最も簡単な方法は(私が正しく理解していると仮定して)、$routeサービスを使用してビューの変更をリッスンすることだと思います。使用可能なすべての$routeChangeイベントのドキュメントは、Angular Docsにあります。ルートの変更をリッスンする方法の例を次に示します。

'eventsCtrl'コントローラーで:

.controller('eventsCtrl', ['$scope','$rootScope', ... // and other dependencies
    function($scope, $rootScope, ...){
        ...
        $rootScope.$on('$routeChangeSuccess', function(e, currRoute, prevRoute){
            switch(currRoute){
                // test for which specific routes you want to check for
                // such as connecting to or destroying your various sockets
            }
        });
        ...
    }
]);

$rootScopeこれにより、ルートが変更されるたびに に通知され、どのルートに変更されたかがわかります。うまくいけば、それはあなたが望んでいたことをします。

于 2013-10-15T14:46:09.287 に答える