From 0ff5d3b92969adfeb6495cb46ef33493fb7e2546 Mon Sep 17 00:00:00 2001 From: Dan Abramov Date: Fri, 8 Sep 2017 20:25:36 +0100 Subject: [PATCH] Blog post: DOM Attributes in React 16 (#10650) * Blog post: DOM Attributes in React 16 * Testing the RC --- .../2017-09-08-dom-attributes-in-react-16.md | 187 ++++++++++++++++++ 1 file changed, 187 insertions(+) create mode 100644 _posts/2017-09-08-dom-attributes-in-react-16.md diff --git a/_posts/2017-09-08-dom-attributes-in-react-16.md b/_posts/2017-09-08-dom-attributes-in-react-16.md new file mode 100644 index 00000000..fba64ecc --- /dev/null +++ b/_posts/2017-09-08-dom-attributes-in-react-16.md @@ -0,0 +1,187 @@ +--- +title: "DOM Attributes in React 16" +author: gaearon +--- + +In the past, React used to ignore unknown DOM attributes. If you wrote JSX with an attribute that React doesn't recognize, React would just skip it. For example, this: + +```js +// Your code: +
+``` + +would render an empty div to the DOM with React 15: + +````js +// React 15 output: +
+``` + +In React 16, we are making a change. Now, any unknown attributes will end up in the DOM: + +```js +// React 16 output: +
+``` + +## Why Are We Changing This? + +React has always provided a JavaScript-centric API to the DOM. Since React components often take both custom and DOM-related props, it makes sense for React to use the `camelCase` convention just like the DOM APIs: + +```js +
+``` + +This has not changed. However, the way we enforced it in the past forced us to maintain a whitelist of all valid React DOM attributes in the bundle: + +```js +// ... +summary: 'summary', +tabIndex: 'tabindex' +target: 'target', +title: 'title', +// ... +``` + +This had two downsides: + +* You could not [pass a custom attribute](https://github.com/facebook/react/issues/140). This is useful for supplying browser-specific non-standard attributes, trying new DOM APIs, and integrating with opinionated third-party libraries. + +* The attribute list kept growing over time, but most React canonical attribute names are already valid in the DOM. Removing most of the whitelist helped us reduce the bundle size a little bit. + +With the new approach, both of these problems are solved. With React 16, you can now pass custom attributes to all HTML and SVG elements, and React doesn't have to include the whole attribute whitelist in the production version. + +**Note that you should still use the canonical React naming for known attributes:** + +```js +// Yes, please +
+ +// Warning: Invalid DOM property `tabindex`. Did you mean `tabIndex`? +
+``` + +In other words, the way you use DOM components in React hasn't changed, but now you have some new capabilities. + +## Should I Keep Data in Custom Attributes? + +No. We don't encourage you to keep data in DOM attributes. Even if you have to, `data-` attributes are probably a better approach, but in most cases data should be kept in React component state or external stores. + +However, the new feature is handy if you need to use a non-standard or a new DOM attribute, or if you need to integrate with a third-party library that relies on such attributes. + +## Data and ARIA Attributes + +Just like before, React lets you pass `data-` and `aria-` attributes freely: + +```js +
+