gpt4 book ai didi

javascript - 我怎样才能对 AngularJs 中的 hashchange 事件采取行动

转载 作者:行者123 更新时间:2023-11-30 05:42:33 33 4
gpt4 key购买 nike

我是 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 中有一个“正确”的方法。
我想了解如何正确执行此操作,更具体地说,如何更正此示例中的代码以按“Angular 方式”工作。

谢谢!

更新 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>

还是不行。输出中没有任何显示..

最佳答案

AngularJs 在所有常规路由的 url 中使用哈希,这是导航页面的默认方式。您可以使用 routeProvider 来定义 url-schemas,就像您在 Django 等后端 MVC 框架中所做的那样,routeProvider 将监听哈希中的变化并相应地加载新内容。

我建议做教程。它相当不错(即使它遗漏了很多东西)。路线在step 7中展示.

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

关于javascript - 我怎样才能对 AngularJs 中的 hashchange 事件采取行动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19923579/

33 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com