JSX
我们知道React使用一颗DOM对象树来描述文档,如果它是普通的对象,会是怎样?
var element = { tagName: 'div', props: { id: 'div', className: 'container' }, children: [ { tagName: 'div', props: { id: 'div1', className: 'header' }, children: [...{element}] }, { tagName: 'div', props: { id: 'div2', className: 'content' }, children: [...{element}] }, { tagName: 'div', props: { id: 'div3', className: 'footer' }, children: [...{element}] } ]}
对应的 HTML:
<div class="container"> <div class="header"></div> <div class="content"></div> <div class="footer"></div></div>
JSX给予的方式正好相反,通过书写这样类似 HTML结构,通过transformer工具将其转换成了对象,且让我们看一个不借助 JSX的写法实现上面的结构。
React.createElement( 'div', { className: 'container'}, React.createElement( 'div', { className: 'header'} ), React.createElement( 'div', { className: 'content'} ), React.createElement( 'div', { className: 'footer'} ));
开始使用JSX
在今后的编程实践中期望大家使用JSX来书写React组件
利用JSX我们现在可以像写 HTML一样来书写React组件,某些情况下在属性中你还需要注意 JavaScript的保留字,比如class属性要写成className,for需要写成htmlFor。 JSX对于大小写是敏感的,小写属于HTML标签,大写则是React组件。
使用 JSX书写一个简单的组件:
import React from 'react';import { render } from 'react-dom';function Hello (props){ const { className, children } = props; return ( <div className={ className }> { children } </div> );}render(( <Hello className="div"> Hello World </Hello>),document.getElementById('app'))
表达式
在 JSX中 {}用来表示一个 JavaScript表达式,你可以在这里进行求值逻辑或者赋值,赋值且可看上述的Hello例子,只需要 { children }。
且看我们已经实现的 Dialog根据不同的 type类型来呈现不同的子组件。
好的写法是将逻辑判断写在return之前(good):
import Alert from './Alert';import Confirm from './Confirm';class Dialog extends React.Component { render (){ const { type } = this.props; const Component = type === 'alert' ? Alert : Confirm; return ( <section> <Component {...this.props} /> </section> ); }}
当然你也可以直接将表达式写在return里面(这个写法非常不好 bad):
import Alert from './Alert';import Confirm from './Confirm';class Dialog extends React.Component { render (){ const { type } = this.props; return ( <section> { type === 'alert' ? <Alert {...this.props} /> : <Confirm {...this.props} /> } </section> ); }}
注释
在 JSX里的注视和 JavaScript一样,比如 //, /**/,唯一的要求是需要使用 {}包括起来。
{/*<Component {...this.props }/>*/}
spread attributes
在Dialog的例子中可以看见大量的 ...符号,这是属于ES2015规范中的操作符,在React组件中的 {...this.props},可以将 props的属性设置为 React Component的属性。
HTML转义和自定义属性
为了防止XSS攻击,React组件会将需要显示到DOM的字符串进行转义,如果实在有这样的需求,可以有如下的几种方式解决:
- 使用UTF-8的字符集
- 使用对应字符的Unicode编码
- 使用数组组装
- 使用原始HTML
<div>{['First ', <span key="middot">·</span>, ' Second']}</div>
如果你在JSX中使用了不存在于HTML规范的属性,这个属性是会被忽略的,你需要使用 data-方式来自定义属性。
关于支持的标签,属性,以及可访问性属性前缀的列表:
- React支持的标签,属性
- 可访问性属性前缀列表

HTMLISNOTAPROGRAMMENGUAGE; ITISAMARKUMARKUPLAGUAGE.1)htmlStructures andFormatSwebContentusingtags.2)itworkswithcsssforstylingandjavascript for Interactivity,增強WebevebDevelopment。

HTML是構建網頁結構的基石。 1.HTML定義內容結構和語義,使用、、等標籤。 2.提供語義化標記,如、、等,提升SEO效果。 3.通過標籤實現用戶交互,需注意表單驗證。 4.使用、等高級元素結合JavaScript實現動態效果。 5.常見錯誤包括標籤未閉合和屬性值未加引號,需使用驗證工具。 6.優化策略包括減少HTTP請求、壓縮HTML、使用語義化標籤等。

HTML是一種用於構建網頁的語言,通過標籤和屬性定義網頁結構和內容。 1)HTML通過標籤組織文檔結構,如、。 2)瀏覽器解析HTML構建DOM並渲染網頁。 3)HTML5的新特性如、、增強了多媒體功能。 4)常見錯誤包括標籤未閉合和屬性值未加引號。 5)優化建議包括使用語義化標籤和減少文件大小。

WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。

HTML的作用是通過標籤和屬性定義網頁的結構和內容。 1.HTML通過到、等標籤組織內容,使其易於閱讀和理解。 2.使用語義化標籤如、等增強可訪問性和SEO。 3.優化HTML代碼可以提高網頁加載速度和用戶體驗。

htmlisaspecifictypefodyfocusedonstructuringwebcontent,而“代碼” badlyLyCludEslanguagesLikeLikejavascriptandPytyPythonForFunctionality.1)htmldefineswebpagertuctureduseTags.2)“代碼”代碼“ code” code code code codeSpassSesseseseseseseseAwiderRangeLangeLangeforLageforLogageforLogicIctInterract

HTML、CSS和JavaScript是Web開發的三大支柱。 1.HTML定義網頁結構,使用標籤如、等。 2.CSS控製網頁樣式,使用選擇器和屬性如color、font-size等。 3.JavaScript實現動態效果和交互,通過事件監聽和DOM操作。

HTML定義網頁結構,CSS負責樣式和佈局,JavaScript賦予動態交互。三者在網頁開發中各司其職,共同構建豐富多彩的網站。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Dreamweaver Mac版
視覺化網頁開發工具

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具