博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
AngularJS 中的友好 URL —— 移除URL 中的 # 【已翻译100%】
阅读量:6007 次
发布时间:2019-06-20

本文共 1372 字,大约阅读时间需要 4 分钟。

AngularJS 默认将会使用一个 # 号来对URL进行路由.

例如:

要获得干净的URL并将井号从URL中移除是很容易的.

完成两件事情就行了.

1.配置 $locationProvider

2.设置我们的相对连接的起点路径

$location 服务

在Angular中, $location服务会解析地址栏中的URL,并对你的应用程序作出改变,反之亦然.

我强烈推荐通读官方的 Angular $location 文档 以对$location 服务及其所提供的特性有一个了解.

$locationProvider 和 html5 模式(html5Mode)

我们会使用 $locationProvider 模块,并将html5Mode设置为true.

我们会在你定义Angular应用程序并配置你的路由时做这些.

**angular.module('scotchy', [])

.config(function($routeProvider, $locationProvider) {    $routeProvider        .when('/', {            templateUrl : 'partials/home.html',            controller : mainController        })        .when('/about', {            templateUrl : 'partials/about.html',            controller : mainController        })        .when('/contact', {            templateUrl : 'partials/contact.html',            controller : mainController        });    // use the HTML5 History API    $locationProvider.html5Mode(true);});**

什么是 HTML5 History API? 它是使用一个脚本来操作浏览器历史的标准方法. 有了它就能在不刷新页面的前提下让 Angular 改变路由和页面的URL. 更多的信息,这里有一篇蛮好的 HTML5 History API 文章.

为相对链接设置

为了在应用程序各处使用相对链接,你将需要在你文档的

里面设置一个.
    

有大量的方法可以用来配置这个东西,而将HTML5Mode设置为true就会自动的解析相对链接了. 在我这儿这种方式总是能起效. 如果你应用程序的根同url相比有所不同,例如 /my-base, 那就用那个作为你的起点路径.

老浏览器的回调

$location服务对不支持HTML5浏览历史API的浏览器将自动回调hashbang方法。

一切的发生对你是透明的,你不需为此做任何配置。从Angular $location文档中,你可以看到回调的方法已经它是如何工作的。

image

总结

这是一个在Angular应用中获得漂亮URL并删除哈希标记的简单方法。享受超洁净、超快速的Angular应用吧!

转载地址:http://mcvmx.baihongyu.com/

你可能感兴趣的文章
聪明人不做的十件事
查看>>
Python操作memecache
查看>>
PHP文件缓存与memcached缓存 相比 优缺点是什么呢【总结】
查看>>
Oracle 创建表空间
查看>>
JAVA下实现二叉树的先序、中序、后序、层序遍历(递归和循环)
查看>>
采集技术网址
查看>>
Spring JDBC 例子
查看>>
网上下载的 chm 文件打开后右侧内容显示空白
查看>>
MySQL——SQL Mode详解
查看>>
淡入淡出特效
查看>>
ThinkPHP CURD操作
查看>>
Duilib自定义控件响应指定命令(转载)
查看>>
Zabbix 监控 Nginx(四)
查看>>
drop user ora-604 ora-54
查看>>
ABAP WB01 BDC ”No batch input data for screen & &“ ”没有屏幕 & & 的批输入数据“
查看>>
JavaScript闭包的应用案例——让Onclick事件都能正确的弹出相应的参数
查看>>
边界测试——让BUG现形
查看>>
16个Javascript的Web UI库、框架及工具包
查看>>
[学习链接]infoQ与腾讯大讲堂
查看>>
吃知了有什么好处
查看>>