網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
一、 State
1.概念
概念:state是組件對(duì)象最重要的屬性,值是對(duì)象(可以包含多個(gè)key:value的組合),組件被稱為狀態(tài)機(jī),通過(guò)更新組件的state來(lái)更新對(duì)應(yīng)的頁(yè)面顯示(重新渲染組件),有state稱為復(fù)雜組件。
2.State的簡(jiǎn)單用法
實(shí)現(xiàn)簡(jiǎ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核心庫(kù) -->
<script src="js/react.development.js"></script>
<!-- 引入操作dom的擴(kuò)展庫(kù) -->
<script src="js/react-dom.development.js"></script>
<!-- 引入babel來(lái)解析jsx語(yǔ)法 -->
<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>
}
說(shuō)明:
·onclick 變?yōu)?onClick。
·{函數(shù)名}返回值給click,加()就會(huì)直接調(diào)用。
5.react this指向問(wèn)題
demo(){ console.log(this);//undefined
console.log('事件被點(diǎn)擊了');
}
舉例說(shuō)明:
class Person{
constructor(name,age) {
this.name = name;
this.age = age;
}
say(){
console.log(this);
}
}
const p1 = new Person('張三',18);
p1.say();//p1為實(shí)例對(duì)象
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'));
說(shuō)明:
bind會(huì)生成一個(gè)新的方法 并傳對(duì)象 改變this的指向必須使用setState 修改才有效,修改內(nèi)容為合并。有值得修改沒(méi)有的不動(dòng)
7.代碼簡(jiǎn)寫(xiě)
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'));
說(shuō)明:
類中的屬性直接賦值,省去構(gòu)造函數(shù)。
自定義方法—用賦值語(yǔ)句的形式+箭頭函數(shù)
二、props
1.概念
每個(gè)組件對(duì)象都會(huì)有props(properties的簡(jiǎn)寫(xiě))屬性。
組件標(biāo)簽的所有屬性都保存在props中。
props 是不可變的,只能通過(guò) props 來(lái)傳遞數(shù)據(jù)。
2.傳參的基礎(chǔ)方法、運(yùn)算符傳參
其中先通過(guò)let創(chuàng)建了一個(gè)對(duì)象,在通過(guò)三點(diǎn)運(yùn)算符,來(lái)遍歷得到,對(duì)象里面的值
在通過(guò)對(duì)象結(jié)構(gòu)得到props中的realname和age,GetName是Person組件的子組件,在Person中傳值給GetName,GetName通過(guò)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核心庫(kù) -->
<script src="js/react.development.js"></script>
<!-- 引入操作dom的擴(kuò)展庫(kù) -->
<script src="js/react-dom.development.js"></script>
<!-- 引入babel來(lái)解析jsx語(yǔ)法 -->
<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來(lái)標(biāo)識(shí)自己。
字符串形式的ref、回調(diào)函數(shù)下ref、createRef 創(chuàng)建ref容器
字符串形勢(shì),是直接通過(guò)ref綁定值,通過(guò)在點(diǎn)擊事件中獲取ref的值,ref如同把整個(gè)input表單傳了過(guò)來(lái),在獲取值的時(shí)候需要點(diǎn)一下value來(lái)獲取的是input表單的內(nèi)容
通過(guò)ref中的箭頭函數(shù),綁定了值,在方法中直接獲取即可,穿過(guò)來(lái)時(shí),由于react的編譯不需要寫(xiě)target但是,還是需要點(diǎn)出value
通過(guò)createRef來(lái)創(chuàng)建兩個(gè)容器,通過(guò)對(duì)象的形勢(shì)與ref綁定,直接就可以在方法中得到值,不過(guò)這里要注意,打印還是獲取的時(shí)候在點(diǎn)value之前點(diǎn)一個(gè)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核心庫(kù) -->
<script src="js/react.development.js"></script>
<!-- 引入操作dom的擴(kuò)展庫(kù) -->
<script src="js/react-dom.development.js"></script>
<!-- 引入babel來(lái)解析jsx語(yǔ)法 -->
<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 (
/*字符串形勢(shì)
<div>
<p><input type="text" placeholder="請(qǐng)輸入姓名" 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="請(qǐng)輸入姓名" 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="請(qǐng)輸入姓名" 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-10-26 Flutter?EventBus事件總線的應(yīng)用詳解_Android
- 2023-06-05 python文件編譯為pyc后運(yùn)行的實(shí)現(xiàn)步驟_python
- 2022-11-05 Python?sklearn庫(kù)三種常用編碼格式實(shí)例_python
- 2022-07-26 Android自定義評(píng)分控件的完整實(shí)例_Android
- 2022-07-15 Qt項(xiàng)目打包的實(shí)現(xiàn)步驟_C 語(yǔ)言
- 2022-03-07 C語(yǔ)言中的rand()和rand_r()詳解_C 語(yǔ)言
- 2022-05-08 ASP.NET?MVC異常過(guò)濾器用法_實(shí)用技巧
- 2023-07-24 解碼方法decodedURIComponent
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- 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)證過(guò)濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支