自己写的angularJs排序指令【原创】

  首先,给大家看看指令完成的效果。(请注意区分下面几张图片中,对象值的变化)

  在页面没点击之前:    

  在点击第一次之后:    

  再点击第二次之后:    

  好了,效果图已经看完了,如果大家有兴趣的话可以继续往下看,接下来要讲的是关于angularJs中filter内置好的order功能,如果熟悉这个功能的同学们可以跳过下面要讲的内容

    orderBy这个功能其实是内置的过滤器,他可以在html和js代码中使用

    html:{{ orderBy_expression | orderBy : expression : reverse}}

    js    :$filter(‘orderBy‘)(array, expression, reverse)

    在这里我们只看html标签的运用,可以看出来他需要传入三个值

      1.orderBy_expression :你需要排序的数组

      2.expression :你需要根据哪个条件排序

      3.reverse :正序还是倒序(boolean)

    看到这里可能有的同学就知道为什么我要创建效果图中的这样的{"orderPredicate":"price","orderReverse":false}对象了。

    由于这里不是详细讲过滤的所以想深入理解的话 登录官方的API吧 : http://docs.angularjs.cn/api/ng/filter/orderBy

  现在开始进入主要内容了,首先我们要讲的是指令,不废话先上代码在分析  

    js:

angular.module(‘MyApp‘,[])
        .controller(‘MyCtrl‘,function(){
            var vm = this;
            //排序条件的数组
            vm.orderList = [{
                "title" : "价格",
                "value" : "price"
            },{
                "title" : "数量",
                "value" : "count"
            }]
            //排序条件对象
            vm.orderInfo = {
                orderPredicate : "",//排序的值
                orderReverse : false//正反序
            }
        })
        .directive(‘orderList‘, function() {
        return {
            controller: function($scope, $element, $attrs, $transclude) {
                var lists = [];//排序条件的列表
                this.getOpened = function(selectedItem) {
                    //控制只能点击一个排序条件
                    angular.forEach(lists, function(item, key) {
                        if (selectedItem != item) {
                            item.showMe = false;
                        }
                    });
                }
                //提供方法,在item生成的时候,将值放入lists中
                this.addItem = function(item) {
                    lists.push(item);
                }
            },
            restrict: ‘AE‘,
            template: ‘<ul class="list-group" ng-transclude></ul>‘,
            replace: true,
            transclude: true,
            link: function($scope, iElm, iAttrs, controller) {}
        };
    })
    .directive(‘orderListItem‘, function() {
        return {
            scope: {
                orderVaule: ‘=‘,//即将排序数组中的排序条件
                orderReverse: ‘=‘,//排序条件的值
                orderPredicate: ‘=‘,//控制排序的正序或倒序
                iconUp: ‘@‘,//升序图标
                iconDown: ‘@‘,//降序图标
            },
            controller: function($scope, $element, $attrs, $transclude) {},
            require: ‘?^orderList‘,//‘^‘判断是否存在父容器oederList,‘?‘可以避免orderList不存在的时候不报错
            restrict: ‘AE‘,
            template: ‘<li class="list-group-item" ng-click="toogle(orderVaule)">‘ +
                ‘<span ng-transclude></span>‘ +
                ‘<i ng-show="showMe" class="glyphicon pull-right" ng-class="{true:\‘{{iconUp}}\‘,false:\‘{{iconDown}}\‘}[orderReverse]"></i>‘ +
                ‘</li>‘,
            transclude: true,
            link: function($scope, iElm, iAttrs, controller) {
                //item渲染刚开始所有的图标都不显示
                $scope.showMe = false;
                //讲渲染的item加入父容器的lists中
                controller.addItem($scope);
                //点击item事件
                $scope.toogle = function(value) {
                    //正反序切换
                    $scope.orderReverse = !$scope.orderReverse;
                    //将值赋予排序条件
                    $scope.orderPredicate = value;
                    //并显示图标
                    $scope.showMe = true;
                    //关闭其他item的图标
                    controller.getOpened($scope);
                }
            }
        };
    })

    html:

<body ng-controller="MyCtrl as vm">
    <order-list>
        <order-list-item ng-repeat="item in vm.orderList" icon-up="glyphicon-arrow-up" icon-down="glyphicon-arrow-down" order-vaule="item.value" order-reverse="vm.orderInfo.orderReverse" order-predicate="vm.orderInfo.orderPredicate">
            {{item.title}}
        </order-list-item>
    </order-list>
    {{vm.orderInfo}}
</body>

  可能有些同学疑惑 ng-controller="MyCtrl as vm" 这是什么意思,其实这是angularJs推荐的写法,为了避免与$scope的原型继承搞混。大家如果控制器没有继承关系,大可不用$scope!!!!毕竟全部都是$scope也不太美观

  大部分的讲解都在注释上了,如果有问题的可以在下方提问;另外这里的图标是不支持图片的,只支持图标,需要引入bootstrap.css和里面的图标功能。

时间: 2024-12-31 03:34:41

自己写的angularJs排序指令【原创】的相关文章

跟我学AngularJs:Directive指令用法解读(上)

林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka 本教程使用AngularJs版本:1.5.3 AngularJs GitHub: https://github.com/angular/angular.js/ AngularJs下载地址:https://angularjs.org/ 摘要: Directive(指令)笔者认为是AngularJ非常强大而有有用的功能之一.它就相当于为我们写了公共的自定义DOM元素或CLASS属性或ATTR属性

学习AngularJs:Directive指令用法(完整版)

这篇文章主要学习AngularJs:Directive指令用法,内容很全面,感兴趣的小伙伴们可以参考一下 本教程使用AngularJs版本:1.5.3 AngularJs GitHub: https://github.com/angular/angular.js/ AngularJs下载地址:https://angularjs.org/ 摘要:Directive(指令)笔者认为是AngularJ非常强大而有有用的功能之一.它就相当于为我们写了公共的自定义DOM元素或LASS属性或ATTR属性,并

AngularJS之指令

紧接上篇博客“初探AngularJS” 一.前言 在AngularJS中指令尤为重要且内容庞多,固单独提炼出来,梳理一番.如有错误,请不吝讲解. 好了,言归正传,让我们一起走进Angular指令的世界. 在上篇博客的前言部分提到,Angular的核心就是对HTML标签的增强.我们用到的诸如ng-app.ng-controller等等这些都是属于Angular指令,具体点,它们为Angular内置的指令. Angular不仅提供了内置指令,它还允许我们自定义指令,不然Angular就太low咯.

跟我学AngularJs:Directive指令用法解读(下)

此文接 跟我学AngularJs:Directive指令用法解读(上) 8.transclude 如果不想让指令内部的内容被模板替换,可以设置这个值为true.一般情况下需要和ngTransclude指令一起使用. 比如:template:"<div>hello every <div ng-transclude></div></div>",这时,指令内部的内容会嵌入到ng-transclude这个div中.也就是变成了<div>

angularJs之指令详解(一)

指令(Directives)是所有AngularJS应用最重要的部分.尽管AngularJS已经提供了非常丰富的指令,但还是经常需要创建应用特定的指令.这篇教程会为你讲述如何自定义指令,以及介绍如何在实际项目中使用.在这篇文章的最后(第二部分),我会指导你如何使用Angular指令来创建一个简单的记事本应用. 概述 一个指令用来引入新的HTML语法.指令是DOM元素上的标记,使元素拥有特定的行为.举例来说,静态的HTML不知道如何来创建和展现一个日期选择器控件.让HTML能识别这个语法,我们需要

写一个函数排序整个字符串数组

创建一个字符串数组,总共5个元素,每个元素最多保存30个字符, 写一个函数排序整个数组 #include<stdio.h> #include<string.h> #include<stdlib.h> int main() { int i,j; char tmp[30]; char arr[5][30]={"bbbb","aaaa","dddd","wwww","eeee"

angularjs自定义指令绑定策略---‘&’绑定

接着上一篇 理解了"="和"@"绑定之后再来理解"&"绑定,就很简单了,同理,用"桥梁"进行分析,但还是有一些例外的情况,要不然angularjs也不会单独设定一个绑定策略,看案例先: <!DOCTYPE html><html lang="en" ng-app="MyModule"><head>    <meta charset=&quo

AngularJS: 自定义指令与控制器数据交互

<!doctype html> <html> <head> <meta charset="utf-8"> <title>AngularJS自定义指令与控制器数据交互</title> <!-- <script src="http://cdn.bootcss.com/angular.js/1.3.15/angular.js"></script>--> <sc

Angularjs 事件指令 input 相关指令 和样式指令 DOM 操作指令详解

Angularjs 事件指令 input 相关指令 和样式指令DOM 操作指令详解学习要点:1. AngularJs 事件指令2. input 相关指令3. 样式指令4. DOM 操作指令5. ngBind/ngBindHtml/ngBindTemplate 重点6. ng-init ng-mode ng-model-options ng-controler 1. Angularjs 事件指令自己研究:ng-click/dbclickng-mousedown/upng-mouseenter/le