移除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 相关文章推荐
js 禁止选择功能实现代码(兼容IE/Firefox)
Apr 23 Javascript
一个分享按钮的插件使用介绍(可扩展,内附开发制作流程)
Sep 19 Javascript
jQuery获取当前对象标签名称的方法
Feb 07 Javascript
使用jquery实现IE下按backspace相当于返回操作
Mar 18 Javascript
javascript常用函数(2)
Nov 05 Javascript
javascript定义类和类的实现实例详解
Dec 01 Javascript
Vue+webpack项目基础配置教程
Feb 12 Javascript
vue2.0项目实现路由跳转的方法详解
Jun 21 Javascript
vue实现文件上传读取及下载功能
Nov 17 Javascript
JS常用排序方法实例代码解析
Mar 03 Javascript
JavaScript实现旋转木马轮播图
Mar 16 Javascript
使用vue判断当前环境是安卓还是IOS
Apr 12 Vue.js
使用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
在apache下限制每个虚拟主机的并发数!!!!
2006/10/09 PHP
php实现的在线人员函数库
2008/04/09 PHP
PHP 面向对象程序设计(oop)学习笔记 (四) - 异常处理类Exception
2014/06/12 PHP
php简单获取复选框值的方法
2016/05/11 PHP
php运行报错Call to undefined function curl_init()的最新解决方法
2016/11/20 PHP
PHP mysqli事务操作常用方法分析
2017/07/22 PHP
JavaScript进阶教程(第四课第一部分)
2007/04/05 Javascript
js常用代码段收集
2011/10/28 Javascript
js字符串转换成数字与数字转换成字符串的实现方法
2014/01/08 Javascript
ECMAScript6的新特性箭头函数(Arrow Function)详细介绍
2014/06/07 Javascript
js阻止浏览器默认行为的简单实例
2016/05/15 Javascript
动态的9*9乘法表效果的实现代码
2016/05/16 Javascript
EditPlus中的正则表达式 实战(2)
2016/12/15 Javascript
vue.js数据绑定的方法(单向、双向和一次性绑定)
2017/07/13 Javascript
ECMAscript 变量作用域总结概括
2017/08/18 Javascript
使用Vue开发一个实时性时间转换指令
2018/01/17 Javascript
JS实现的汉字与Unicode码相互转化功能分析
2018/05/25 Javascript
vue发送websocket请求和http post请求的实例代码
2019/07/11 Javascript
JavaScript回调函数callback用法解析
2020/01/14 Javascript
vue 插槽简介及使用示例
2020/11/19 Vue.js
pycharm中使用anaconda部署python环境的方法步骤
2018/12/19 Python
HTML5 Canvas实现烟花绽放特效
2016/03/02 HTML / CSS
在C#中如何实现多态
2014/07/02 面试题
光电信息专业应届生求职信
2013/10/07 职场文书
社区庆八一活动方案
2014/02/02 职场文书
幼儿教师培训感言
2014/03/08 职场文书
农村党支部书记党群众路线四风问题整改措施
2014/09/26 职场文书
车间主任岗位职责
2015/02/03 职场文书
信仰纪录片观后感
2015/06/08 职场文书
公务员处分决定书
2015/06/25 职场文书
2015年大学迎新晚会总结
2015/07/16 职场文书
医院感染管理制度
2015/08/05 职场文书
2016机关干部作风建设心得体会
2016/01/21 职场文书
Python Socket编程详解
2021/04/25 Python
python之json文件转xml文件案例讲解
2021/08/07 Python
动视暴雪取消疫苗禁令 让所有员工返回线下工作
2022/04/03 其他游戏