AngularJS 路由和模板实例及路由地址简化方法(必看)
最近一同事在学习angularjs,在路由与模板的学习过程中遇到了一些问题,于是今天给她写了个例子,顺便分享出来给那些正在学习angularjs的小伙伴们。
话说这angularjs 开发项目非常的爽,其中爽就爽在它的开发模式,使得代码更加的清晰、更加具有可读性、更简洁、更具有维护性。但是在使用angularjs开发的过程中也有让我头疼的地方,那就是目前前端框架更多的还是以jquery为主,很多插件都是依赖于jquery的,angulajs的插件少之又少(除了angularui其他的angular插件我就不知道了,如果哪位大神指导的话可以跟我分享一下)。为了保证controller中代码清晰,不混乱,我们规定在controller中不允许操作dom,所以每次需要操作dom元素的是我们都是指令去完成,因此就存在了,需要将很多jquery插件转换成指令去操作,这是一件非常恶心的事情。好像扯远了,好吧~~
目录:
1.angularjs路由介绍
2.angularjs路由实例
3.angularjs采用html5模式的路由结合webserver重定向简化路由地址
1.angularjs路由介绍
angularjs路由与后端mvc的路由不一样。angularjs的前端路由,需要在模板页提前对指定的(ng-app),定义路由规则(routeprovider),然后通过不同的url,告诉(ng-app)加载哪个页面(html),再渲染到(ng-app)视图(ng-view)中。而mvc路由是通过不同的url请求,然后根据路由规则请求控制器的action,并返回view。angularjs是一个纯前端的路由。后面我们会结合配置文件简化路由地址。
2.angularjs路由实例
我们新建一个js文件,此处我命名为app.js,在文件中我们写入如下代码:
1 angular.module("app", [ 2 'ngroute' 3 ]) 4 .config(['$routeprovider', function ($routeprovider) { 5 $routeprovider.when("/list", { 6 template: "这是列表页" 7 }).when("/detail", { 8 template: "这是详情页" 9 })10 .otherwise({11 redirectto: "/list"12 })13 }])
我们新建一个html文件命名为index.html,代码及说明如下:
1 <!doctype html> 2 <html xmlns="http://www.w3.org/1999/xhtml" ng-app="app"> 3 <head> 4 <title></title> 5 </head> 6 <body> 7 <header> 8 <h2>这是头部</h2> 9 </header>10 <content>11 <div ng-view></div>12 </content>13 <footer>14 <h3>这是底部</h3>15 </footer>16 </body>17 </html>18 <script src="/scripts/angular/angular.min.js"></script>19 <script src="/scripts/angular-route/angular-route.min.js"></script>20 <script src="/scripts/app.js"></script>
运行实例,效果如下。
浏览器打开输入地址:http://localhost:2987/index.html#/detail和http://localhost:2987/index.html#/list分别可以看到如下图所示页面:
3.angularjs采用html5模式的路由结合webserver简化路由地址
上图中我们可以看到,请求地址很长,对于有强迫症的我来说,很难接受这种类型的地址,于是我决定作出这样的改变:
1)angulajs开启html5模式路由,去掉#号:
对于angulajs来说,其默认是没有打开html5路由模式,我们通过如下做法开启html5路由模式:
1 angular.module("app", [ 2 'ngroute' 3 ]) 4 .config(['$routeprovider', '$locationprovider', function ($routeprovider, $locationprovider) { 5 //开启html5路由模式 6 $locationprovider.html5mode(true) 7 $routeprovider.when("/list", { 8 template: "这是列表页" 9 }).when("/detail", {10 template: "这是详情页"11 })12 .otherwise({13 redirectto: "/404.html"14 })15 }])
这样按照上面的请求地址去掉#号后刷新页面,发现提示404找不到页面,原因是这样的地址请求到后台iis会找不到对应的文件,因此直接返回404错误页面。因此我们需要在配置文件中添加webserver配置,重定向文件如下:
1 <system.webserver> 2 <rewrite> 3 <rules> 4 <rule name="name" > 5 <match url="^list|detail*" ignorecase="true"/> 6 <conditions logicalgrouping="matchall"> 7 <add input="{request_filename}" matchtype="isfile" negate="true"/> 8 <add input="{request_filename}" matchtype="isdirectory" negate="true"/> 9 </conditions>10 <action type="rewrite" url="/index.html"/>11 </rule>12 </rules>13 </rewrite>14 </system.webserver>
如上面代码显示,其中<match url="^list|detail*" ignorecase="true"/> 的意思是,如果请求地址中包含list或detail(根据需求自己书写正则表达式),那么会被重定向到index.html页面,这样在页面上输入http://localhost:2987/detail的时候iis会先返回模板页(index.html),然后angulajs路由才开始执行。
在浏览器输入http://localhost:2987/detail回车,发现并没有得到我们想要的结果,也就是说,路由没有匹配上。
网上查了很久,终于找到解决方案,就是在html页面中添加<base>标签如下:
1 <!doctype html> 2 <html xmlns="http://www.w3.org/1999/xhtml" ng-app="app"> 3 <head> 4 <title></title> 5 <base href="/" /> 6 </head> 7 <body> 8 <header> 9 <h2>这是头部</h2>10 </header>11 <content>12 <div ng-view></div>13 </content>14 <footer>15 <h3>这是底部</h3>16 </footer>17 </body>18 </html>19 <script src="/scripts/angular/angular.min.js"></script>20 <script src="/scripts/angular-route/angular-route.min.js"></script>21 <script src="/scripts/app.js"></script>
这样,在浏览器上输入:http://localhost:2987/detail回车就会看到我们想要的结果,截图如下:
遗留问题:为什么添加<base href="/" />标签就能成功了呢?这个问题还要请教一下广大的博友们。
对于上述有内容,如有哪写得不对的,尽情吐槽!!!
以上就是小编为大家带来的angularjs 路由和模板实例及路由地址简化方法(必看)全部内容了,希望大家多多支持~