框架结构和砖混结构的区别_react框架官网

框架结构和砖混结构的区别_react框架官网实现:创建四个组件,分别是头组件,尾组件,list组件,item组件,存在于这个mvc中的。在APP.js中分别引入前三个个组件(item组件是存在于list中的,所以在list中引入item组件)在app.js中写好初始数据,在list中显示出来const{todos}=this.propsreturn(<ul>{todos.map(todo=>{return<Itemkey={

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

实现:

创建四个组件,分别是头组件,尾组件,list组件,item组件,存在于这个mvc中的。

在APP.js中分别引入前三个个组件(item组件是存在于list中的,所以在list中引入item组件)

在app.js中写好初始数据,在list中显示出来

 const {todos} = this.props 
   return(
    <ul>
    {
        todos.map(todo=>{
            return <Item key={todo.id} {...todo}></Item>
        })
    }
    </ul>
   )

在app中的组件引入数据

 const {todos} = this.state

 <List todos={todos}   deleteTodo={this.deleteTodo}></List>

至此,实现显示初始数据。

接着实现增添数据:1.在头部判断输入的东西是否为空,用到trim(),判空,如果为空,那么弹窗警告“不允许输入空消息”,2.输入后按回车(不为空的情况下)后数据出现到list中。 判断之后直接触发直击app中state数据的增添方法。

 <Header addTodo={this.addTodo}></Header>
 handleKeyup=(event)=>{
    const {keyCode,target} = event 
    if(keyCode!==13) return 
    if(target.value.trim() ===""){
      alert("输入内容不能为空")
      return 
    }
    const todoObj = {
      id:nanoid(),
      name:target.value,
      done:false
    }
    this.props.addTodo(todoObj)
    target.value = ""
  }
 render(){
   return(
     <div>
      Header
      <input placeholder="请输入,按enter结束" onKeyUp={this.handleKeyup}/>
     </div>
   )
 }

在头部输入后按回车后调用下面的方法: 

  addTodo=(todoObj)=>{
    const {todos} = this.state
    const newTodos = [todoObj,...todos]
    this.setState({todos:newTodos})
   }

尾部的已完成项目与未完成项目,如果done状态时true,那就是完成的(+1),false那就未完成(+0)

 const {todos} = this.props
   const total = todos.length
   const doneTotal = todos.reduce((acc,todo)=>acc+(todo.done ? 1:0),0)
   return(
     <div>
     <label>
     <input type="checkbox" onChange={this.handleCheckAll}/>
     </label>
     <span>已完成{doneTotal}/全部{total}</span>
     <button onClick={this.handleClearAllDone}>清楚全部已完成项目</button>
     </div>
   )

删除这条消息:
如果每次删除都要从第一个开始遍历到最后一个的话,那太浪费性能了,所以我们用filter过滤方法,只过滤掉我们点击要删除的消息。

流程:点击删除按钮,弹窗显示:确定真的删除嘛?(该判断弹窗用confirm属性)如果确定删除则过滤掉这条消息,触发在app中的直击state数据的删除方法。

 handleDelete=(id)=>{
      if(window.confirm("确定删除???")){
        this.props.deleteTodo(id)
      }
    }
    render(){
     const {id,name,done} = this.props 
   return(
    <li>
    <label>
    <input type="checkbox" checked={done} onChange={this.handleCheck}/>
    <span>{name}</span>
    </label>
    <button onClick={()=>this.handleDelete(id)}>删除</button>
    </li>
   )

 

deleteTodo=(id)=>{
    const {todos} = this.state
    const newTodos = todos.filter(todoObj=>{
      return todoObj.id !== id
    })
    this.setState({
      todos : newTodos
    })
  }

(记得把方法在app中传入相对应的组件中)

先写到这里啦,先实现了一小部分功能,没有写样式呢,关注看后续哦,我会继续更新的~

 

 

 

 

 

 

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/194732.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 【技术分享】Python3升级pip3[通俗易懂]

    【技术分享】Python3升级pip3[通俗易懂]python3升级pip相关指令错误命令1:错误命令2:正确命令:因为python默认升级pip的命令是:pipinstall–upgradepip,那python3应该如何升级呢(尤其是当系统中同时含有python2.7和python3的时候)错误命令1:pip3install–upgradepip错误命令2:pip3install–upgradepip3正确命令:python3-mpipinstall–upgradepip因提示permiss

    2025年8月19日
    3
  • shell:修改变更值[通俗易懂]

    shell:修改变更值[通俗易懂]#catconfd-general-config.confETCD_SERVER_HOSTIP=192.168.3.103ETCD_SERVER_PORT=2379innernetworksegement=192.168.3pgconn=10.47.245.110:13306,10.47.245.110:23306kafkaconn=10.47.223.223:9090,10…

    2022年7月11日
    26
  • 二项式分布和超几何分布有什么区别_多项分布的协方差

    二项式分布和超几何分布有什么区别_多项分布的协方差原文转自:http://hi.baidu.com/leifenglian/item/636198016851cee7f55ba652一、前言参数估计是一个重要的话题。对于典型的离散型随机变量分布:二项式分布,多项式分布;典型的连续型随机变量分布:正态分布。他们都可以看着是参数分布,因为他们的函数形式都被一小部分的参数控制,比如正态分布的均值和方差,二项式分布事件发生的概

    2022年10月9日
    4
  • xshell7安装步骤_快影下载安装

    xshell7安装步骤_快影下载安装文章目录第一部分下载第一步去官方下载界面第二步填写正确的手机号和密码,之后会有一个下载链接第二部分安装过程第一步双击exe文件,进入安装界面第二步接受统一许可证书第三步选择安装的路径第四步随便选一个图面的目录第五步进行安装界面,等待安全完成第三部分设置ssh配置连接第一步设置名称、主机、端口第二步设置链接方式,我选的账号和密码第三步选择接受密钥第四步成功链接主机摘抄第一部分下载第一步去官方下载界面https://www.xshellcn.com/xiazai.html

    2025年10月12日
    2
  • JVM – 彻底理解打破双亲委派机制

    文章目录Pre双亲委派何为打破双亲委派演示Pre双亲委派JVM-白话聊一聊JVM类加载和双亲委派机制源码解析JVM-自定义类加载器何为打破双亲委派举个例子有个类Artisan我们希望通过自定义加载器直接从某个路径下读取Artisan.class.而不是说通过自定义加载器委托给AppClassLoader——>ExtClassLoader—->BootClassLoader这么走一遍,都没有的话,才让自定义加载器去加载Artis

    2022年4月8日
    76
  • 系统临时文件的写和读:createTempFile和tempFileContent[通俗易懂]

    写java的时候,有时候查到的数据暂时用不到,我们可以把它写到一个临时文件中。今天写项目的时候发现了这个好方法。将context的内容写到临时文件@PostMapping("/temp")@ResponseBodyStringtemp(@RequestParamStringcontent)throwsIOException{FiletempFil…

    2022年4月11日
    48

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号