移除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面向对象之Javascript 继承
May 04 Javascript
读jQuery之十 事件模块概述
Jun 27 Javascript
namespace.js Javascript的命名空间库
Oct 11 Javascript
JS 打印界面的CSS居中代码适用所有浏览器
Mar 19 Javascript
使用原生js实现页面蒙灰(mask)效果示例代码
Jun 20 Javascript
bootstrapValidator bootstrap-select验证不可用的解决办法
Jan 11 Javascript
从零学习node.js之mysql数据库的操作(五)
Feb 24 Javascript
Node.js中.pfx后缀文件的处理方法
Mar 10 Javascript
教你快速搭建Node.Js服务器的方法教程
Mar 30 Javascript
vue-quill-editor富文本编辑器简单使用方法
Sep 21 Javascript
微信小程序自定义toast的实现代码
Nov 16 Javascript
js作用域及作用域链工作引擎
Jul 07 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
PHP4实际应用经验篇(5)
2006/10/09 PHP
实现了一个PHP5的getter/setter基类的代码
2007/02/25 PHP
php下HTTP Response中的Chunked编码实现方法
2008/11/19 PHP
php中rename函数用法分析
2014/11/15 PHP
php使用ZipArchive函数实现文件的压缩与解压缩
2015/10/27 PHP
Gambit vs ForZe BO3 第二场 2.13
2021/03/10 DOTA
jquery异步跨域访问代码
2013/06/28 Javascript
jQuery使用CSS()方法给指定元素同时设置多个样式
2015/03/26 Javascript
js中javascript:void(0) 真正含义
2020/11/05 Javascript
Bootstrap+jfinal退出系统弹出确认框的实现方法
2016/05/30 Javascript
jQuery实现发送验证码并60秒倒计时功能
2016/11/25 Javascript
AngularJS实现tab选项卡的方法详解
2017/07/05 Javascript
Nodejs模块载入运行原理
2018/02/23 NodeJs
js闭包学习心得总结
2018/04/17 Javascript
手把手教你用Node.js爬虫爬取网站数据的方法
2018/07/05 Javascript
Vue 应用中结合vux使用微信 jssdk的方法
2018/08/28 Javascript
javascript 构建模块化开发过程解析
2019/09/11 Javascript
python中的实例方法、静态方法、类方法、类变量和实例变量浅析
2014/04/26 Python
Win7上搭建Cocos2d-x 3.1.1开发环境
2014/07/03 Python
Python读取图片EXIF信息类库介绍和使用实例
2014/07/10 Python
python轻松实现代码编码格式转换
2015/03/26 Python
在Linux系统上通过uWSGI配置Nginx+Python环境的教程
2015/12/25 Python
Django中url的反向查询的方法
2018/03/14 Python
python爬虫 使用真实浏览器打开网页的两种方法总结
2018/04/21 Python
python selenium登录豆瓣网过程解析
2019/08/10 Python
python 双循环遍历list 变量判断代码
2020/05/04 Python
python:删除离群值操作(每一行为一类数据)
2020/06/08 Python
如何避免常见的6种HTML5错误用法
2017/11/06 HTML / CSS
法国大使拉杆箱官网:DELSEY Paris
2018/03/20 全球购物
伦敦剧院及景点门票:Encore Tickets
2018/07/01 全球购物
应届生自荐信
2014/06/30 职场文书
税务干部个人整改措施思想汇报
2014/10/10 职场文书
2015大学生求职信范文
2015/03/20 职场文书
2015年圣诞节寄语
2015/08/17 职场文书
redis通过6379端口无法连接服务器(redis-server.exe闪退)
2021/05/08 Redis
python处理json数据文件
2022/04/11 Python