javascript - Angularjs 指令幻灯片显示和隐藏内容

标签 javascript angularjs angularjs-directive ng-show ng-hide

我用过Slide up/down effect with ng-show and ng-animate作为我的问题的基础。然而,该指令只允许隐藏/显示一个元素。当有2个时,仅显示第一个:

这是一个骗子:http://plnkr.co/edit/YtPgcUcnapiQfAR5hxiE?p=preview

如果您点击链接 2,它将显示第一个内容。

angular.module('app', [])
.directive('sliderToggle', function() {
    return {
        restrict: 'AE',
        link: function(scope, element, attrs) {
            var target = element.parent()[0].querySelector('[slider]');
            attrs.expanded = false;
            element.bind('click', function() {
                var content = target.querySelector('.slideable_content');
                if(!attrs.expanded) {
                    content.style.border = '1px solid rgba(0,0,0,0)';
                    var y = content.clientHeight;
                    content.style.border = 0;
                    target.style.height = y + 'px';
                } else {
                    target.style.height = '0px';
                }
                attrs.expanded = !attrs.expanded;
            });
        }
    }
})
.directive('slider', function () {
    return {
        restrict:'A',
        compile: function (element, attr) {
            // wrap tag
            var contents = element.html();
            element.html('<div class="slideable_content" style="margin:0 !important; padding:0 !important" >' + contents + '</div>');

            return function postLink(scope, element, attrs) {
                // default properties
                attrs.duration = (!attrs.duration) ? '1s' : attrs.duration;
                attrs.easing = (!attrs.easing) ? 'ease-in-out' : attrs.easing;
                element.css({
                    'overflow': 'hidden',
                    'height': '0px',
                    'transitionProperty': 'height',
                    'transitionDuration': attrs.duration,
                    'transitionTimingFunction': attrs.easing
                });
            };
        }
    };
});

最佳答案

该缺陷发生在这里:var target = element.parent()[0].querySelector('[slider]'); 。本声明element.parent()[0]将返回当前元素的父元素,该元素始终为 <article> .

进一步:我假设 element.parent()[0].querySelector('[slider]')将选择article的第一个 child 根据“querySelector”的文档:

Returns the first element within the document (using depth-first pre-order traversal of the document's nodes) that matches the specified group of selectors

您应该使用var target = element.next()[0];如果您想选择按钮后面的 slider 。 或var target = element.next('[slider]')[0];如果不是紧接着;

这是一个plunker

希望这有帮助!

关于javascript - Angularjs 指令幻灯片显示和隐藏内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29008231/

相关文章:

javascript - 如何保存按钮

javascript - AngularJS 中 Controller 组件是如何实例化的?

javascript - 如何在 Rails 4 的 javascript 中包含 ruby​​ 变量?

javascript - 将图像复制粘贴到 JavaScript 富文本编辑器中

javascript - 无法在组件内部使用 [routerLink]

angularjs - Angular - 带有 controllerAs、bindToController 和 $scope.$watch 的指令

javascript - angular.js 显示模糊后的解析值

angularjs-directive - AngularJS 通过按钮切换 div 可见性

javascript - 如何创建 JSONP 回调?

javascript - 使用共享 Controller 来处理常见的 html 行为