Angularjs中的标签模式和html5模式-创新互联

浏览$location的实例代码我们不难发现,每次的url中都会带一个#,这是因为angularjs默认使用的是标签模式,它和html5模式有什么区别?

创新互联建站坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都网站设计、成都做网站、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的南涧网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!

(1)标签模式

 标签模式使用的是内部链接的技巧,URL后面紧跟一个#,angularjs本身不会重写<a>标签,也不需要服务器端的支持,链接后的URL样子基本是这样的:

http://example.com/#/some/path?foo=bar&baz=xoxo

(2)HTML5模式

标签模式的url看起来总是觉得不爽,html5模式可能比较适合咱们的请求格式(比如说REST),

http://example.com/some/path?foo=bar&baz=xoxo

在angularjs内部,可以通过$locationProvider.Html5Mode()(内部用的是html5 history api,如果浏览器不支持将自动降级到标签模式)方法来实现这样的路由要求,在该模式下,angularjs会重写<a>标签。使用该模式时,永远都不要使用相对路径,如果你的应用是在根路径中加载的,这不会有什么问题,但如果是在其他路径中,AngularJS应用就无法正确处理路由了.

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

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

注:html5 history api

  1. history.pushState(data, title [, url]):往历史记录堆栈顶部添加一条记录;data会在onpopstate事件触发时作为参数传递过去;title为页面标题,当前所有浏览器都会忽略此参数;url为页面地址,可选,缺省为当前页地址。

  2. history.replaceState(data, title [, url]) :更改当前的历史记录,参数同上。

  3. history.state:用于存储以上方法的data数据,不同浏览器的读写权限不一样。

浏览器支持情况(完整的可以通过www.caniuse.com查询)

 IE 10+, FF38+,chrome 31+,safari 7.1+, opera 30+

为什么要用history api?

  1. 无法使用浏览器的前进、后退来切换前后数据。

  2. 当我们将浏览器地址栏中的链接与朋友分享时,可能实际上却并非我们期望的内容。

  3. 单纯地使用AJAX不利于搜索引擎优化。

参考链接:http://diveintohtml5.info/history.html

          http://www.clanfei.com/2012/09/1646.html

          https://docs.angularjs.org/api/ng/provider/$locationProvider

         https://scotch.io/quick-tips/pretty-urls-in-angularjs-removing-the-hashtag

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。

文章标题:Angularjs中的标签模式和html5模式-创新互联
标题路径:https://www.cdcxhl.com/article40/csjcho.html

成都网站建设公司_创新互联,为您提供定制开发动态网站面包屑导航网站维护App设计域名注册

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

外贸网站建设