Angular路由ui-router配置详解


Posted in Javascript onAugust 01, 2018

简介

angularJs自身提供路由ng-router,但是ng-router不是很好用,配置项零散,好比Vue提供的组件传值一样,虽然提供给你了用法,但是开发过程中逻辑一多用着萌萌的,所以我们抛开ng-router来看ui-router。

引入ui-router

我们可以去bootCDN搜索ui-router,本地创建js文件,将代码copy进去使用,这样就可以打入本地使用了,但是要注意的是,Angular的main.js一定要在ui-router之前引用,注意一下先后顺序问题。

例如:

<script src="angular.main.js"></script>
<script src="angular-ui-router.js"></script>

配置ui-router

//angular.module("moduleName",dep); 定义模块依赖(两个参数)
  //angular.module("moduleName"); 获取模块 (一个参数)
  var app = angular.module("myApp",["ui-router"]);
  app.config(["$stateProvider","$urlRouterProvider",function($stateProvider){
      //app.config配置项
      //$stateProvider 状态供应商,(名字可以看出关于路由的一系列配置需要由$stateProvider完成)
      //$urlRouterProvider 路由重定向
      $stateProvider.state("home",{
        url: "/home"
        template: "<h1>首页</h1>"
      }) .state("about",{
          url: "/about"
          template: "关于我们"
      });
      $urlRouterProvider.otherwise("home")
  }])

页面配置

<div ui-view></div>  //相当于Vue中的插槽,单页面应用切换路由用来显示当前路由界面
<a ui-sref="home">首页</a> //Angular默认会转换为href
<a ui-sref="about">关于我们</a> //Angular默认会转换为href

路由激活状态样式

ui-sref-active="active"

完整代码

<html ng-app="myApp">
<head>
<style>
.active{
color: red
}
</style>
<script src="angular.main.js"></script>
<script src="angular-ui-router.js"></script>
</head>
<body>
<div ui-view></div>
<footer>
<a ui-sref="home" ui-sref-active="active">首页</a>
<a ui-sref="about" ui-sref-active="active">关于</a>
<a ui-sref="items">商品</a>
</footer>
</body>
<script>
var app = angular.module("myApp", [ui-router]);            app.config(["$stateProvider","$urlRouterProvider",function($stateProvider){
$stateProvider.state("home",{
url: "/home"
template: "首页"
}) .state("about",{
url: "/about"
template: "关于我们"
}).state("items",{//牛逼的潜逃路由
url: "/items",
templateUrl: "./items.html",
controller:["$scope",$state,function($scope,$state){
$scope.jump = function(){
$state.go("home");
}
$scope.jumpOther = function() {
$state.go("items.phone",{
id: "phone"
});
}
}]
}).state("items.comp",{
url: "/comp",
template: "<h1>电脑商品</h1>"
}).state("item.phone",{
url:"phone/:id",
template:"<h1>手机商品</h1>",
controller:["$scope","$stateParams",function($scope,$stateParams){
console.log($stateParams);
}]
});
$urlRouterProvider.otherwise("home")
}
</script>
</html>

嵌套路由页面

<div>
          <h1>商品展示</h1>
          <button ng-click="jump()">点击跳转首页</button>
          <a ui-sref="about">跳转至关于我们</a>
          <button ng-click="jumpOther()">穿参数</button>
          <a ui-sref="items.other({id:"sref"})"></a>
          <ul>
              //因为我们外面父级路由是items所以自路由用items为前缀
            <li><a ui-sref="items.comp">电脑</a></li>
            <li><a ui-sref="items.phone">手机</a></li>
          </ul>
          <div ui-view></div>
      </div>

总结

以上所述是小编给大家介绍的Angular路由ui-router配置详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
js实现获取焦点后光标在字符串后
Sep 17 Javascript
js调试工具Console命令详解
Oct 21 Javascript
javascript批量修改文件编码格式的方法
Jan 27 Javascript
简介JavaScript中toTimeString()方法的使用
Jun 12 Javascript
gameboy网页闯关游戏(riddle webgame)--仿微信聊天的前端页面设计和难点
Feb 21 Javascript
JS组件系列之Bootstrap table表格组件神器【终结篇】
May 10 Javascript
angularJS之$http:与服务器交互示例
Mar 17 Javascript
jQuery实现table中两列CheckBox只能选中一个的示例
Sep 22 jQuery
详解关于webpack多入口热加载很慢的原因
Apr 24 Javascript
Postman动态获取返回值过程详解
Jun 30 Javascript
解决vue的router组件component在import时不能使用变量问题
Jul 26 Javascript
解决vue watch数据的方法被调用了两次的问题
Nov 07 Javascript
javascript数据结构之多叉树经典操作示例【创建、添加、遍历、移除等】
Aug 01 #Javascript
JavaScript事件冒泡与事件捕获实例分析
Aug 01 #Javascript
JS+HTML实现的圆形可点击区域示例【3种方法】
Aug 01 #Javascript
create-react-app 修改为多入口编译的方法
Aug 01 #Javascript
Vue项目全局配置页面缓存之按需读取缓存的实现详解
Aug 01 #Javascript
JavaScript执行环境及作用域链实例分析
Aug 01 #Javascript
Vue.js 利用v-for中的index值实现隔行变色
Aug 01 #Javascript
You might like
PHP实现下载功能的代码
2012/09/29 PHP
利用php + Laravel如何实现部署自动化详解
2017/10/11 PHP
php微信开发之图片回复功能
2018/06/14 PHP
Yii框架布局文件的动态切换操作示例
2019/11/11 PHP
初探jquery——表单应用范例
2007/02/20 Javascript
Angularjs全局变量被作用域监听的正确姿势
2016/02/06 Javascript
js获取元素的外链样式的简单实现方法
2016/06/06 Javascript
JavaScript实现阿拉伯数字和中文数字互相转换
2016/06/12 Javascript
利用jquery实现下拉框的禁用与启用
2016/12/07 Javascript
JQuery统计input和textarea文字输入数量(代码分享)
2016/12/29 Javascript
js实现消息滚动效果
2017/01/18 Javascript
基于JavaScript实现简单的音频播放功能
2018/01/07 Javascript
Vue.js组件高级特性实例详解
2018/12/24 Javascript
原生javascript如何实现共享onload事件
2020/07/03 Javascript
Vue中引入svg图标的两种方式
2021/01/14 Vue.js
[40:48]DOTA2上海特级锦标赛D组败者赛 Liquid VS COL第二局
2016/02/28 DOTA
python抓取并保存html页面时乱码问题的解决方法
2016/07/01 Python
python设计tcp数据包协议类的例子
2019/07/23 Python
解决pycharm中导入自己写的.py函数出错问题
2020/02/12 Python
django模型类中,null=True,blank=True用法说明
2020/07/09 Python
python实现跨年表白神器--你值得拥有
2021/01/04 Python
荷兰时尚精品店:Labels Fashion
2020/03/22 全球购物
德国消费电子产品购物网站:Guter Kauf
2020/09/15 全球购物
什么是makefile? 如何编写makefile?
2012/08/08 面试题
企划经理的岗位职责
2013/11/17 职场文书
销售工作岗位职责
2013/12/24 职场文书
个人职业生涯规划书1500字
2013/12/31 职场文书
关于工资低的辞职信
2014/01/14 职场文书
科技工作者先进事迹
2014/08/16 职场文书
2014年保育员工作总结
2014/12/02 职场文书
2015年生产车间工作总结
2015/04/22 职场文书
少年派的奇幻漂流观后感
2015/06/08 职场文书
2015年教学副校长工作总结
2015/07/22 职场文书
坚持不是死撑,更重要的是心态
2019/08/19 职场文书
python爬虫之selenium库的安装及使用教程
2021/05/23 Python
python之json文件转xml文件案例讲解
2021/08/07 Python