У меня этот div где-то в моем коде.ng-класс не может применять класс css к элементу
<div ng-class="className" >{{className}}</div>
В какой-то момент я звоню changeClass
функцию от нг нажмите, чтобы изменить класс этого дел.
$scope.changeClass = function(){
console.log($scope.className)
if ($scope.className === "expand-icon")
$scope.className = "expand-icon.expanded";
else
$scope.className = "expand-icon";
};
Я могу видеть изменения класса из-за console.log, а также {{имя класса}} является outputed на этой странице. Однако класс css не применяется.
Это знак «+», который должен превратиться в «-» с анимацией. Вот CSS:
/* + button */
.expand-icon {
height: 32px;
width: 32px;
position: relative;
}
.expand-icon::before, .expand-icon::after {
content: " ";
width: 32px;
height: 6px;
background-color: #fff;
display: block;
position: absolute;
top: 50%;
left: 50%;
transition: all 0.15s cubic-bezier(.42, 0, .58, 1);
opacity: 1;
border-radius: 2px;
}
.expand-icon::before {
transform: translate(-50%, -50%) rotate(90deg);
}
.expand-icon::after {
transform: translate(-50%, -50%);
}
.expand-icon {
height: 32px;
width: 32px;
position: relative;
}
.expand-icon.expanded::before {
transform: translate(-50%, -50%) rotate(0deg);
}
.expand-icon.expanded::after {
transform: translate(-50%, -50%) rotate(-90deg);
opacity: 0;
}
Так-значок расширения применяется, но расширить-icon.expanded не оказывает никакого влияния, так как я использую этот нг класса уловку. Любая идея почему?
Вы должны заменить точку с пробелом: '$ scope.className = "расширение-значок расширяется",' – devqon
возможно дубликат http://stackoverflow.com/questions/20460369/ добавление-и-удаление-классы-в-angularjs-использования-нг-клик –