欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React學習之JSX與react事件實例分析

 更新時間:2020年01月06日 10:14:11   作者:theVicTory  
這篇文章主要介紹了React學習之JSX與react事件,結合實例形式分析了React中JSX表達式、屬性、嵌套與react事件相關使用技巧,需要的朋友可以參考下

本文實例講述了React學習之JSX與react事件。分享給大家供大家參考,具體如下:

1、JSX

1.1、表達式

在React中使用JSX來描述HTML頁面,而且可以與js混合使用,使用JavaScript表達式時要將表達式包含在大括號里

const user = {
 firstName: 'Harper',
 lastName: 'Perez'
};
const element = (    //將JSX語句保存在變量中
 <h1>
  Hello, {formatName(user)}!  {/* {}中寫js語句*/}
 </h1>
);

在編譯之后呢,JSX 其實會被轉化為普通的 JavaScript 對象,可以對其賦值或把它當作參數(shù)傳遞:

ReactDOM.render(
 element,        //通過JSX變量渲染react節(jié)點
 document.getElementById('root')
);

1.2、屬性

JSX中可以像HTML中一樣使用"字符串"的屬性,也可以使用{表達式}屬性:

const element = <div tabIndex="0"></div>;
const element = <img src={user.avatarUrl}></img>;

注意:

1、React DOM 使用 camelCase 小駝峰命名 來定義屬性的名稱,而不是使用 HTML 的屬性名稱。例如font-size要改為fontSize。

2、HTML中的保留字不能用于js中,例如class,應改為className:

const ele= <div className="red">Red Color</div>

3、JSX中行內樣式style需要用一個對象返回,而不是字符串:

const ele=<div style="color:red">Red</div>     //會報錯
const ele= <div style={{color:'red'}}>Red</div>

{{color:red}}中第一個大括號代表這是一個js表達式,第二個代表這是一個用大括號引起的對象

1.3、嵌套

如果 JSX 標簽是閉合式的,那么需要在結尾處用 />:

const element = <img src={user.avatarUrl} />;

jJSX內含多個標簽時,返回時需要在最外面用一個div把它們包起來:

const element = (
 <div>
  <h1>Hello!</h1>
  <h2>Good to see you here.</h2>
 </div>
);

1.4、注釋

在jsx中的注釋要單獨占一行,且用大括號包起來,例如:{/*注釋*/},否則有可能會被當成普通文本,引起錯誤。

2、事件

react事件的綁定采用駝峰寫法onClick={this.function}

例如定義一個切換ON/OFF的函數(shù)shiftFlag:

class Toggole extends React.Component{
 constructor(props){
  super(props);
  this.state={
   flag:true
  };
  this.shiftFlag=this.shiftFlag.bind(this);   //函數(shù)shiftFlag綁定this
 }
 shiftFlag(e){
  e.preventDefault();
  this.setState({
   flag:!this.state.flag
  });
 }
 render(){
  return <a href="#" rel="external nofollow" onClick={this.shiftFlag}>{this.state.flag?'ON':'OFF'}</a>
 }
}

注:

1、類的方法默認是不會綁定this的,直接在方法shiftFlag中使用this會報錯this is undefined,因此需要為shiftFlag綁定this。

2、e是一個事件參數(shù),使用e.preventDefault()方法來阻止a標簽的默認跳轉行為。

react事件參數(shù)的傳遞通過綁定來實現(xiàn),在傳遞時,綁定的this在前,參數(shù)在后。在定義函數(shù)時,事件對象e要放在最后,例如定義一個setName函數(shù)修改name為傳入的參數(shù):

class Name extends React.Component{
 constructor(props){
  super(props);
  this.state={
   name:'default'
  }
 }
 setName(name,e){   //事件e放在最后
  this.setState({
   name:name
  })
 }
 render(){
  return <button onClick={this.setName.bind(this,'tory')}>{this.state.name}</button>
 }
}

希望本文所述對大家React程序設計有所幫助。

相關文章

  • React實現(xiàn)控制減少useContext導致非必要的渲染詳解

    React實現(xiàn)控制減少useContext導致非必要的渲染詳解

    這篇文章主要介紹了React如何有效減少使用useContext導致的不必要渲染,使用useContext在改變一個數(shù)據(jù)時,是通過自己逐級查找對比改變的數(shù)據(jù)然后渲染,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-11-11
  • 使用react-dnd編寫一個可拖拽排列的list

    使用react-dnd編寫一個可拖拽排列的list

    這篇文章主要為大家詳細介紹了如何使用react-dnd編寫一個可拖拽排列的list,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2024-03-03
  • 全棧輕量級搭配之Remix Prisma Sqlite使用分析

    全棧輕量級搭配之Remix Prisma Sqlite使用分析

    這篇文章主要為大家介紹了全棧輕量級搭配之Remix Prisma Sqlite使用示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-05-05
  • react項目打包后點擊index.html頁面出現(xiàn)空白的問題

    react項目打包后點擊index.html頁面出現(xiàn)空白的問題

    這篇文章主要介紹了react項目打包后點擊index.html頁面出現(xiàn)空白的問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • React?如何向url中添加參數(shù)

    React?如何向url中添加參數(shù)

    這篇文章主要介紹了React?如何向url中添加參數(shù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • react native實現(xiàn)往服務器上傳網絡圖片的實例

    react native實現(xiàn)往服務器上傳網絡圖片的實例

    下面小編就為大家?guī)硪黄猺eact native實現(xiàn)往服務器上傳網絡圖片的實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • react事件對象無法獲取offsetLeft,offsetTop,X,Y等元素問題及解決

    react事件對象無法獲取offsetLeft,offsetTop,X,Y等元素問題及解決

    這篇文章主要介紹了react事件對象無法獲取offsetLeft,offsetTop,X,Y等元素問題及解決方案,具有很好的參考價值,希望對大家有所幫助。
    2022-08-08
  • React報錯map()?is?not?a?function詳析

    React報錯map()?is?not?a?function詳析

    這篇文章主要介紹了React報錯map()?is?not?a?function詳析,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-08-08
  • Redis數(shù)據(jù)結構面試高頻問題解析

    Redis數(shù)據(jù)結構面試高頻問題解析

    這篇文章主要為大家介紹了Redis數(shù)據(jù)結構高頻面試問題解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • react中涉及的增加,刪除list方式

    react中涉及的增加,刪除list方式

    這篇文章主要介紹了react中涉及的增加,刪除list方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01

最新評論