首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JavaScript测试教程–part 4:模拟 API 调用和模拟 React 组件交互

你将学到两种方法,开始吧! 模拟 对于我们的程序来说,从 API 获取一些数据是很常见的。但是它可能由于各种原因而失败,例如 API 被关闭。我们希望测试可靠且独立,并确保可以模拟某些模块。...spyOn 函数返回一个 mock函数。有关其功能的完整列表,请阅读文档。我们的测试检查组件在渲染和运行之后是否从模拟中调用 get函数,并成功执行。...你还可以通过在 package.json 文件中添加以下代码段来使其成为默认行为: "jest": { "clearMocks": true } 模拟获取 API 另一个常见情况是使用 Fetch...一个窍门是它是附加到 window 对象的全局函数并对其进行模拟,可以将其附加到 global 对象。首先,让我们创建模拟的 fetch 函数。.../__mocks__/fetch'; global.fetch = fetch; configure({adapter: new Adapter()}); 注意,你需要在 package.json

3.7K10

React学习(九)-React中发送Ajax请求以及Mock数据

撰文 | 川川 前言 在React中,render函数返回的结果,取决于组件的props和state 我们都知道UI页面上的数据不是写死的,往往是从后端的数据接口中拿到的 然后将真实的数据填充到页面上...但是官方推荐放在componentDidMount这个生命周期函数中发起Ajax请求,因为执行这个生命周期时,DOM已经挂载完了 这样做可以拿到Ajax请求返回的数据并通过setState来更新组件...()方法将字符串转化为json对象 const { goodlists } = JSON.parse(res); this.setState({ list...字符串格式,你需要用JSON.parse()的方式 将json字符串,转化为json对象,然后做处理的 如果你是使用axios的方式请求数据,那么是不用进行json序列的格式化的 小结 在React中请求数据的几种方式...axios(普遍常用) fetch方法(尝鲜,显逼格用) jquery Ajax(不推荐使用) request(常用,仅次于axios使用频率) 注意:都是放在componentDidMount函数中进行数据请求的

4.7K31
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    React基础(9)-React中发送Ajax请求以及Mock数据

    image.png 前言 在React中,render函数返回的结果,取决于组件的props和state 我们都知道UI页面上的数据不是写死的,往往是从后端的数据接口中拿到的 然后将真实的数据填充到页面上...Ajax请求返回的数据并通过setState来更新组件 componentDidMount(){    // 在这里进行Ajax数据请求,axios,fetch,jquery Ajax或者request...()方法将字符串转化为json对象         const { goodlists } = JSON.parse(res);         this.setState({            list...字符串格式,你需要用JSON.parse()的方式 将json字符串,转化为json对象,然后做处理的 如果你是使用axios的方式请求数据,那么是不用进行json序列的格式化的 小结 在React中请求数据的几种方式...axios(普遍常用) fetch方法(尝鲜,显逼格用) jquery Ajax(不推荐使用) request(常用,仅次于axios使用频率) 注意:都是放在componentDidMount函数中进行数据请求的

    2.2K30

    【JS 口袋书】第 8 章:以更细的角度来看 JS 中的 this

    即使在全局上下文中调用函数,隐式绑定也在起作用 function whoIsThis() { console.log(this); } whoIsThis(); 咱们无法从代码中看出,但是JS引擎将该函数分配给全局对象...用于的显式绑定(规则3):显式绑定指显示地将this绑定到一个上下文。但为什么要显式绑定或重新绑定函数呢?...只要咱们从构造函数中创建一个新对象,就会有一个针对REST API的Fetch请求: "use strict"; function Post(id) { this.data = []; fetch...箭头函数将this指向其封闭的环境(也称“词法作用域”)。换句话说,箭头函数并不关心它是否在window对象中运行。它的封闭环境是对象post1,以post1为宿主。...隐式绑定表示当一个函数引用 this 并作为 JS 对象的一部分运行时,this 将指向这个“宿主”对象。但 JS 函数总是在一个对象中运行,这是任何全局函数在所谓的全局作用域中定义的情况。

    2.7K20

    React入门看这篇就够了

    ,就是一个组件的生命周期 组件生命周期函数的定义:从组件被创建,到组件挂载到页面上运行,再到页面关闭组件被卸载,这三个阶段总是伴随着组件各种各样的事件,那么这些事件,统称为组件的生命周期函数!...,子组件调用函数将数据作为参数传递给父组件 兄弟组件:因为React是单向数据流,因此需要借助父组件进行传递,通过父组件回调函数改变兄弟组件的props React中的状态管理: flux(提出状态管理的思想...fetch() 方法返回一个Promise对象 fetch 基本使用 fetch Response fetch 介绍 Javascript 中的神器——Promise /* 通过fetch请求回来的数据...fetch('/api/movie/' + this.state.movieType) // response.json() 读取response对象,并返回一个被解析为JSON格式的promise...('/api/movie/in_theaters') .then(function(data) { // 将服务器返回的数据转化为 json 格式 return data.json(

    4.6K30
    领券