diff --git a/src/ng/directive/input.js b/src/ng/directive/input.js index 09e07d365e79..1c873b2152a2 100644 --- a/src/ng/directive/input.js +++ b/src/ng/directive/input.js @@ -435,6 +435,7 @@ function validate(ctrl, validatorName, validity, value){ } function textInputType(scope, element, attr, ctrl, $sniffer, $browser) { + var placeholder = element[0].placeholder, noevent = {}; // In composition mode, users are still inputing intermediate text buffer, // hold the listener until composition is done. // More about composition events: https://developer.mozilla.org/en-US/docs/Web/API/CompositionEvent @@ -451,10 +452,18 @@ function textInputType(scope, element, attr, ctrl, $sniffer, $browser) { }); } - var listener = function() { + var listener = function(event) { if (composing) return; var value = element.val(); + // Some versions of MSIE emit an 'input' event when the placeholder attribute/property + // change. This hack prevents an otherwise pristine field from being dirtied on IE + // browsers. + if (msie && (event || noevent).type === 'input' && element[0].placeholder !== placeholder) { + placeholder = element[0].placeholder; + return; + } + // By default we will trim the value // If the attribute ng-trim exists we will avoid trimming // e.g. diff --git a/test/ng/directive/inputSpec.js b/test/ng/directive/inputSpec.js index b9f737ac0593..f9454a92b33e 100644 --- a/test/ng/directive/inputSpec.js +++ b/test/ng/directive/inputSpec.js @@ -520,6 +520,23 @@ describe('input', function() { } }); + it('should not dirty the model on an input event in response to a placeholder change', inject(function($sniffer) { + if (msie && $sniffer.hasEvent('input')) { + compileInput(''); + inputElm.attr('placeholder', 'Test'); + browserTrigger(inputElm, 'input'); + + expect(inputElm.attr('placeholder')).toBe('Test'); + expect(inputElm).toBePristine(); + + inputElm.attr('placeholder', 'Test Again'); + browserTrigger(inputElm, 'input'); + + expect(inputElm.attr('placeholder')).toBe('Test Again'); + expect(inputElm).toBePristine(); + } + })); + describe('"change" event', function() { function assertBrowserSupportsChangeEvent(inputEventSupported) { // Force browser to report a lack of an 'input' event