【AngularJS学习笔记】封装一些简单的控件(封装成Html标签)

bootstrap有强大的指令系统,可以自定义一些属性,基本知识请移步:http://angularjs.cn/A00r  http://www.cnblogs.com/lvdabao/p/3391634.html

我参考这两篇文章所述,封装了bootstrap的alert和panel控件,现将代码简单的贴出来。

注:目前我对ng了解非常浅,没有关注细节,实现功能第一位,我觉得比较合适的学习路线是,先用起来,在用的过程中不断深入。

第一步:注册module

angular.module('app.directives', [])

第二步:定义指令

1.alert的封装,这个是最简单的了,只是div上面多了两个class而已

angular.module('app.directives', [])
    .directive('successtip', function () {
        return {
            restrict: 'E',
            template: '<div class="alert alert-success" role="alert" ng-transclude></div>',
            replace: true,
            transclude: true
        }

    })

2.panel的封装,特点:多层标签嵌套

特别注意的点是:ng-transclude,这个写到哪里,完了之后,你的标签中的内容就会填充在那个节点下面,比如panelheader的定义,用户将来使用时

<panelheader>content</panelheader>,这里的content会填充到h3下面,而不是div下面.

.directive('panel', function () {
        return {
            restrict: 'E',
            template: '<div class="panel panel-danger" ng-transclude></div>',
            replace: true,
            transclude: true
        }
    })
    .directive('panelheader', function () {
        return {
            restrict: 'E',
            template: '<div class="panel-heading"><h3 class="panel-title" ng-transclude></h3></div>',
            replace: true,
            transclude: true
        }
    })
    .directive('panelbody', function () {
        return {
            restrict: 'E',
            template: ' <div class="panel-body" ng-transclude></div>',
            replace: true,
            transclude: true
        }
    });

如果你的模板比较复杂,不适合用一个string来写,那你可以用html模板来放置,只是在directive方法中,你就不能写template了,而是要写templateurl,路径是你定义的html模板的路径。

第三步:使用

这个时候,使用起来就不需要记那些繁琐的css和div的层级结构了,只需要记住标签的层级结构就好,这样子我个人的感觉是有点面向对象编程的意思了,比较容易理解和记忆。

1.alert的使用

<successtip>登录成功</successtip>

显示效果:

2.panel的使用

 <panel>
     <panelheader> panel healer</panelheader>
      <panelbody>panel Body</panelbody>
 </panel>

显示效果:

对于一些复杂的控件,这个封装就会大大减少开发工作量,我这个目前还是有问题的,我现在是每个颜色都需要封装一次,我觉得是会有办法在上面加个属性能让他们显示为不同颜色的。待续...

原文地址:https://www.cnblogs.com/baiyunchen/p/5078390.html