From b71abe45f1cf04ca375ad92e4f780aad2b8ba60d Mon Sep 17 00:00:00 2001 From: Vjeux Date: Thu, 13 Jun 2013 01:00:38 +0200 Subject: [PATCH] Adding JSX pitfalls section in the docs --- _includes/nav_docs.html | 7 +++ docs/api.md | 1 + docs/jsx-is-not-html.md | 95 +++++++++++++++++++++++++++++++++++++++++ 3 files changed, 103 insertions(+) create mode 100644 docs/jsx-is-not-html.md diff --git a/_includes/nav_docs.html b/_includes/nav_docs.html index d6d9e945..1dbd3b5c 100644 --- a/_includes/nav_docs.html +++ b/_includes/nav_docs.html @@ -21,4 +21,11 @@
  • API
  • + + diff --git a/docs/api.md b/docs/api.md index fd29070e..f8b9edda 100644 --- a/docs/api.md +++ b/docs/api.md @@ -3,6 +3,7 @@ id: docs-api title: React API layout: docs prev: mixins.html +next: jsx-is-not-html.html --- ## React diff --git a/docs/jsx-is-not-html.md b/docs/jsx-is-not-html.md new file mode 100644 index 00000000..e3c41263 --- /dev/null +++ b/docs/jsx-is-not-html.md @@ -0,0 +1,95 @@ +--- +id: docs-jsx-is-not-html +title: JSX is not HTML +description: Differences between JSX and HTML. +layout: docs +prev: api.html +--- + +JSX looks like HTML but there are some important differences you may run into. + +## Whitespace removal + +JSX doesn't follow the same whitespace elimination rules as HTML. JSX removes all the whitespaces between two curly braces expressions. If you want to have a white space, a work-around is to add `{' '}`. + +```javascript +
    {this.props.name} {' '} {this.props.surname}
    +``` + +This behavior is still being debated. Follow [Issue #65](https://github.com/facebook/react/issues/65) to be updated on the situation. + +## HTML Entities + +You can insert HTML entities within literal text in JSX: + +```javascript +
    First · Second
    +``` + +If you want to display an HTML entity within a dynamic content, you will run into double escaping issues as React escapes all the strings you are displaying in order to prevent a wide range of XSS attacks by default. + +```javascript +// Bad: It displays "First · Second" +
    {'First · Second'}
    +``` + +There are various ways to work-around this issue. The easiest one is to write unicode character directly in Javascript. You've got to make sure that the file is saved as UTF-8 and that the propers UTF-8 directives are set so the browser will display it correctly. + +```javascript +
    {'First ยท Second'}
    +``` + +A safer alternative is to find the unicode number corresponding to the entity and use it inside of a Javascript string. + +```javascript +
    {'First \u00b7 Second'}
    +
    {'First ' + String.fromCharCode(183) + ' Second'}
    +``` + +You can use mixed arrays with strings and JSX elements. + +```javascript +
    {['First ', ·, ' Second']}
    +``` + +In last resort, you always have the ability to insert raw HTML inside of the div. + +```javascript +
    +``` + +## Comments + +JSX supports both single-line and multi-lines Javascript comments within a tag declaration: + +```javascript +
    +``` + +As of React 0.3, there is no good way to insert comments within the children section. [Issue #82](https://github.com/facebook/react/issues/82) is tracking progress to enable the following way to write comments: + +```javascript +// Note: The following is not implemented yet! +
    + {/* This is a comment */} +
    +``` + +## Custom HTML attributes + +If you pass properties to native HTML elements that do not exist in the HTML specification, React will not render them. If you want to use a custom attribute, you should prefix it with `data-`. + +```javascript +
    +``` + +[Web Accessibility](http://www.w3.org/WAI/intro/aria) attributes starting with `aria-` will be rendered properly. + +```javascript +
    +```