From 3bf315d70eac7102d8b6892a2ee404f8ea215719 Mon Sep 17 00:00:00 2001 From: Dmitriy Kubyshkin Date: Fri, 13 May 2016 02:00:04 +0200 Subject: [PATCH] Fixed removing attributes during custom element update. Fixes #6747 (#6748) (cherry picked from commit 0e889d7c724fe41a16668d651ddb443b854397be) --- .../dom/shared/DOMPropertyOperations.js | 18 ++++++++++++++++++ src/renderers/dom/shared/ReactDOMComponent.js | 7 +++++++ .../shared/__tests__/ReactDOMComponent-test.js | 9 +++++++++ 3 files changed, 34 insertions(+) diff --git a/src/renderers/dom/shared/DOMPropertyOperations.js b/src/renderers/dom/shared/DOMPropertyOperations.js index a4fbd376ae9aa..cb9dbc520dff0 100644 --- a/src/renderers/dom/shared/DOMPropertyOperations.js +++ b/src/renderers/dom/shared/DOMPropertyOperations.js @@ -206,6 +206,24 @@ var DOMPropertyOperations = { } }, + /** + * Deletes an attributes from a node. + * + * @param {DOMElement} node + * @param {string} name + */ + deleteValueForAttribute: function(node, name) { + node.removeAttribute(name); + if (__DEV__) { + ReactDOMInstrumentation.debugTool.onDeleteValueForProperty(node, name); + ReactInstrumentation.debugTool.onNativeOperation( + ReactDOMComponentTree.getInstanceFromNode(node)._debugID, + 'remove attribute', + name + ); + } + }, + /** * Deletes the value for a property on a node. * diff --git a/src/renderers/dom/shared/ReactDOMComponent.js b/src/renderers/dom/shared/ReactDOMComponent.js index 079a5344df1dc..4a5940e8ad1d2 100644 --- a/src/renderers/dom/shared/ReactDOMComponent.js +++ b/src/renderers/dom/shared/ReactDOMComponent.js @@ -904,6 +904,13 @@ ReactDOMComponent.Mixin = { // listener (e.g., onClick={null}) deleteListener(this, propKey); } + } else if (isCustomComponent(this._tag, lastProps)) { + if (!RESERVED_PROPS.hasOwnProperty(propKey)) { + DOMPropertyOperations.deleteValueForAttribute( + getNode(this), + propKey + ); + } } else if ( DOMProperty.properties[propKey] || DOMProperty.isCustomAttribute(propKey)) { diff --git a/src/renderers/dom/shared/__tests__/ReactDOMComponent-test.js b/src/renderers/dom/shared/__tests__/ReactDOMComponent-test.js index dd939ede63391..d72d497d3f599 100644 --- a/src/renderers/dom/shared/__tests__/ReactDOMComponent-test.js +++ b/src/renderers/dom/shared/__tests__/ReactDOMComponent-test.js @@ -302,6 +302,15 @@ describe('ReactDOMComponent', function() { expect(container.firstChild.className).toEqual(''); }); + it('should properly update custom attributes on custom elements', function() { + var container = document.createElement('div'); + ReactDOM.render(, container); + ReactDOM.render(, container); + var node = container.firstChild; + expect(node.hasAttribute('foo')).toBe(false); + expect(node.getAttribute('bar')).toBe('buzz'); + }); + it('should clear a single style prop when changing `style`', function() { var styles = {display: 'none', color: 'red'}; var container = document.createElement('div');