網(wǎng)站首頁 編程語言 正文
一、 State
1.概念
概念:state是組件對象最重要的屬性,值是對象(可以包含多個key:value的組合),組件被稱為狀態(tài)機(jī),通過更新組件的state來更新對應(yīng)的頁面顯示(重新渲染組件),有state稱為復(fù)雜組件。
2.State的簡單用法
實現(xiàn)簡單的切換效果,這里的效果是一種覆蓋
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
.btn{
width: 100px;
height: 40px;
background-color: red;
}
.on{
background-color: gray;
}
</style>
</head>
<body>
<div id="root"></div>
<!-- 引入react核心庫 -->
<script src="js/react.development.js"></script>
<!-- 引入操作dom的擴(kuò)展庫 -->
<script src="js/react-dom.development.js"></script>
<!-- 引入babel來解析jsx語法 -->
<script src="js/babel.min.js"></script>
<script type="text/babel">
class IsLike extends React.Component {
state = { flag:true }
//箭頭函數(shù)this指向上下文,靜態(tài)不可改變
changeFlag=()=>{
this.setState({flag:!this.state.flag})
}
render() {
const {flag}=this.state
return (
<div>
<button className={flag?'btn':'btn on'} onClick={this.changeFlag}>{flag?'喜歡':'不喜歡'}</button>
</div>
)
}
}
ReactDOM.render(<IsLike/>,document.getElementById('root'))
</script>
</body>
</html>
編輯
3.?JS綁定事件
let btn = document.getElementById('btn');
btn.addEventListener('click',function(){
alert('按鈕被點(diǎn)擊了!');
})
btn.onclick = function(){
alert('按鈕被點(diǎn)擊了!');
}
function demo(){
alert('按鈕被點(diǎn)擊了');
}
4.react 綁定事件
render(){
return <a href='javascript:;' onClick={demo} className='btn'>{this.state.isflag?'已關(guān)注':'取消關(guān)注'}</a>
}
說明:
·onclick 變?yōu)?onClick。
·{函數(shù)名}返回值給click,加()就會直接調(diào)用。
5.react this指向問題
demo(){ console.log(this);//undefined
console.log('事件被點(diǎn)擊了');
}
舉例說明:
class Person{
constructor(name,age) {
this.name = name;
this.age = age;
}
say(){
console.log(this);
}
}
const p1 = new Person('張三',18);
p1.say();//p1為實例對象
const p2 = p1.say;
p2();//undefined 類采取是嚴(yán)格模式
6.修改state值
class MyClass extends React.Component{
constructor(props) {
super(props);
this.state = {isflag:true};
this.demo = this.demo.bind(this);
}render(){
return <a href='javascript:;' onClick={this.demo} className='btn'>{this.state.isflag?'已關(guān)注':'取消關(guān)注'}</a>
}
demo(){
this.setState({isflag:!this.state.isflag})
}}
ReactDOM.render(<MyClass/>,document.getElementById('root'));
說明:
bind會生成一個新的方法 并傳對象 改變this的指向必須使用setState 修改才有效,修改內(nèi)容為合并。有值得修改沒有的不動
7.代碼簡寫
class MyClass extends React.Component{
state = {isflag:true}
render(){
return <a href='javascript:;' onClick={this.demo} className='btn'>{this.state.isflag?'已關(guān)注':'取消關(guān)注'}</a>
}
demo = () => {
this.setState({isflag:!this.state.isflag})
}
}
ReactDOM.render(<MyClass/>,document.getElementById('root'));
說明:
類中的屬性直接賦值,省去構(gòu)造函數(shù)。
自定義方法—用賦值語句的形式+箭頭函數(shù)
二、props
1.概念
每個組件對象都會有props(properties的簡寫)屬性。
組件標(biāo)簽的所有屬性都保存在props中。
props 是不可變的,只能通過 props 來傳遞數(shù)據(jù)。
2.傳參的基礎(chǔ)方法、運(yùn)算符傳參
其中先通過let創(chuàng)建了一個對象,在通過三點(diǎn)運(yùn)算符,來遍歷得到,對象里面的值
在通過對象結(jié)構(gòu)得到props中的realname和age,GetName是Person組件的子組件,在Person中傳值給GetName,GetName通過props接收
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<div id="root"></div>
<!-- 引入react核心庫 -->
<script src="js/react.development.js"></script>
<!-- 引入操作dom的擴(kuò)展庫 -->
<script src="js/react-dom.development.js"></script>
<!-- 引入babel來解析jsx語法 -->
<script src="js/babel.min.js"></script>
<script type="text/babel">
class GetName extends React.Component {
render() {
return (
<div>姓名:{this.props.realname}</div>
);
}
}
class Person extends React.Component {
render() {
const {realname,age} = this.props
return (
<div>
<GetName realname={this.props.realname}/>
<span>年齡:{age}</span>
</div>
);
}
}
let p1 = {realname:'張三',age:19}
ReactDOM.render(<Person {...p1}/>,document.getElementById('root'))
</script>
</body>
</html>
三、refs
定義
組件內(nèi)的標(biāo)簽可以定義ref來標(biāo)識自己。
字符串形式的ref、回調(diào)函數(shù)下ref、createRef 創(chuàng)建ref容器
字符串形勢,是直接通過ref綁定值,通過在點(diǎn)擊事件中獲取ref的值,ref如同把整個input表單傳了過來,在獲取值的時候需要點(diǎn)一下value來獲取的是input表單的內(nèi)容
通過ref中的箭頭函數(shù),綁定了值,在方法中直接獲取即可,穿過來時,由于react的編譯不需要寫target但是,還是需要點(diǎn)出value
通過createRef來創(chuàng)建兩個容器,通過對象的形勢與ref綁定,直接就可以在方法中得到值,不過這里要注意,打印還是獲取的時候在點(diǎn)value之前點(diǎn)一個current,如this.realname.current.value
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<div id="root"></div>
<!-- 引入react核心庫 -->
<script src="js/react.development.js"></script>
<!-- 引入操作dom的擴(kuò)展庫 -->
<script src="js/react-dom.development.js"></script>
<!-- 引入babel來解析jsx語法 -->
<script src="js/babel.min.js"></script>
<script type="text/babel">
class Person extends React.Component {
//createRef 創(chuàng)建ref容器
realname = React.createRef()
age = React.createRef()
ShowInfo=()=>{
//字符串
// const {realname,age}=this.refs
// console.log(`姓名:${realname.value}年齡:${age.value}`);
//回調(diào)函數(shù)
// let realname = this.realname.value
// let age = this.age.value
// console.log(`姓名:${realname}年齡:${age}`);
//類綁定
console.log(this.realname.current.value);
console.log(this.age.current.value);
}
render() {
return (
/*字符串形勢
<div>
<p><input type="text" placeholder="請輸入姓名" ref='realname'/></p>
<p><input type="text" placeholder="年齡" ref='age'/></p>
<p><button onClick={this.ShowInfo}>提交</button></p>
</div>
*/
//回調(diào)函數(shù)
// <div>
// <p><input type="text" placeholder="請輸入姓名" ref={e=>this.realname=e}/></p>
// <p><input type="text" placeholder="年齡" ref={e=>this.age=e}/></p>
// <p><button onClick={this.ShowInfo}>提交</button></p>
// </div>
//createRef 創(chuàng)建ref容器
<div>
<p><input type="text" placeholder="請輸入姓名" ref={this.realname}/></p>
<p><input type="text" placeholder="年齡" ref={this.age}/></p>
<p><button onClick={this.ShowInfo}>提交</button></p>
</div>
);
}
}
ReactDOM.render(<Person/>,document.getElementById('root'))
</script>
</body>
</html>
原文鏈接:https://juejin.cn/post/7140296171260084232
相關(guān)推薦
- 2022-05-11 mac zsh: command not found: vim
- 2022-03-19 AJAX請求數(shù)據(jù)及實現(xiàn)跨域的三種方法詳解_AJAX相關(guān)
- 2022-10-17 漫談C++哈夫曼樹的原理及實現(xiàn)_C 語言
- 2022-09-07 Python?CSV?文件解析和生成方法示例_python
- 2022-04-14 Go語言context?test源碼分析詳情_Golang
- 2024-03-14 docker創(chuàng)建自定義網(wǎng)絡(luò)
- 2022-06-13 Docker鏡像的commit操作示例及作用_docker
- 2022-10-14 SpringCloud組件之Feign遠(yuǎn)程調(diào)用
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支