IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> React基本使用JSX事件 -> 正文阅读

[JavaScript知识库]React基本使用JSX事件

要使用React需要引入React所对应的文件
这两个标签就是加载react

<script src="https://unpkg.com/react@17/umd/react.development.js" crossorigin></script>
<script src="https://unpkg.com/react-dom@17/umd/react-dom.development.js" crossorigin></script>

基本使用
reactDOM提供了与浏览器交互的DOM功能,渲染DOM,虚拟DOM
ReactDOM.render() 中有三个参数
第一:要渲染的内容
第二:要渲染的内容存放的容器
第三:渲染后的回调函数,可选参数

<!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>
    <script src="https://unpkg.com/react@17/umd/react.development.js" crossorigin></script>
    <script src="https://unpkg.com/react-dom@17/umd/react-dom.development.js" crossorigin></script>
    <script src="like_button.js"></script>
</head>
<body>
    <!-- react.js 提供核心代码 -->
    <div id="root"></div>
    <script>
        // raactDOM  提供了与浏览器交互的DOM功能,如虚拟DOM,渲染DOM
        // reactDOM.render(三个参数)
        ReactDOM.render(
            // 渲染的内容
            "今天是阴天",
            // 要渲染内容要存放的容器
            document.querySelector('#root'),
            // 渲染后的回调函数,可选参数
            ()=>{
                console.log('ok')
            }
        )
    </script>
</body>
</html>

动态创建视图标签
React.createElement 三个参数{传入HTML标签名,表示属性类型,要显示的内容}

<body>
    <div id="root"></div>
    <script>**加粗样式**
        //  React.createElement 三个参数{传入HTML标签名,表示属性类型,要显示的内容}
        let h1 = React.createElement('h1',null,'React')
        let q = React.createElement('h2',null,'React')
        let el = React.createElement(
            'header',
            {id:"className"},
            h1,
            q)
        ReactDOM.render(
            // 渲染的内容
            el,
            document.querySelector('#root'),
            ()=>{
                console.log('ok')
            }
        )
    </script>
</body>

JSX

引入

<script src="https://unpkg.com/babel-standalone@6/babel.min.js"></script>

使用

<!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>
    <script src="https://unpkg.com/react@17/umd/react.development.js" crossorigin></script>
    <script src="https://unpkg.com/react-dom@17/umd/react-dom.development.js" crossorigin></script>
    <!-- <script src="like_button.js"></script> -->
    <script src="https://unpkg.com/babel-standalone@6/babel.min.js"></script>
</head>
<body>
    <div id="root"></div>
    <script type="text/babel">
    let str = "蛇精"     
        ReactDOM.render(       
            <h1>
                <p>葫芦小金刚</p>
                <p>{str}</p>
                </h1>,          
            document.querySelector('#root'),
            ()=>{
                console.log('ok')
            }
        )
    </script>
</body>
</html>

JSX注意点

 <div id="root"></div>
    <script type="text/babel">   
    // class类型名 要写成className,
    // style 接受的是一个对象,并不是字符串
    // 每次只能输出一个标签(或者是必须要有一个跟标签)
    // 唯一父级,
    // jsx不能与js语句一起使用,所有标签都得闭合,标签名必须小写
          ReactDOM.render(
            <div>
                <div className="box" style={{width:'300px'}}></div>
                </div>,
            document.querySelector('#root')
          ) 

React组件使用下载安装

npx create-react-app my-app
cd my-app
npm start

组件的创建方式

类组件:
1.组件类必须继承 React.Component
2.组件类必须有render方法
3.render 方法的return 后定义组件的内容
最后记得导出

import React from "react";
class Family extends React.Component{
    render(){
      return  (<div>
            <ul>
                <li>one</li>
                <li>two</li>
                <li>three</li>
            </ul>
        </div>)
    }
};
export default Family

显示直接引入,单标签使用双标签也ok

import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
import reportWebVitals from './reportWebVitals';

ReactDOM.render(
  <App/>,//使用
//  '啦啦啦啦',
  document.getElementById('root')
);
reportWebVitals();

React事件处理

state
改变state必须通过setState

import React,{Component} from "react";
import Family from "./family";
class App extends Component{
  state = {
    hEight:174
  }
  tianjia(){
    this.setState({
      hEight:this.state.hEight+1
    }) 
  }
  render(){
    // let {hEight} = this.state
    return (<div>hellow,REACT
        <Family/>
        <p>{this.state.hEight}</p>
        <button onClick={
          ()=>{
            // this.setState({
            //   hEight:hEight+1
            // })
            this.tianjia()
          }
        }>点我变高</button>
    </div>)
  }
};
export default App;
 

防止this指向问题
解决
第一:

 tianjia()=>(){
    this.setState({
      hEight:this.state.hEight+1
    }) 
  }

第二:箭头函数调用

      ()=>{
            this.tianjia()
          }

建议直接使用第一种

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-07-27 16:07:20  更:2021-07-27 16:10:32 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/6 4:32:26-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码