热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

React第三方组件2(状态管理之Refast的使用③扩展ctx)

本教程总共5篇,每日更新一篇,请关注我们!你可以进入历史消息查看以往文章,也敬请期待我们的新文章!1、React第三方组件2(状态管理之Refast的使用①简单


本教程总共5篇,每日更新一篇,请关注我们!你可以进入历史消息查看以往文章,也敬请期待我们的新文章!


1、React第三方组件2(状态管理之Refast的使用①简单使用)---2018.01.29


2、React第三方组件2(状态管理之Refast的使用②异步修改state)---2018.01.30


3、React第三方组件2(状态管理之Refast的使用③扩展ctx)---2018.02.31


4、React第三方组件2(状态管理之Refast的使用④中间件middleware使用)---2018.02.01


5、React第三方组件2(状态管理之Refast的使用⑤LogicRender使用)---2018.02.02


开发环境:Windows 8,node v8.9.1,npm 5.5.1,WebStorm 2017.2.2


我们今天讲下扩展ctx。

为什么要扩展ctx?

比如说你异步请求会有个加载提示,或者说请求成功给个提示!


我们今天要做的就是请求成功后给个提示,失败也会给个提示!


1、我们先建一个提示组件  Toast.jsx

在 app -> common -> 新建 layer 文件夹 -> 新建 Toast.jsx

import React from 'react';

class Toast extends React.Component {
constructor(props) {
super(props);
       this.state = {
show: false,
           text: ''
       };
   }

show(text) {
this.setState({show: true, text: text}, () => setTimeout(() => this.setState({show: false}), 2000))
}

render() {
let {show, text} = this.state;
       return [
show ?
className="layer toast" key="toast">{text}

               :
null
       ];
   }
}

export default Toast;

2、添加样式

.layer {
&.toast {
background-color: rgba(0, 0, 0, 0.6);
   color: #ffffff;
   width: auto;
   padding: 5px 10px;
   border-radius: 4px;
   position: absolute;
   top: 50%;
   left: 50%;
   transform: translate(-50%, -50%);
 }
}

3、导出这个组件

layer -> Index.jsx

import Toast from './Toast'

export {Toast}

4、在demo5 中,修改 TodoList.jsx

import {Toast} from '../../common/layer';
ref={e => Refast.use('fn', {Toast: e})}/>

完整代码

import React from 'react';
import Refast, {Component} from 'refast';
import {Toast} from '../../common/layer';
// 引入 logic.js
import logic from './logic';
import List from './List';
import '../../../public/css/todoList.pcss';

class TodoList extends Component {
constructor(props) {
super(props, logic);
   }

componentDidMount() {
this.dispatch('getTodoList');
   }

render() {
let {list} = this.state, {dispatch} = this;
       return (
className="todoList">
               type="text" ref="todoInput"/>
               
               
className="cont">
                   
className="box">
                       全部
type={0} list={list} dispatch={dispatch}/>
                   

                   
className="box">
                       未删除
type={1} list={list} dispatch={dispatch}/>
                   

                   
className="box">
                       已删除
type={2} list={list} dispatch={dispatch}/>
                   

               

               ref={e => Refast.use('fn', {Toast: e})}/>
           

       );
   }
}

export default TodoList;


5、修改 logic.js

async getTodoList({setState,fn}) {
let todoList = await apiRequestAsync.post('todoList');
   fn.Toast.show('操作成功');
   setState({list: todoList.list})
}


6、看下浏览器效果

7、处理下 错误提示


async getTodoList({setState,fn}) {
let todoList = {};
   try {
todoList = await apiRequestAsync.post('todoList');
       fn.Toast.show('操作成功');
       setState({list: todoList.list})
} catch (error) {
fn.Toast.show('操作失败');
   }
}

修改下 mock 下的 todoList.js

8、看下浏览器

OK 异常也捕获到了!

9、还可以这样写

如果要提示服务端返回的错误应该如何写?

10、再看下浏览器


OK,提示的是 服务端返回错误信息!

 那这是为什么呢?

主要看这里

本文完 

禁止擅自转载,如需转载请在公众号中留言联系我们!

感谢童鞋们支持!

如果你有什么问题,可以在下方留言给我们!


推荐阅读
  • 深入理解CSS中的margin属性及其应用场景
    本文主要介绍了CSS中的margin属性及其应用场景,包括垂直外边距合并、padding的使用时机、行内替换元素与费替换元素的区别、margin的基线、盒子的物理大小、显示大小、逻辑大小等知识点。通过深入理解这些概念,读者可以更好地掌握margin的用法和原理。同时,文中提供了一些相关的文档和规范供读者参考。 ... [详细]
  • Ihavethefollowingonhtml我在html上有以下内容<html><head><scriptsrc..3003_Tes ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 本文介绍了在wepy中运用小顺序页面受权的计划,包含了用户点击作废后的从新受权计划。 ... [详细]
  • JavaScript和HTML之间的交互是经由过程事宜完成的。事宜:文档或浏览器窗口中发作的一些特定的交互霎时。能够运用侦听器(或处置惩罚递次来预订事宜),以便事宜发作时实行相应的 ... [详细]
  • React基础篇一 - JSX语法扩展与使用
    本文介绍了React基础篇一中的JSX语法扩展与使用。JSX是一种JavaScript的语法扩展,用于描述React中的用户界面。文章详细介绍了在JSX中使用表达式的方法,并给出了一个示例代码。最后,提到了JSX在编译后会被转化为普通的JavaScript对象。 ... [详细]
  • CSS3选择器的使用方法详解,提高Web开发效率和精准度
    本文详细介绍了CSS3新增的选择器方法,包括属性选择器的使用。通过CSS3选择器,可以提高Web开发的效率和精准度,使得查找元素更加方便和快捷。同时,本文还对属性选择器的各种用法进行了详细解释,并给出了相应的代码示例。通过学习本文,读者可以更好地掌握CSS3选择器的使用方法,提升自己的Web开发能力。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • springmvc学习笔记(十):控制器业务方法中通过注解实现封装Javabean接收表单提交的数据
    本文介绍了在springmvc学习笔记系列的第十篇中,控制器的业务方法中如何通过注解实现封装Javabean来接收表单提交的数据。同时还讨论了当有多个注册表单且字段完全相同时,如何将其交给同一个控制器处理。 ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
  • 本文介绍了南邮ctf-web的writeup,包括签到题和md5 collision。在CTF比赛和渗透测试中,可以通过查看源代码、代码注释、页面隐藏元素、超链接和HTTP响应头部来寻找flag或提示信息。利用PHP弱类型,可以发现md5('QNKCDZO')='0e830400451993494058024219903391'和md5('240610708')='0e462097431906509019562988736854'。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
author-avatar
泥土人走泥u加水
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有