关于ng的路由的几点想法(ui-view)
在配置路由的时候,我们可以选择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)的更多相关文章
- 走进AngularJs(八) ng的路由机制
在谈路由机制前有必要先提一下现在比较流行的单页面应用,就是所谓的single page APP.为了实现无刷新的视图切换,我们通常会用ajax请求从后台取数据,然后套上HTML模板渲染在页面上,然而a ...
- webpack整合 vue-router 路由,模块嵌套,整合Mint UI,MUI
webpack整合 vue-router 结构 各个文件内容,一共八个文件, 还有src components 目录 Login.vue <template> <div> &l ...
- 去除angularjs路由的显眼的#号
在接触到angularj并完成第一个demo后,惊奇地发现居然还可以这样开发前端界面.个人喜欢的一个功能点就是ng的路由功能,可以很好地将视图放入多个文件中.但最基础的使用会给url添加一个显眼的#, ...
- 消息智能路由组件SmartRoute
消息传递在软件开发过程中是一件很常见的事情,而在不同的场景所使用消息传递方式也有所不同,在对象之间制定相关接口方法和对象结构,对于进程之间可能使用内存共享或一些通讯产品,在不同服务器之的消息通讯则使用 ...
- Angular路由与多视图综合案例
Ajax请求存在的几个问题 (1)Ajax请求不会留下History 记录,会导致浏览器后退按钮失效 (2)用户无法直接通过URL进入应用中的指定页面(保存书签.链接分享给朋友) (3)Ajax对SE ...
- django框架--路由系统
目录 一.路由系统理解 二.路由系统功能划分 三.路由表创建 创建工具 二级路由 路由别名 动态路由及重定向 四.自定义错误页面 五.图示路由系统在框架中的定位 六.路由系统的进阶想法 一.路由系统理 ...
- [转]angular的路由机制
在谈路由机制前有必要先提一下现在比较流行的单页面应用,就是所谓的single page APP.为了实现无刷新的视图切换,我们通常会用ajax请求从后台取数据,然后套上HTML模板渲染在页面上,然而a ...
- RouteReuseStrategy angular路由复用策略详解,深度刨析路由复用策略
关于前端路由复用策略网上的文章很多,大多是讲如何实现tab标签切换历史数据,至于如何复用的原理讲的都比较朦胧,代码样例也很难适用各种各样的路由配置,比如懒加载模式下多级嵌套路由出口网上的大部分代码都会 ...
- MVC中路由
篇目 介绍 路线的性质 了解缺省路由 用一个例子的路由 结论 介绍 本文介绍了MVC中的路由.如何执行的路线是由路由引擎和如何定义的URL路由. ASP.NET MVC的路由是一个模式匹配系统,负责传 ...
随机推荐
- Sublime Text 3 修改配色主题【侧边框之...】
Sublime Text3 是挺喜欢的一款编辑器,一周五天朝九晚六面对,而默认的侧边栏颜色总显得不尽人意.右侧的代码高亮[color_scheme:Monokai]挺喜欢的,心里就想着如何把侧边栏也给 ...
- 基于DDD的.NET开发框架ABP实例,多租户 (Sass)应用程序,采用.NET MVC, Angularjs, EntityFramework-介绍
介绍 基于ABPZERO的多租户 (Sass)应用程序,采用ASP.NET MVC, Angularjs-介绍 ASP.NET Boilerplate作为应用程序框架. ASP.NET MVC和ASP ...
- linux编译内核
ubuntu 14.04 编译内核出现unable to locate package ncurses-devel 问题的解决 首先,在make menuconfig的时候就会提示没有 nucrs ...
- API code
/*--------------------------------------------------- BLOKOUT2.C -- Mouse Button & Capture Demo ...
- ReactJS的开发日常
在用React框架开发的日子里,踩的坑真不少!今天就来说说这个关于组件的周期,说的可能不是很清楚,但是也给自己留下一个踩坑的纪念,如有不妥 还望大家指点一二 Warning: setState(... ...
- Animate自定义动画
在jQuery中出了基本的动画之外,还有用户 可以自定义的函数,Animate() 用于创建自定义动画的函数. apI上指出: 这个函数的关键在于指定动画形式及结果样式属性对象.这个对象中每个属性都表 ...
- struts2.5框架使用通配符指定方法(常见错误)
在学习struts框架时经常会使用到通配符调用方法,如下: <package name="shop" namespace="/" extends=&quo ...
- MySQL优化-一 、缓存优化
body { font-family: Helvetica, arial, sans-serif; font-size: 14px; line-height: 1.6; padding-top: 10 ...
- 黑苹果引导工具 Clover 配置详解及Clover Configurator使用
黑苹果引导工具 Clover 配置详解及Clover Configurator使用 2017-03-11 14:01:40 by SemiconductorKING 转自:@三个表哥 简介: 可 ...
- iOS下的界面布局利器-MyLayout布局框架
Swift:TangramKit: https://github.com/youngsoft/TangramKit OC:MyLayout: https://github.com/youngsof ...