在配置路由的时候,我们可以选择ng框架自带的路由,也可以使用第三方路由插件ui-router

注意:

(1)在使用angular-ui-router的时候,必须先引入angular-ui-router.js模块

(2)在自己的项目中注入“ui-router”

(3)给他一个ui-view="..."当作模板的容器

the problems of my project:

the question:  in my project, i want to use the common tags but the different part pages,

solution:将tags放在父级的ui-view="content" 中,在html 模板中再次写一个ui-view="part"

<div class="con-detail">
<div ui-view="content">
<div ng-show="nav_show">
<settingnav></settingnav>
<proadduser></proadduser>
</div>
</div>
</div>
<div class="ideas-list">
<div class="my-row">
<div class="amdin-nav" ><!--共用的tags-->
<ul class="list-inline adminAction-listHeader">
<li ui-sref="home.ideas.allIdeas" >
<a href="" ng-class="{active:eval=='allIdeas'}" class="my-btn-lg" >全部创意</a>
</li>
<li ui-sref="home.ideas.myIdeas" >
<a class="my-btn-lg" ng-class="{active:eval=='myIdeas'}" >我的创意</a>
</li>
<li ui-sref="home.ideas.appr_list" >
<a class="my-btn-lg" ng-class="{active:eval=='waitList'}">待审批</a>
</li>
<li ui-sref="home.ideas.approval" >
<a class="my-btn-lg" ng-class="{active:eval=='hasApproval'}" >已审批</a>
</li>
</ul>
</div>
<div class=" list-content" ui-view="part" >
        <!--用于子模板的放入-->
</div>
</div>
</div>
js:
define(['angular','ng-require','rap','ng-bootstrap','ui-router'], function (angular) {
var myapp = angular.module('myapp', ['ui.router', 'ui.bootstrap', 'ngRap','ngRequire']); /................................./
return myapp;
});
define(['app'], function (myapp) {
myapp.config(['$stateProvider', '$urlRouterProvider', '$locationProvider', '$requireProvider',
function ($stateProvider, $urlRouterProvider, $locationProvider, $requireProvider) {
$urlRouterProvider.otherwise('home.ideas'); //默认跳转
$stateProvider.state('home.ideas', {//创意列表(全部创意)
url: '/ideasList',
views: {
"content": {
templateUrl: 'tpls/ideas/list.html',
//controller:"ideas_list_ctrl"
controller:function($state){
$state.go("home.ideas.allIdeas");<!---进一步的跳转到全部创意--->
}
}
}
})
.state('home.ideas.allIdeas', {//全部创意(用于跳转的状态)
url: '/allIdeas', //浏览器的地址栏上面显示的
views: {
"part": {
templateUrl: 'tpls/ideas/all_idea_list.html',
controller:'ideas_list_ctrl'
}
}
}) .state('home.ideas.myIdeas', {//我的创意
url: '/myIdeas',
views: {
"part": {
templateUrl: 'tpls/ideas/myIdeas.html',
controller:'ideas_myIdeas_ctrl'
}
}
})
然后在每一个的控制器中配置:tags的状态(注意要在rootScope中配置状态,因为我没给出父级控制器(上面在配置content的时候))
 /............../
myapp.controller('ideas_list_ctrl',
['$scope','$rootScope','ideas_api','myalert', function (s,rs,ideas_api,myalert) { console.log("this is idea_list ctrl"); rs.eval="allIdeas"; /............./
myapp.controller('ideas_hasPass_ctrl',
['$scope','$rootScope','setting_api', 'ideas_api', function (s,rs,setting_api, ideas_api) {
      console.log("this is idea_hasApproval ctrl"); rs.eval='hasApproval';

  

												

关于ng的路由的几点想法(ui-view)的更多相关文章

  1. 走进AngularJs(八) ng的路由机制

    在谈路由机制前有必要先提一下现在比较流行的单页面应用,就是所谓的single page APP.为了实现无刷新的视图切换,我们通常会用ajax请求从后台取数据,然后套上HTML模板渲染在页面上,然而a ...

  2. webpack整合 vue-router 路由,模块嵌套,整合Mint UI,MUI

    webpack整合 vue-router 结构 各个文件内容,一共八个文件, 还有src components 目录 Login.vue <template> <div> &l ...

  3. 去除angularjs路由的显眼的#号

    在接触到angularj并完成第一个demo后,惊奇地发现居然还可以这样开发前端界面.个人喜欢的一个功能点就是ng的路由功能,可以很好地将视图放入多个文件中.但最基础的使用会给url添加一个显眼的#, ...

  4. 消息智能路由组件SmartRoute

    消息传递在软件开发过程中是一件很常见的事情,而在不同的场景所使用消息传递方式也有所不同,在对象之间制定相关接口方法和对象结构,对于进程之间可能使用内存共享或一些通讯产品,在不同服务器之的消息通讯则使用 ...

  5. Angular路由与多视图综合案例

    Ajax请求存在的几个问题 (1)Ajax请求不会留下History 记录,会导致浏览器后退按钮失效 (2)用户无法直接通过URL进入应用中的指定页面(保存书签.链接分享给朋友) (3)Ajax对SE ...

  6. django框架--路由系统

    目录 一.路由系统理解 二.路由系统功能划分 三.路由表创建 创建工具 二级路由 路由别名 动态路由及重定向 四.自定义错误页面 五.图示路由系统在框架中的定位 六.路由系统的进阶想法 一.路由系统理 ...

  7. [转]angular的路由机制

    在谈路由机制前有必要先提一下现在比较流行的单页面应用,就是所谓的single page APP.为了实现无刷新的视图切换,我们通常会用ajax请求从后台取数据,然后套上HTML模板渲染在页面上,然而a ...

  8. RouteReuseStrategy angular路由复用策略详解,深度刨析路由复用策略

    关于前端路由复用策略网上的文章很多,大多是讲如何实现tab标签切换历史数据,至于如何复用的原理讲的都比较朦胧,代码样例也很难适用各种各样的路由配置,比如懒加载模式下多级嵌套路由出口网上的大部分代码都会 ...

  9. MVC中路由

    篇目 介绍 路线的性质 了解缺省路由 用一个例子的路由 结论 介绍 本文介绍了MVC中的路由.如何执行的路线是由路由引擎和如何定义的URL路由. ASP.NET MVC的路由是一个模式匹配系统,负责传 ...

随机推荐

  1. 【android开发笔记】为Button的背景图片添加边框式样式效果

    现在做的项目遇到一个问题,设计给过来的图片只有一种状态,但是实现的需求是要求有两个状态,另一种选状态为图片背景加边框.如图: 刚开使用使用ImageView ,ImageViewButton 效果不是 ...

  2. 新手学js的效果图1---( 淘宝等商城货物查看特效)

    本人结合之前所学一起写了,多个特效,只是新手自己瞎鼓捣的,思路清晰,具体实现的货物放大镜等,替换当中的img地址就可以查看特效 <!DOCTYPE html> <html lang= ...

  3. 【CNMP系列】PHP配置和调优

    上一节我们说到PHP5.6.30在CentOS7.0下的整个安装过程,http://www.cnblogs.com/riverdubu/p/6428226.html 今天我来和大家讲解一下PHP-FP ...

  4. [数据挖掘] - 聚类算法:K-means算法理解及SparkCore实现

    聚类算法是机器学习中的一大重要算法,也是我们掌握机器学习的必须算法,下面对聚类算法中的K-means算法做一个简单的描述: 一.概述 K-means算法属于聚类算法中的直接聚类算法.给定一个对象(或记 ...

  5. Jquery基本用法

    今天下午讲了Jquery的基本用法:在用Jquery方法时,首先要引用Jquery文件: <script src="jquery-1.11.2.min.js">< ...

  6. 2761: [JLOI2011]不重复数字(哈希表)

    2761: [JLOI2011]不重复数字 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1770  Solved: 675[Submit][Stat ...

  7. 九度OJ题目1076:N的阶乘 (java)运用BigInteger的例子。

    题目描述: 输入一个正整数N,输出N的阶乘. 输入: 正整数N(0<=N<=1000) 输出: 输入可能包括多组数据,对于每一组输入数据,输出N的阶乘 样例输入: 4 5 15 样例输出: ...

  8. 会话控制之session和cookie(20161107)

    注:除了登录页面,每个页面,包括处理页面也要加,为了提高安全性 session尽量不用,因为很占内存 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML ...

  9. python 接口自动化测试(三)

    1.WriteIni.py import ConfigParser cf = ConfigParser.ConfigParser() cf.add_section("PC_WSDL" ...

  10. Pydev for eclipse 安装及配置

    1.安装JDK,eclipse 2.打开eclipse->help->install new software,点Add,名称输入:Pydev,更新链接为:http://pydev.org ...