1-3 组件和组件状态

本文介绍了React中的事件绑定方法(内联、单独函数),组件状态的使用,以及如何通过useState管理简单和复杂类型状态的修改。
摘要由CSDN通过智能技术生成

1、React事件绑定

代码:

const handleClick = (e) => {

  e.preventDefault();

  alert("跳转到百度页面");

};

root.render(

  <div>

    {/* 1、时间绑定 */}

    <div

      className="box"

      onClick={() => {

        alert("你好");

      }}

    ></div>

    {/* 2、事件对象 */}

    {/* <a

      href="https://www.baidu.com"

      onClick={(e) => {

        e.preventDefault();

        alert("跳转到百度页面");

      }}

    >

      百度

    </a> */}

    {/* 3、使用单独创建的事件处理程序函数 */}

    <a href="https://www.baidu.com" onClick={handleClick}>

      百度

    </a>

  </div>

);

2、React组件

3、组件的状态

代码:

// 组件的状态

const App = () => {

  const [count, setCount] = useState(10);

  return (

    <div>

      <h1>计数器:{count}</h1>

      <button onClick={() => setCount(count + 1)}>+1</button>

    </div>

  );

};

export default App;

4、修改状态的规则

代码:

const App = () => {

  const [count, setCount] = useState(10);

  const [list, setList] = useState(["app", "orange"]);

  const [user, setUser] = useState({ name: "zs", age: 18 });

  return (

    <div>

      <h1>简单类型:{count}</h1>

      <button onClick={() => setCount(count + 1)}>修改</button>

      <hr></hr>

      <h1>复杂类型-数组</h1>

      <div>{list.join(",")}</div>

      <button

        onClick={() => {

          setList([...list, "ccc"]);

        }}

      >

        添加

      </button>

      <button

        onClick={() => {

          setList(list.filter((item) => item !== "orange"));

        }}

      >

        删除

      </button>

      <button

        onClick={() => {

          setList(

            list.map((item) => {

              if (item == "app") {

                return "苹果";

              }

              return item;

            })

          );

        }}

      >

        修改

      </button>

      <hr></hr>

      <h1>复杂类型-对象</h1>

      <div>

        姓名:{user.name}年龄:{user.age}

      </div>

      <button onClick={() => setUser({ ...user, name: "ls" })}>修改</button>

    </div>

  );

};

export default App;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值