崩溃过渡不适用于angular的UI Bootstrap

时间:2015-05-11 22:20:10

标签: angularjs css-transitions angular-ui-bootstrap

我正在尝试创建一个div,它会在单击按钮时显示/隐藏。 UI Bootstrap page显示了一个使用css转换的简单示例。

这是我的fiddle,我在那里复制他们的代码,几乎完全正确(略微改变以使html语法突出显示工作,以及在js中声明我的“app”的行)。

正如您所看到的,它在示例中不起作用 - 没有转换。为什么不?也许需要一个css转换规则 - 但这不是bootstrap.css提供的那部分吗?

对于后代,来自小提琴的等效html文件将是:

<html>
<head>
    <link rel="stylesheet" type="text/css" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" />
    <link rel="stylesheet" type="text/css" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap-theme.min.css" />
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/angular-ui-bootstrap/0.13.0/ui-bootstrap.js"></script>

</head>
<body ng-app="my_app">
    <div ng-controller="CollapseDemoCtrl">
        <button class="btn btn-default" ng-click="isCollapsed = !isCollapsed">Toggle collapse</button>
        <hr />
        <div collapse="isCollapsed">
            <div class="well well-lg">Some content</div>
        </div>
    </div>
</body>
</html>

和等效的.js将是:

var my_app = angular.module('my_app', ['ui.bootstrap']);

my_app.controller('CollapseDemoCtrl', function ($scope) {
    $scope.isCollapsed = false;
});

谢谢!

3 个答案:

答案 0 :(得分:39)

Angulajs UI Bootstrap 0.13.0需要用于动画的ngAnimate模块。注册ngAnimate它会工作。 issue

Original plnkr

Modified, animation working plnkr

答案 1 :(得分:8)

将ui-bootstrap版本降级为0.12.0。 0.13.0中存在一个错误,导致动画不起作用。

<html>
<head>
    <link rel="stylesheet" type="text/css" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" />
    <link rel="stylesheet" type="text/css" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap-theme.min.css" />
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/angular-ui-bootstrap/0.12.0/ui-bootstrap.js"></script>

</head>
<body ng-app="my_app">
    <div ng-controller="CollapseDemoCtrl">
        <button class="btn btn-default" ng-click="isCollapsed = !isCollapsed">Toggle collapse</button>
        <hr />
        <div collapse="isCollapsed">
            <div class="well well-lg">Some content</div>
        </div>
    </div>
</body>
</html>

JS可以保持不变。我刚刚修改了html代码中的ui-bootstrap版本。

以下是更新的小提琴 - https://jsfiddle.net/xv7tws10/5/

编辑:请参阅以下Premchandra的回复。显然,您必须包含ng-animate才能使折叠动画在角度1.3中工作。

答案 2 :(得分:2)

似乎有一个版本限制,直到它停止动画。

这是一个 Fiddle ,可以看到它按照您的意愿运行,但最新版本只能使用。

<html !DOCTYPE html>
<head>

<link href="//netdna.bootstrapcdn.com/twitter-bootstrap/2.3.1/css/bootstrap-combined.min.css" rel="stylesheet">

</head>

<body  ng-app="my_app">
<br>
<div ng-controller="CollapseDemoCtrl">
    <button class="btn btn-default" ng-click="isCollapsed = !isCollapsed">Toggle collapse</button>
    <hr />
    <div collapse="isCollapsed" >
        <div class="well well-lg">Some content</div>
    </div>
</div>

<script src="http://code.angularjs.org/1.2.28/angular.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular-ui-bootstrap/0.8.0/ui-bootstrap.js"></script>
<script src="//ajax.googleapis.com/ajax/libs/angularjs/1.2.5/angular-animate.min.js"></script>

<script>
angular.module('my_app', ['ngAnimate', 'ui.bootstrap']);
function CollapseDemoCtrl($scope) {
$scope.isCollapsed = false;
}   
</script>     
</body>
</html>