【跨端技术】React Native学习记录一

文章目录

  • [一. 官方文档学习](#一. 官方文档学习)
    • [1. 环境搭建](#1. 环境搭建)
    • [2. 函数式组件和class组件](#2. 函数式组件和class组件)
    • [3. React 基础](#3. React 基础)
      • [3.1 JSX语法定义一个组件](#3.1 JSX语法定义一个组件)
      • [3.2 Props 属性](#3.2 Props 属性)
      • [3.3 State 状态](#3.3 State 状态)
      • [4. 处理文本输入](#4. 处理文本输入)

记录RN的入坑记录,零散笔记

一. 官方文档学习

官方文档

1. 环境搭建

资料1
资料2

2. 函数式组件和class组件

函数式组件和 Class 组件是 React 中定义组件的两种主要方式,它们在语法、功能和使用场景上有一些区别。

  • 函数式组件(Functional Component)
    函数式组件是一个简单的 JavaScript 函数,接收一个 props 对象作为参数,并返回一个 React 元素。它是定义组件的最简单方式。
xml 复制代码
function Welcome(props) {
  return <h1>Hello, {props.name}</h1>;
}
  • Class 组件(Class Component)
    Class 组件是通过继承 React.Component 类来定义的,它需要实现 render() 方法来返回 React 元素。
xml 复制代码
class Welcome extends React.Component {
  render() {
    return <h1>Hello, {this.props.name}</h1>;
  }
}

3. React 基础

添加链接描述

3.1 JSX语法定义一个组件

javascript 复制代码
import React from 'react';
import { Text } from 'react-native';

const Cat = () => {
  return (
    <Text>Hello, I am your cat!</Text>
  );
}

export default Cat;

在别处通过来任意引用这个组件了

3.2 Props 属性

javascript 复制代码
import React from 'react';
import { Text, View } from 'react-native';

const Cat = (props) => {
  return (
    <View>
      <Text>Hello, I am {props.name}!</Text>
    </View>
  );
}

const Cafe = () => {
  return (
    <View>
      <Cat name="Maru" />
      <Cat name="Jellylorum" />
      <Cat name="Spot" />
    </View>
  );
}

export default Cafe;

3.3 State 状态

如果把 props 理解为定制组件渲染的参数, 那么state就像是组件的私人数据记录。状态用于记录那些随时间或者用户交互而变化的数据。状态使组件拥有了记忆!

javascript 复制代码
import React, { useState } from "react";
import { Button, Text, View } from "react-native";

const Cat = (props) => {
  const [isHungry, setIsHungry] = useState(true);

  return (
    <View>
      <Text>
        I am {props.name}, and I am {isHungry ? "hungry" : "full"}!
      </Text>
      <Button
        onPress={() => {
          setIsHungry(false);
        }}
        disabled={!isHungry}
        title={isHungry ? "Pour me some milk, please!" : "Thank you!"}
      />
    </View>
  );
}

const Cafe = () => {
  return (
    <>
      <Cat name="Munkustrap" />
      <Cat name="Spot" />
    </>
  );
}

export default Cafe;

4. 处理文本输入

相关推荐
一定要AK3 小时前
刷题时的学习笔记
c++·笔记·学习
尘中客5 小时前
放弃 Echarts?前端直接渲染后端高精度 SVG 矢量图流的踩坑记录
前端·javascript·echarts·前端开发·svg矢量图·echarts避坑
xxxibolva5 小时前
SQL 学习
数据库·sql·学习
2501_916007475 小时前
网站爬虫原理,基于浏览器点击行为还原可接口请求
前端·javascript·爬虫·ios·小程序·uni-app·iphone
Highcharts.js7 小时前
适合报表系统的可视化图表|Highcharts支持直接导出PNG和PDF
javascript·数据库·react.js·pdf
叫我一声阿雷吧7 小时前
JS 入门通关手册(35):执行上下文、调用栈与作用域链深度解析
javascript·作用域链·js进阶·执行上下文·调用栈·变量提升·闭包原理
星辰即远方7 小时前
OC学习Foudation框架
学习·ios·objective-c
M ? A8 小时前
解决 VuReact 中 ESLint 规则冲突的完整指南
前端·react.js·前端框架
yyk的萌8 小时前
AI 应用开发工程师基础学习计划
开发语言·python·学习·ai·lua
Amumu121389 小时前
Js:正则表达式(一)
开发语言·javascript·正则表达式