React - 三大屬性 Props
React - 三大屬性 Props
前言
介紹組件 三大屬性中的 Props 屬性。
React 起手式
老規矩,先建立一個 HTML,並搭建好環境
Props - 基礎
在 script 中,使用類式組件。
1
2
3
4
5
6
7
8
9
10
11
12
13
14class Person extends React.Component {
render(){
return (
<ul>
<li>
<h4>姓名:小傑·富力士</h4>
<h4>性別:男</h4>
<h4>念能力:強化系</h4>
</li>
</ul>
)
}
}
ReactDOM.render( <Person/>, document.getElementById( 'app' ) )這樣就先完成了最簡單的組件
接著開始運用
props
功能1
2
3
4
5
6
7
8
9
10
11
12
13class Person extends React.Component {
render(){
return (
<li>
<h4>姓名:{ this.props.name }</h4>
<h4>年齡:{ this.props.age }</h4>
<h4>性別:{ this.props.gender }</h4>
</li>
)
}
}
// 在 Person 標籤內添加 props 屬性
ReactDOM.render( <Person name="小傑·富力士" age="12" gender="男"/>, document.getElementById( 'app' ) )接著開啟 live server,就可以查看到
props
內傳遞的值再利用解構賦值,簡化程式碼
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15class Person extends React.Component {
render(){
// 這樣每次使用都可以不用加 this.props 了
const { name, age, gender } = this.props;
return (
<li>
<h4>姓名:{ name }</h4>
<h4>年齡:{ age }</h4>
<h4>性別:{ gender }</h4>
</li>
)
}
}
// 在 Person 標籤內添加 props 屬性
ReactDOM.render( <Person name="小傑·富力士" age="12" gender="男"/>, document.getElementById( 'app' ) )
Props 批量傳遞 & 運算
當資料要代入許多
props
時,可以用 React 裡提供的方法,來批量傳遞1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20class Person extends React.Component {
render(){
const { name, age, gender } = this.props;
return (
<li>
<h4>姓名:{ name }</h4>
<h4>年齡:{ age }</h4>
<h4>性別:{ gender }</h4>
</li>
)
}
}
// 資料
const hunter = {
name: "小傑·富力士",
age: "12",
gender: "男",
}
// 運用 React 裡提供的方法,類似 ES6 的展開運算符'...',來批量傳遞
ReactDOM.render( <Person {...hunter}/>, document.getElementById( 'app' ) )當小傑使用強制成長,把年齡提升 10 歲則可以直接在
{}
內進行運算1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19class Person extends React.Component {
render(){
const { name, age, gender } = this.props;
return (
<li>
<h4>姓名:{ name }</h4>
<h4>年齡:{ age + 10 }</h4>
<h4>性別:{ gender }</h4>
</li>
)
}
}
// 資料
const hunter = {
name: "小傑·富力士",
age: "12",
gender: "男",
}
ReactDOM.render( <Person {...hunter}/>, document.getElementById( 'app' ) )看到畫面時,這時候聰明的你,一定知道問題出在哪裡
沒錯!把資料的字串型態改成數字型態就能正常運算了。
當多人協作,且專案龐大時,很容易不小心出錯,變成難以找到問題
檢查 props 資料型態與預處理的套件
有些時候資料不齊全時,可以設置一些警告,來避免找不到問題出在哪裡
例如:資料沒有名字,性別亂寫,年齡是字串型態。1
2
3
4
5// 資料
const hunter = {
age: "12",
gender: 9453,
}可以再環境配置裡新引入 prop-types CDN
1
<script src="https://cdnjs.cloudflare.com/ajax/libs/prop-types/15.7.2/prop-types.js"></script>
為組件裡面,
render
上面,新增資料型態檢查1
2
3
4
5
6
7// 需注意這裡 propTypes 的 p 是小寫,React 設定的
static propTypes = {
// 這裡 PropTypes 的 P 是大寫,套件設定的
name: PropTypes.string,
age: PropTypes.number,
gender: PropTypes.string,
}這時雖然畫面還是一樣,但開發人員工具就會出現警告
馬上就能發現資料型態的錯誤這時發現沒名字卻沒報錯,在必須傳遞的資料添加
.isRequired
,就會設定必須傳,否則報錯1
2
3
4
5
6
7static propTypes = {
// 設定 isRequired 為必傳
name: PropTypes.string.isRequired,
age: PropTypes.number,
gender: PropTypes.string,
// 如果要限定傳函數則設 PropTypes.func
}
這時名字年齡修正好,而性別故意不寫的話,為不是必傳的值,新增默認值
1
2
3
4
5// 新增默認值,如果沒有設年齡的預設值,資料沒年齡時,會變成 NaN
static defaultProps = {
age: 12,
gender: '無'
}
使用函數式組件來進行 props 傳遞
雖然函數式組件沒有 this 指向,但可以透過參數來進行 props 傳遞
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17function Person( props ) {
const { name, age, gender } = props;
return (
<li>
<h4>姓名:{ name }</h4>
<h4>年齡:{ age }</h4>
<h4>性別:{ gender }</h4>
</li>
)
}
// 資料
const hunter = {
name: "小傑·富力士",
age: 12,
gender: "男"
}
ReactDOM.render( <Person {...hunter}/>, document.getElementById( 'app' ) )
總結 Props
- props 是透過組件的標籤屬性傳遞。
- PropTypes 套件非必須,但有使用除錯會比較快。
- 需注意使用時的大小寫,大小寫寫錯雖然不會報錯,但會失效。
- props 是從組件外往組件內傳遞資料
- 注意 props 只能讀取,不可修改。
- React 中 props 可以透過
...
展開運算符展開屬性