2

我是 AngularJs 的新手。我想要做的是更新 hashchange 事件的页面。

我目前所做的(并且知道这不是“正确”的方式)是:

<!DOCTYPE html>
<html>
<head>
<style>
    #hashdrop {
      display:block;
      border: 1px solid gray;
      width: 500px;
      overflow: auto;
      background-color: rgb(241,241,241);
      border-radius: 4px;
      text-align: center;
      vertical-align: middle;
      line-height: 100px;
      font-size: large;
      height: 100px;
    }
</style>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/2.0.2/jquery.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.0.7/angular.min.js"></script>
<script>
    var example = function($scope) {
      $scope.lastHash = location.hash.slice(1);
      $(window).on('hashchange', function (event) {
        $scope.lashHash = location.hash.slice(1);
        $scope.$apply();
      });
    };
</script>
<meta charset=utf-8 />
</head>
<body ng-app ng-controller="example">
  <div id="hashdrop" >
    {{lastHash}}
  </div>
</body>
</html>

(这可以复制粘贴到一个空白的 html 文件中并运行。对我来说,jsbin 没有正确检测到 haschange。)

这真的行不通。由于某种原因,该值没有更新,我认为在 angularjs 中有一个“正确”的方法。
我想了解如何正确执行此操作,更具体地说,如何更正此示例中的代码以以“角度方式”工作。

谢谢!

更新 1 好的,在阅读了关于 $location 的评论后,我找到了一些信息并将我的应用程序更改为:

<!DOCTYPE html>
<html>
<head>
<style>
    #hashdrop {
      display:block;
      border: 1px solid gray;
      width: 500px;
      overflow: auto;
      background-color: rgb(241,241,241);
      border-radius: 4px;
      text-align: center;
      vertical-align: middle;
      line-height: 100px;
      font-size: large;
      height: 100px;
    }
</style>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/2.0.2/jquery.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.0.7/angular.min.js"></script>
<script>
    angular.module('example',[]).config(function($locationProvider, $routeProvider) {
      $locationProvider.html5Mode(true);
    });
    var example = function($scope, $location) {


    };
</script>
<meta charset=utf-8 />
</head>
<body ng-app="example" ng-controller="example">
  <div id="hashdrop" >
    Hash = {{$location.hash()}}
  </div>
</body>
</html>

还是不行。输出中什么都没有显示..

4

2 回答 2

1

AngularJs 在所有正常路由的 url 中使用哈希,这是导航页面的默认方式。您使用 routeProvider 来定义 url-schemas,就像在后端 MVC 框架(如 Django)中一样,并且 routeProvider 将侦听散列中的更改并相应地加载新内容。

我建议做教程。它相当好(即使它错过了很多东西)。路线在步骤 7中演示。

只是警告。Angular 假定您使用哈希作为处理 url 和路由的主要方式,因此 routeParams 不会让您在更改 url 的哈希部分时只更改页面的一部分。为此,您可以切换到使用 get 参数或使用更灵活的 ui-router 之类的东西。

于 2013-11-12T08:39:09.680 回答
0

您可以使用而不是 jQuery 绑定到 hashchange 事件angular.element,从而可能减少依赖关系。

将此包含在您的控制器中。

angular.element(window).bind('hashchange', function() {
  console.log('hash has changed');
});

当哈希更改时,此代码将记录“哈希已更改”。

不确定它是否能解决您的问题(正如 Kevin Beal 指出的那样,您的代码中有一些更时髦的东西),但您在说什么“不起作用”有点不清楚。

值得注意angular.element 的是,如果 jQuery 可用,则使用 jQuery,因此如果您仍然想使用 jQuery,angular.element(window)则不会做任何与$(window).

于 2018-04-12T17:21:59.460 回答