六、React 键盘事件 表单事件 事件对象以及React中的ref获取dom节点 、React实现类似Vue的双向数据绑定
接:https://www.cnblogs.com/chenxi188/p/11782349.html
事件对象 、键盘事件、 表单事件 、ref获取dom节点、React实现类似vue双向数据绑定
一、事件对象
事件对象:在触发DOM上的某个事件时,会产生一个事件对象event。这个对象中包含着所有与事件有关的信息
新建Demo2.js输入如下(文件在[在src/components/]下)
1.获取目标节点,并改变其背景色
import React from 'react';
class Demo2 extends React.Component{
constructor(props){
super(props);
this.state={
msg:'hello'
}
}
run=(event)=>{
//打印出所有event事件函数
//console.log(event);
//获取目标节点(此处是button),并改变其背景色为blue
alert(event.target);
event.target.style.background='blue';
}
render(){
return(
<div>
<h1>{this.state.msg}</h1>
<button onClick={this.run}>输出所有事件对象</button>
</div>
)
}
}
export default Demo2;
App.js内容如下:
import React from 'react';
import logo from './logo.svg';
import './App.css';
//import Demo from './components/Demo'
import Demo2 from './components/Demo2.js';
function App() {
return (
<div className="App">
<img src={logo} className="App-logo" alt="logo" />
<Demo2 />
</div>
);
}
export default App;
效果:改变按钮的颜色为blue
点后
2.获取目标节点的属性值
通过事件函数获取目标节点的aid属性值:event.target.getAttribute('aid')
Demo2.js内容:
import React from 'react';
class Demo2 extends React.Component{
constructor(props){
super(props);
this.state={
msg:'hello'
}
}
run=(event)=>{
//获取目标节点属性(button的aid='xxx')其中的xxxx
alert(event.target.getAttribute('aid'))
}
render(){
return(
<div>
<button aid='111111' onClick={this.run}>输出所有事件对象</button>
</div>
)
}
}
export default Demo2;
App.js内容同上
结果:
3.表单事件(目标:通过按钮获取input输入的值)
方法1.通过onChange事件监听input值改变,运行对应函数(函数获取值用x.target.value)改变state值,再通过button的onClick事件监听点击,运行对应函数获取state值
1、监听表单的改变事件 onChange
2、在改变的事件里面获取表单输入的值 事件对象
3、把表单输入的值赋值给username this.setState({})
4、点击按钮的时候获取 state里面的username this.state.username
Demo2.js内容:
import React from 'react';
class Demo2 extends React.Component{
constructor(props){
super(props);
this.state={
msg:'hello',
input_value:''
}
}
//1.获取到input节点,并把值改变到state里的input_value
chan_state=(e)=>{
//a.在控制台输出获取到的input值
console.log(e.target.value);
//b.改变state的值
this.setState({
input_value:e.target.value
});
}
//2.通过按键点击事件获取state的input_value值
get_state=()=>{
//弹出state的input_value值
alert(this.state.input_value);
}
render(){
return(
<div>
{/*
1.首先用onChange监听input值改变的事件,然后调用chan_state自写函数,来改变state里的,input_value值;
2.再用button按钮的监听点击事件,然后去获取state内的input_value被改变后的值。从而实现获取input值功能
*/}
<input onChange={this.chan_state} />
<button onClick={this.get_state}>事件对象</button>
</div>
)
}
}
export default Demo2;
App.js内容不变
结果:
控制台的变化:
方法2.[同方法1]通过onChange事件监听input值改变,运行对应函数(函数获取值用ref)改变state值,再通过button的onClick事件监听点击,运行对应函数获取state值
1、监听表单的改变事件 : onChange
2、在改变的事件里面获取表单输入的值 : ref获取
(注:DOM用ref='xxx',函数获取时用 this.refs.userName.value)
3、把表单输入的值赋值给username : this.setState({})
4、点击按钮的时候获取 state里面的username : this.state.username
Demo.js内容:
import React from 'react';
class Demo2 extends React.Component{
constructor(props){
super(props);
this.state={
userName:''
}
}
//1.获取到input节点,并把值改变到state里的userName
chan_state=()=>{
// 【重点】通过refs获取到input的值【注意此处是refs】
let um=this.refs.userName.value
//a.在控制台输出获取到的input值
console.log(um);
//b.改变state的值
this.setState({
userName:um
});
}
//2.通过按键点击事件获取state的userName值
get_state=()=>{
//弹出state的userName值
alert(this.state.userName);
}
render(){
return(
<div>
{/*
1.首先用onChange监听input值改变的事件,然后调用chan_state自写函数,来改变state里的,name值。为了方便对应函数获取input值此处加一属性ref='name';
2.再用button按钮的监听点击事件,然后去获取state内的input_value被改变后的值。从而实现获取input值功能
*/}
<input ref='userName' onChange={this.chan_state} />
<button onClick={this.get_state}>事件对象</button>
</div>
)
}
}
export default Demo2;
App.js内容不变,刷新查看效果(与方法1相同):
4.表单事件(在input输入值后按回车,获取到输入内容)
1.通过input的监听键盘弹起(onKeyUp),运行指定自写函数,判断按下的是否是回车键(代码:13),是的话就通过x.target.value获取input值,弹出来
Demo3.js
import React from 'react';
class Demo3 extends React.Component{
constructor(props){
super(props);
this.state={
userName:''
}
}
//键盘事件【获取按下键盘的代码:e.keyCode】
run=(e)=>{
console.log(e.keyCode);
if (e.keyCode==13){
//获取目标节点,并弹出其值
alert(e.target.value);
}
}
render(){
return(
<div>
{/*
1.监听函数onKeyUp() 或 onKeyDown() keypress 键盘弹起或按下都可
*/}
<input onKeyUp={this.run} />
</div>
)
}
}
export default Demo3;
App.js:
import React from 'react';
import logo from './logo.svg';
import './App.css';
//import Demo from './components/Demo'
import Demo3 from './components/Demo3.js';
function App() {
return (
<div className="App">
<img src={logo} className="App-logo" alt="logo" />
<Demo3 />
</div>
);
}
export default App;
效果:
输入并按下回车后:
控制台显示:
5.双向数据绑定(改变input值,state对应值跟着改变,h1显示state的值跟着也改变)
双向数据绑定即:model改变影响View,view改变反过来影响model。
todolist.js内容:
import React from 'react';
class List extends React.Component{
constructor(props){
super(props);
this.state={
username:'jim rans'
}
}
//input函数:数据双向绑定(model改变影响View,view改变反过来影响model)
changevalue=(e)=>{
this.setState({
username:e.target.value
})
}
//button函数:点击按钮改变state值,input,h1也跟着变
setname=(e)=>{
this.setState({
username:'变身按钮传来的名字'
})
}
render(){
return(
<div>
{/*h1 input是view.input改变影响state,state又影响h1显示的内容*/}
<h1>{this.state.username}</h1>
<input value={this.state.username} onChange={this.changevalue} />
<button onClick={this.setname} >改变</button>
</div>
);
}
}
export default List;
App.js内容:
import React from 'react';
import logo from './logo.svg';
import './App.css';
import List from './components/todolist.js'
function App() {
return (
<div className="App">
<img src={logo} className="App-logo" alt="logo" />
<List />
</div>
);
}
export default App;
效果:input里输入值,state会跟着改变,然后h1也跟着变
点按钮,传值改变state和h1,input:
六、React 键盘事件 表单事件 事件对象以及React中的ref获取dom节点 、React实现类似Vue的双向数据绑定的更多相关文章
- vue 双向数据绑定 Vue事件介绍 以及Vue中的ref获取dom节点
<template> <div id="app"> <h2>{{msg}}</h2> <input type="te ...
- vue2.* 双向数据绑定 Vue事件介绍 以及Vue中的ref获取dom节点 04
<template> <div id="app"> <!-- 双向数据绑定(必须在表单里面使用) m:model v:view mvvm:model改 ...
- Vue 及双向数据绑定 Vue事件 以及Vue中的ref获取dom节点
<template> <div id="app"> <h2>{{msg}}</h2> <input type="te ...
- React 事件对象、键盘事件、表单事件、ref获取dom节点、react实现类似Vue双向数据绑定
1.案例实现代码 import React, { Component } from 'react'; /** * 事件对象.键盘事件.表单事件.ref获取dom节点.react实现类似Vue双向数据绑 ...
- React对比Vue(03 事件的对比,传递参数对比,事件对象,ref获取DOM节点,表单事件,键盘事件,约束非约束组件等)
import React from 'react'; class Baby extends React.Component { constructor (props) { super(props) t ...
- Vue 双向数据绑定、事件介绍以及ref获取dom节点
vue是一个MVVM的框架 M model V view MVVM model改变会影响视图view,view改变会影响model 双向数据绑定必须在表单里面使用 //我发现在谷歌浏览器翻译后的网页 ...
- Angular4.x 创建组件|绑定数据|绑定属性|数据循环|条件判断|事件|表单处理|双向数据绑定
Angular4.x 创建组件|绑定数据|绑定属性|数据循环|条件判断|事件|表单处理|双向数据绑定 创建 angular 组件 https://github.com/angular/angular- ...
- 20181019 记录 window.setTimeout('dofunction()',2000); - layui form 表单提交 事件 - F11全屏 事件 window.onresize
1 延时事件 window.setTimeout('dofunction()',2000); 函数外面要有引号 如果没有引号 就不能延时执行 应该是内容进行eval,所以外层不是传递字符串的话,外层函 ...
- form表单submit事件
form表单submit事件同时会触发form表单中button按钮的click事件 <!DOCTYPE html> <html> <head> <meta ...
随机推荐
- Django线上部署代码修改失效问题
记一次django项目的线上部署维护问题,django+nginx 关于nginx反向代理服务器的介绍这里有一篇博客介绍的比较好:nginx的相关介绍 以及当一次客户端请求发出后,uwsig以及uWS ...
- D. Cow and Snacks 并查集
D. Cow and Snacks 题意:有n种小吃,m个人,每个人有两种喜欢的小吃,当一个人遇到两种自己都喜欢的小吃,可以都吃掉,问在最优的吃小吃顺序下,不能吃到自己喜欢的小吃的人数最少是多少? 题 ...
- 【剑指Offer面试编程题】题目1503:二叉搜索树与双向链表--九度OJ
题目描述: 输入一棵二叉搜索树,将该二叉搜索树转换成一个排序的双向链表.要求不能创建任何新的结点,只能调整树中结点指针的指向. 输入: 输入可能包含多个测试样例. 对于每个测试案例,输入的第一行为一个 ...
- JavaWeb--概述
1.Java Web应用由一组Servlet.HTML页.类以及其他可以被绑定的资源构成.它可以在何种供应商提供的实现Servlet规范的Servlet容器中运行: 2.Java Web应用中包含如下 ...
- 奇异值分解(SVD)和主成分分析(PCA)
参考: 奇异值分解:https://www.cnblogs.com/endlesscoding/p/10033527.html 主成分分析:https://blog.csdn.net/program_ ...
- Day2-H-非常可乐-HDU1495
大家一定觉的运动以后喝可乐是一件很惬意的事情,但是seeyou却不这么认为.因为每次当seeyou买了可乐以后,阿牛就要求和seeyou一起分享这一瓶可乐,而且一定要喝的和seeyou一样多.但see ...
- ibd2sdi — InnoDB表空间SDI提取实用程序
参考mysql8.0官方文档 https://dev.mysql.com/doc/refman/8.0/en/ibd2sdi.html ibd2sdi是一个实用程序,用于从表空间文件中提取 序列化的字 ...
- 「NOIP2014」飞扬的小鸟
传送门 Luogu 解题思路 考虑 \(\text{DP}\) 设 \(dp[i][j]\) 表示飞到 \((i, j)\) 这个点的最小触屏次数. 转移其实比较显然,但问题是每次上升时都可以点很多次 ...
- golang的传值调用和传引用调用
传值还是传引用 调用函数时, 传入的参数的 传值 还是 传引用, 几乎是每种编程语言都会关注的问题. 最近在使用 golang 的时候, 由于 传值 和 传引用 的方式没有弄清楚, 导致了 BUG. ...
- Nginx配置详解 http://www.cnblogs.com/knowledgesea/p/5175711.html
Nginx配置详解 序言 Nginx是lgor Sysoev为俄罗斯访问量第二的rambler.ru站点设计开发的.从2004年发布至今,凭借开源的力量,已经接近成熟与完善. Nginx功能丰富,可作 ...