Как динамически изменить свойство CSS в AngularJS
Прямо сейчас у меня есть URL фонового изображения, жестко запрограммированный в CSS. Я хотел бы динамически выбирать фоновое изображение, используя логику в AngularJS. Вот что у меня сейчас есть:
HTML
<div class="offer-detail-image-div"><div>
CSS
.offer-detail-image-div {
position: relative;
display: block;
overflow: hidden;
max-width: 800px;
min-height: 450px;
min-width: 700px;
margin-right: auto;
margin-left: auto;
padding-right: 25px;
padding-left: 25px;
-webkit-box-flex: 1;
-webkit-flex: 1;
-ms-flex: 1;
flex: 1;
border-radius: 5px;
background-image: url('/assets/images/118k2d049mjbql83.jpg');
background-position: 0px 0px;
background-size: cover;
background-repeat: no-repeat;
}
Как вы можете видеть, фоновое изображение в CSS ссылается на конкретное местоположение файла. Я хочу, чтобы иметь возможность программно определять местоположение URL изображения. Я действительно не знаю, с чего начать. Я не знаю JQuery. Спасибо.
4 ответа
Вы можете использовать стиль ng для динамического изменения свойства класса CSS с помощью AngularJS.
Надеюсь, этот пример в стиле нг поможет вам хотя бы понять концепцию.
Больше информации для ngStyle
var myApp = angular.module('myApp', []);
myApp.controller("myAppCtrl", ["$scope", function($scope) {
$scope.colors = ['#C1D786', '#BF3978', '#15A0C6', '#9A2BC3'];
$scope.style = function(value) {
return { "background-color": value };
}
}]);
ul{
list-style-type: none;
color: #fff;
}
li{
padding: 10px;
text-align: center;
}
.original{
background-color: red;
}
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<body ng-app="myApp">
<div ng-controller="myAppCtrl">
<div class="container">
<div class="row">
<div class="span12">
<ul>
<li ng-repeat="color in colors">
<h4 class="original" ng-style="style(color)"> {{ color }}</h4>
</li>
</ul>
</div>
</div>
</div>
</div>
</body>
Edit-1
Вы можете изменить background-image: URL следующим образом.
$scope.style = function(value) {
return { 'background-image': 'url(' + value+')' };
}
Ты можешь использовать ng-class
: документация. Если вы хотите сделать это в вашем directive
проверять directive
- attr
: attr.
Ты можешь использовать [ngStyle]
непосредственно. Это карта, поэтому вы можете напрямую обратиться к одному из ее элементов следующим образом: [ngStyle.CSS_PROPERTY_NAME]
Например:
<div class="offer-detail-image-div"
[ngStyle.background-image]="'url(' + backgroundSrc + ')'">Hello World!</div>
Кроме того, для обслуживания активов, Angular имеет bypassSecurityTrustStyle
функция полезности, которая может пригодиться при динамическом обслуживании активов.
Введите размер в текстовое поле вы можете увидеть окно изменения высоты и ширины
<!DOCTYPE html>
<html>
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.6.4/angular.min.js"></script>
<body>
<p>Change the value of the input field:</p>
<div ng-app="" >
<input ng-model="myCol" type="textbox">
<div style="background-color:red; width:{{myCol}}px; height:{{myCol}}px;"> </div>
</div>
</body>
</html>