移除AngularJS下URL中的#字符的方法


Posted in Javascript onJune 19, 2015

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

例如:

    http://example.com/

    http://example.com/#/about

    http://example.com/#/contact

要获得干净的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 文章.

为相对链接设置<base>

为了在应用程序各处使用相对链接,你将需要在你文档的<head>里面设置一个<set>.
 

<!doctype html>
<html>
<head>
 <meta charset="utf-8">
 
 <base href="/">
</head>

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

老浏览器的回调

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

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

移除AngularJS下URL中的#字符的方法
总结

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

Javascript 相关文章推荐
JavaScript 函数调用规则
Sep 14 Javascript
Jquery之美中不足小结
Feb 16 Javascript
使用js写的一个简易的投票
Nov 27 Javascript
基于JS实现的倒计时程序实例
Jul 24 Javascript
异步JavaScript编程中的Promise使用方法
Jul 28 Javascript
Bootstrap 过渡效果Transition 模态框(Modal)
Mar 17 Javascript
从源码看angular/material2 中 dialog模块的实现方法
Oct 18 Javascript
使用Bootstrap和Vue实现用户信息的编辑删除功能
Oct 25 Javascript
JS排序算法之冒泡排序,选择排序与插入排序实例分析
Dec 13 Javascript
Next.js实现react服务器端渲染的方法示例
Jan 06 Javascript
javascript json对象小技巧之键名作为变量用法分析
Nov 11 Javascript
最全vue的vue-amap使用高德地图插件画多边形范围的示例代码
Jul 17 Javascript
使用AngularJS创建单页应用的编程指引
Jun 19 #Javascript
使用AngularJS实现可伸缩的页面切换的方法
Jun 19 #Javascript
使用AngularJS实现表单向导的方法
Jun 19 #Javascript
举例详解AngularJS中ngShow和ngHide的使用方法
Jun 19 #Javascript
使用AngularJS和PHP的Laravel实现单页评论的方法
Jun 19 #Javascript
测试IE浏览器对JavaScript的AngularJS的兼容性
Jun 19 #Javascript
使用ngView配合AngularJS应用实现动画效果的方法
Jun 19 #Javascript
You might like
PHP.MVC的模板标签系统(三)
2006/09/05 PHP
php与php MySQL 之间的关系
2009/07/17 PHP
基于php常用正则表达式的整理汇总
2013/06/08 PHP
ThinkPHP独立分组使用的注意事项
2014/11/25 PHP
PHP实现的迪科斯彻(Dijkstra)最短路径算法实例
2017/09/16 PHP
让innerHTML的脚本也可以运行起来
2006/07/01 Javascript
JQuery AJAX实现目录浏览与编辑的代码
2008/10/21 Javascript
javascript 对象比较实现代码
2009/04/27 Javascript
点击隐藏页面左栏或右栏实现js代码
2013/04/01 Javascript
如何阻止复制剪切和粘贴事件为了表单内容的安全
2013/05/23 Javascript
解决jquery实现的radio重新选中的问题
2015/07/03 Javascript
jquery mobile 移动web(5)
2015/12/20 Javascript
jQuery中弹出iframe内嵌页面元素到父页面并全屏化的实例代码
2016/12/27 Javascript
使用DeviceOne实现微信小程序功能
2016/12/29 Javascript
JS实现线性表的链式表示方法示例【经典数据结构】
2017/04/11 Javascript
详解weex默认webpack.config.js改造
2018/01/08 Javascript
浅谈react受控组件与非受控组件(小结)
2018/02/09 Javascript
微信小程序搜索功能(附:小程序前端+PHP后端)
2019/02/28 Javascript
浅谈vue 二级路由嵌套和二级路由高亮问题
2020/08/06 Javascript
JavaScript使用setTimeout实现倒计时效果
2021/02/19 Javascript
[01:01:23]完美世界DOTA2联赛PWL S2 Forest vs FTD.C 第一场 11.26
2020/11/30 DOTA
python3处理含有中文的url方法
2018/05/10 Python
django 链接多个数据库 并使用原生sql实现
2020/03/28 Python
Python使用pdb调试代码的技巧
2020/05/03 Python
python requests.get带header
2020/05/05 Python
Python QT组件库qtwidgets的使用
2020/11/02 Python
送给他或她的礼物:FUN.com
2018/08/17 全球购物
写出SQL四条最基本的数据操作语句(DML)
2012/12/12 面试题
商务助理岗位职责
2013/11/13 职场文书
优秀民警事迹材料
2014/01/29 职场文书
《值日生》教学反思
2014/02/17 职场文书
小学生安全演讲稿
2014/04/25 职场文书
党委班子剖析材料
2014/08/21 职场文书
追悼会答谢词范文
2015/09/29 职场文书
大学三好学生主要事迹范文
2015/11/03 职场文书
排查MySQL生产环境索引没有效果
2022/04/11 MySQL