0

为可能是一个非常基本的问题道歉。我正在用 Angular 制作一个小演示测验项目。在第一页上,我有一个基本的双向数据绑定问候语(即您在一个框中输入您的姓名,它会欢迎用户,例如<p> Welcome {{name}} </p>

如何保存输入的名称并将此欢迎带到下一页/模板?这是代码

<strong>Welcome</strong> {{email}}

  <p class="lead">Please enter your name </p>
      <body ng-app ng-init="email = 'John';">
      <label>enter name<input type="text" ng-model="firstName"/></label><br />
  </body>

这是我的路线

'use strict';


angular
  .module('angularQuizApp', [
    'ngAnimate',
    'ngCookies',
    'ngResource',
    'ngRoute',
    'ngSanitize',
    'ngTouch'
  ])
  .config(function ($routeProvider) {
    $routeProvider
      .when('/', {
        templateUrl: 'views/main.html',
        controller: 'MainCtrl'
      })
      .when('/about', {
        templateUrl: 'views/about.html',
        controller: 'AboutCtrl'
      })
      [...]

我从一个 yeoman angular 脚手架开始,所以只更改了很少的代码。提前谢谢你善良的角度向导

4

1 回答 1

2

为了轻松实现您的愿望,您可以创建一个保留用户名的服务:

angular.module('angularQuizApp').
 factory('StorageService',[
function(){

    var name = "";

    var _setName  = function(name){
        name = name;
    }:

    var _getName = function(){
        return name;
    };  

    return {
        setName : _setName,
        getName : _getName,
    }



}]);

然后在您的控制器中,从 service 调用正确的方法:

angular.module('angularQuizApp').
controller('MyController', ['$scope', 'StorageService',
   function($scope, StorageService) {
     $scope.name = StorageService.getName(); // or setName(name_value)
}]);

通过这种方式,该服务通过您的 Angular 应用程序保留用户的姓名。在这项服务中,您可以保存任何您想要的东西。但是如果您退出应用程序,此对象/名称将被销毁。

如果您想持久保留对象,请查看 angular-storage :https ://github.com/grevory/angular-local-storage

编辑

这是我制作的一个功能性应用程序: http ://plnkr.co/edit/7ZzBYnKmV1xflzi81YQc?p=preview

于 2015-06-27T12:16:08.867 回答