zoukankan      html  css  js  c++  java
  • [AngularJS] ui-router: named views

    The ui-router library for AngularJS provides the ability to name views within your application. This is useful for dividing up your application into sections, and changing the content of a section based on the current state.

    We use named view to build a simple webpage with 'header','sidebar','content' and 'footer'.

    /**
     * Created by Answer1215 on 12/17/2014.
     */
    angular.module('app', ['ui.router'])
        .config(function($stateProvider, $urlRouterProvider) {
            $stateProvider
                .state('app', {
                    url: '/',
                    views: {
                        'header': {
                            templateUrl: 'app/common/header.tpl.html'
                        },
                        'sidebar': {
                            templateUrl: 'app/common/sidebar.tpl.html'
                        },
                        'content': {
                            templateUrl: 'app/common/content.tpl.html'
                        },
                        'footer': {
                            templateUrl: 'app/common/footer.tpl.html'
                        }
                    }
                });
            $urlRouterProvider.otherwise('/');
        });
    <div class="container">
    
        <!-- Header -->
        <div ui-view="header" class="row"></div>
    
        <div class="row">
            <!-- Sidebar/Nav -->
            <div ui-view="sidebar" class="col-xs-3"></div>
            <!-- Content -->
            <div ui-view="content" class="col-xs-9"></div>
        </div>
    
        <!-- Footer -->
        <div ui-view="footer" class="row"></div>
    </div>

    Result: 

    Now when we click 'One', 'Two' and 'Three', we also want to replace the content accordingly.

    alt-one.js:

    /**
     * Created by Answer1215 on 12/17/2014.
     */
    angular.module('app.alt-one', ['ui.router'])
        .config(function($stateProvider, $urlRouterProvider) {
            $stateProvider
                .state('app.alt-one', {
                    url: 'alt-one',
                    views: {
                        // '@': replace the content
                        // if there is just @ without other stuff, it will looking for the parent 'app' root
                        'content@': {
                            templateUrl: 'app/alt-one/alt-one.content.tpl.html'
                        }
                    }
                })
        })    

    alt-two.js: we replace the content and header both at the same time.

    /**
     * Created by Answer1215 on 12/17/2014.
     */
    angular.module('app.alt-two', ['ui.router'])
        .config(function($stateProvider, $urlRouterProvider) {
                    $stateProvider
                        .state('app.alt-two', {
                            url: 'alt-two',
                            views: {
                                'content@': {
                                    templateUrl: 'app/alt-two/alt-two.content.tpl.html'
                                },
                                'header@': {
                                    templateUrl: 'app/alt-two/alt-two.header.tpl.html'
                                }
                            }
                        })
                })

    alt-three.js:

    /**
     * Created by Answer1215 on 12/17/2014.
     */
    angular.module('app.alt-three', [
        'ui.router'
    ])
        .config(function($stateProvider) {
            $stateProvider
                .state('app.alt-three', {
                    url: 'alt-three',
                    views: {
                        'content@': {
                            templateUrl: 'app/alt-three/alt-three.content.tpl.html'
                        },
                        'header@': {
                            templateUrl: 'app/alt-three/alt-three.header.tpl.html'
                        },
                        // find the 'alt-three' directory to replace the name view == "one"
                        'one@app.alt-three': {
                            template: '<div class="alert-info">Sub One</div>'
                        },
                        // find the 'alt-three' directory to replace the name view == "two"
                        'two@app.alt-three': {
                            template: '<div class="alert-success">Sub Two</div>'
                        }
                    }
                }
            )
        })
    ;

    Read More: https://egghead.io/lessons/angularjs-ui-router-named-views

  • 相关阅读:
    java反射小练习
    Set与list测试
    关于用户界面
    自定义标签打包使用问题
    jsp中获取当前访问路径
    LeetCode 汇总
    LeetCode 46. 全排列
    LeetCode 40.组合总和II
    LeetCode 39.组合总和
    LeetCode 37.解数独
  • 原文地址:https://www.cnblogs.com/Answer1215/p/4169843.html
Copyright © 2011-2022 走看看