React 相关

创建 React App

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

JSX 语法

JSX 语法里面,有两种类型的标签

  1. 普通的 html 标签
<div></div>
<p></p>
<span></span>
  1. 组件标签
<App />

组件标签首字母必须大写

JSX 使用时最外层只能有一个标签

// index.js
ReactDom.render(<div><App /><Test /></div>, document.getElementById('root'));
// App.js
class App extends Component {
	render() {
		return (
			<div>
				<input />
				<ul>
					<li>learn React</li>
					<li>learn Vue</li>
				</ul>
			</div>
		);
	}
}

有时代码结构要求不能在最外层添加div,这时可以用占位符标签 Fragment

// App.js
import React, { Component, Fragment } from 'react';
class App extends Component {
	render() {
		return (
			<Fragment>
				<input />
				<ul>
					<li>learn React</li>
					<li>learn Vue</li>
				</ul>
			</Fragment>
		);
	}
}

数据绑定

React 是由数据驱动的,所以不要以 DOM 为关注点

// TodoList.js
import React, { Component, Fragment } from 'react';

class TodoList extends Component {
  constructor(props) {		// 固定形式
    super(props);			// 固定形式
    this.handleInputChange = this.handleInputChange.bind(this);			// 调用方法的 this 为 undefined 所以需要用 bind 来指定 this 指向类
    this.handleKeyUp = this.handleKeyUp.bind(this);
    this.state = {			// 数据规定写在 state 里面
      inputValue: '',
      list: []
    }
  }
  handleKeyUp(e) {
    if (e.keyCode === 13 && e.target.value !== '') {
      const list = [...this.state.list, this.state.inputValue];
      this.setState({ list, inputValue: '' });
    }
  }
  handleInputChange(e) {
    this.setState({
      inputValue: e.target.value
    });
  }
  handleItemDel(index) {
    const list = [...this.state.list];
    list.splice(index, 1);
    this.setState({ list });
  }
  getListItem() {
    return this.state.list.map((value, index) => {
      return <li key={index} onClick={this.handleItemDel.bind(this, index)}>{value}</li>;
    })
  }
  render() {
    return (
      <Fragment>	// 仅占位,不在页面中显示
        <input value=  {this.state.inputValue} onChange={this.handleInputChange} onKeyUp={this.handleKeyUp}/>
        <ul>
          { this.getListItem() }
        </ul>
      </Fragment>
    );
  }
}

export default TodoList;

JSX 语法细节

  • JSX 语法在用到 class 时,需要改成 className,因为要避免和类的 class 相混淆
  • JSX 语法在用到 label 的 for 时,要用 htmlFor
<label htmlFor="myinput"></label><input id="myinput" />
  • JSX语法中添加注释,要加 {}
{/* 这是一个 JSX 语法中的注释 */}
  • input 中的输入,不经转义直接输出
    例如 <h1></h1> 直接显示为大字体的格式,这时
    应该用 dangerouslySetInnerHTML 属性
...
getListItem() {
    return this.state.list.map((value, index) => {
      return <li key={index} onClick={this.handleItemDel.bind(this, index)} dangerouslySetInnerHTML={{__html: value}}></li>;
    })
  }
  ...

组件之间的传值

父组件通过属性的形式向子组件传值
// 父组件中通过属性向子组件传值
<TodoItem content={value} />
// 子组件中通过 this.props 接收父组件传过来的值
render() {
	return <li>{this.props.content}</li>
}

render 函数执行时间

  1. 当组件初次创建的时候,render 函数会被执行一次
  2. 当 state 数据发生变更的时候,render 函数会被重新执行
  3. 当 props 数据发生变更的时候,render函数会被重新执行

ref 的使用

  • ref 写在 html 标签上,获取的是 dom 节点
  • ref 写在组件标签上,获取的是组件的 js 实例
<button ref={(button) => { this.buttonElem = button } }></button>	// 获取元素绑定到实例上

setState 异步造成的一些问题

如果希望改变完数据之后才执行可以用一下写法

this.setState(() => {
	return {
		counter: newCounter
	}
}, () => {
	// 改变完数据之后执行的代码
});

生命周期函数

在 React 中,生命周期函数指的是组件在某一时刻会自动执行的函数

render() 就是生命周期函数

在这里插入图片描述
shouldComponentUpdate() 需要返回值,默认为 true ,如果为 true 则接下来的生命周期函数执行,如果为 false,则接下来的生命周期函数不执行

ajax 请求应放在 componentDidMount() 生命周期函数中

Ant Design

是 React 的一个组件库,具体使用方法见官网

路由

安装

npm install react-router-dom --save

使用

import React, { Component } from 'react';
import ReactDom from 'react-dom';
import { BrowserRouter, Route } from 'react-router-dom';	// 引入
import Antd from './Antd';
import Father from './Father';
import "antd/dist/antd.css";

class Entry extends Component {
  render() {
    return (
      // 使用 
      <BrowserRouter>
        <div>
          <Route path="/antd" component={Antd}></Route>
          <Route path="/father" component={Father}></Route>
        </div>
      </BrowserRouter>
    );
  }
}

ReactDom.render(<Entry />, document.getElementById('root'))

路由跳转

import React, { Component } from 'react';
import { Button } from 'antd';
import { Link } from 'react-router-dom';		// 引入 Link

class Antd extends Component {
  render() {
    return (
      <Link to="/father">		// 跳转
        <Button type="primary" style={{marginLeft: 20}}>按钮</Button>
      </Link>
    );
  }
}

export default Antd;

路由携带参数

// 跳转时携带参数
<Link to="/father?a=123">
  <Button type="primary" style={{marginLeft: 20}}>按钮</Button>
</Link
// 获取
console.log(this.props.location.search);	// ?a=123
// 路由配置
<BrowserRouter>
  <div>
    <Route path="/antd" component={Antd}></Route>
    <Route path="/list/:id" component={newList}></Route>
  </div>
</BrowserRouter>
// 跳转时携带的参数
<Link to="/father/123">
  <Button type="primary" style={{marginLeft: 20}}>按钮</Button>
</Link
// 获取
console.log(this.props.match.params.id);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ava实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),可运行高分资源 Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现的毕业设计&&课程设计(包含运行文档+数据库+前后端代码),Java实现
C语言是一种广泛使用的编程语言,它具有高效、灵活、可移植性强等特点,被广泛应用于操作系统、嵌入式系统、数据库、编译器等领域的开发。C语言的基本语法包括变量、数据类型、运算符、控制结构(如if语句、循环语句等)、函数、指针等。下面详细介绍C语言的基本概念和语法。 1. 变量和数据类型 在C语言中,变量用于存储数据,数据类型用于定义变量的类型和范围。C语言支持多种数据类型,包括基本数据类型(如int、float、char等)和复合数据类型(如结构体、联合等)。 2. 运算符 C语言中常用的运算符包括算术运算符(如+、、、/等)、关系运算符(如==、!=、、=、<、<=等)、逻辑运算符(如&&、||、!等)。此外,还有位运算符(如&、|、^等)和指针运算符(如、等)。 3. 控制结构 C语言中常用的控制结构包括if语句、循环语句(如for、while等)和switch语句。通过这些控制结构,可以实现程序的分支、循环和多路选择等功能。 4. 函数 函数是C语言中用于封装代码的单元,可以实现代码的复用和模块化。C语言中定义函数使用关键字“void”或返回值类型(如int、float等),并通过“{”和“}”括起来的代码块来实现函数的功能。 5. 指针 指针是C语言中用于存储变量地址的变量。通过指针,可以实现对内存的间接访问和修改。C语言中定义指针使用星号()符号,指向数组、字符串和结构体等数据结构时,还需要注意数组名和字符串常量的特殊性质。 6. 数组和字符串 数组是C语言中用于存储同类型数据的结构,可以通过索引访问和修改数组中的元素。字符串是C语言中用于存储文本数据的特殊类型,通常以字符串常量的形式出现,用双引号("...")括起来,末尾自动添加'\0'字符。 7. 结构体和联合 结构体和联合是C语言中用于存储不同类型数据的复合数据类型。结构体由多个成员组成,每个成员可以是不同的数据类型;联合由多个变量组成,它们共用同一块内存空间。通过结构体和联合,可以实现数据的封装和抽象。 8. 文件操作 C语言中通过文件操作函数(如fopen、fclose、fread、fwrite等)实现对文件的读写操作。文件操作函数通常返回文件指针,用于表示打开的文件。通过文件指针,可以进行文件的定位、读写等操作。 总之,C语言是一种功能强大、灵活高效的编程语言,广泛应用于各种领域。掌握C语言的基本语法和数据结构,可以为编程学习和实践打下坚实的基础。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值