AngularJs 的ng-include指令的使用

AngularJs经过指令ng-include来将页面中共用的模块分离出来,这个功能和mvc里面的分部页的做用同样的。javascript

先看文件的结构:html

父页面:java

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <title></title>
    <script src="https://cdn.staticfile.org/angular.js/1.7.5/angular.min.js"></script>
</head>
<body ng-app="myApp" ng-controller="ParentCtr">
    <div ng-include="'Childrens/Header.html'"></div>
    <input type="text" ng-model="test" />
    <p style="background-color:darkgoldenrod">这里演示在一个HTML页面中,经过引用子页面来完成整个页面功能</p>

    <div ng-include="'Childrens/Footer.html'"></div>
        <script type="text/javascript">
            var formapp = angular.module('myApp', []);
            formapp.controller('ParentCtr', function ($scope) {
                $scope.test = "hello";
                $scope.$on('to-parent', function (d, data) {
                    $scope.$broadcast('to-child', data);  
                });  
            })
                .controller("headerCtr", function ($scope) {
                    $scope.headerTitle = "头部";
                    $scope.btnheader = function () {
                        $scope.headerTitle = "点击了按钮";
                    }
                    $scope.btnheader1 = function () {   
                        $scope.$emit('to-parent', $scope.headerTitle);                                             
                    }
                })
                .controller("footerCtr", function ($scope) {
                    $scope.ft = "尾部";
                    $scope.list = ["abc", "efg", "xyz"];
                    $scope.$on('to-child', function (d, data) {
                        $scope.fromHeader= data;
                    });  
                });
        </script>
</body>

</html>

子页面Header.html: mvc

<div ng-controller="headerCtr">
    <h2>这是头部</h2>
    <input ng-model="headerTitle" />
    <input type="button" ng-click="btnheader()" value="点击我" />
    <input type="button" ng-click="btnheader1()" value="点击我,将文本框的内容显示到尾部" />
</div>

子页面Footer.html:app

<div ng-controller="footerCtr">
    <h2>这是尾部</h2>
    <p>{{ft}}</p>
    <p>{{fromHeader}}</p>
    <ul>
        <li ng-repeat="t in list">{{t}}</li>
    </ul>
</div>

运行效果:函数

 在不一样的控制器之间传值比较麻烦,同级的控制器之间不能相互传值,而是经过父级控制器来传值。具体步骤:spa

当点击头部的按钮的时候,经过 $scope.$emit('to-parent', $scope.headerTitle); 将要传递的数据传递到父级控制器,而后在父级控制器中,经过 $scope.$on('to-parent', function (d, data)来获取数据,而后在函数中调用  $scope.$broadcast('to-child', data);code

将数据传递到子控制器,最后在子控制器中用$scope.$on('to-child', function (d, data) 来接收传来的数据。orm

 若是想把js脚本单独放到js文件中,能够这样:但要注意的是,全部的js文件的引用都是在父级页面cdn

相关文章
相关标签/搜索