2012-03-08 23:00:38 +00:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @ngdoc directive
|
2012-06-12 06:49:24 +00:00
|
|
|
* @name ng.directive:ngStyle
|
2012-03-08 23:00:38 +00:00
|
|
|
*
|
|
|
|
|
* @description
|
2012-04-06 23:35:17 +00:00
|
|
|
* The `ngStyle` directive allows you to set CSS style on an HTML element conditionally.
|
2012-03-08 23:00:38 +00:00
|
|
|
*
|
|
|
|
|
* @element ANY
|
2012-05-24 21:49:47 +00:00
|
|
|
* @param {expression} ngStyle {@link guide/expression Expression} which evals to an
|
2012-03-08 23:00:38 +00:00
|
|
|
* object whose keys are CSS style names and values are corresponding values for those CSS
|
|
|
|
|
* keys.
|
|
|
|
|
*
|
|
|
|
|
* @example
|
2012-04-29 05:45:28 +00:00
|
|
|
<example>
|
|
|
|
|
<file name="index.html">
|
2012-03-09 08:00:05 +00:00
|
|
|
<input type="button" value="set" ng-click="myStyle={color:'red'}">
|
|
|
|
|
<input type="button" value="clear" ng-click="myStyle={}">
|
2012-03-08 23:00:38 +00:00
|
|
|
<br/>
|
2012-03-09 08:00:05 +00:00
|
|
|
<span ng-style="myStyle">Sample Text</span>
|
2012-03-08 23:00:38 +00:00
|
|
|
<pre>myStyle={{myStyle}}</pre>
|
2012-04-29 05:45:28 +00:00
|
|
|
</file>
|
|
|
|
|
<file name="style.css">
|
|
|
|
|
span {
|
|
|
|
|
color: black;
|
|
|
|
|
}
|
|
|
|
|
</file>
|
|
|
|
|
<file name="scenario.js">
|
2012-03-09 08:00:05 +00:00
|
|
|
it('should check ng-style', function() {
|
2012-03-08 23:00:38 +00:00
|
|
|
expect(element('.doc-example-live span').css('color')).toBe('rgb(0, 0, 0)');
|
|
|
|
|
element('.doc-example-live :button[value=set]').click();
|
|
|
|
|
expect(element('.doc-example-live span').css('color')).toBe('rgb(255, 0, 0)');
|
|
|
|
|
element('.doc-example-live :button[value=clear]').click();
|
|
|
|
|
expect(element('.doc-example-live span').css('color')).toBe('rgb(0, 0, 0)');
|
|
|
|
|
});
|
2012-04-29 05:45:28 +00:00
|
|
|
</file>
|
|
|
|
|
</example>
|
2012-03-08 23:00:38 +00:00
|
|
|
*/
|
|
|
|
|
var ngStyleDirective = ngDirective(function(scope, element, attr) {
|
2012-07-06 09:53:40 +00:00
|
|
|
scope.$watch(attr.ngStyle, function ngStyleWatchAction(newStyles, oldStyles) {
|
2012-03-08 23:00:38 +00:00
|
|
|
if (oldStyles && (newStyles !== oldStyles)) {
|
|
|
|
|
forEach(oldStyles, function(val, style) { element.css(style, '');});
|
|
|
|
|
}
|
|
|
|
|
if (newStyles) element.css(newStyles);
|
|
|
|
|
}, true);
|
|
|
|
|
});
|