首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    React Router v4 完全指北

    React Router 事实上是React官方的标准路由库。当你在一个多视图的React应用中来回切换,你需要一个路由来管理那些URL。...那些习惯于多页应用的最终用户,期望在一个SPA中应该包含以下特性: 应用中每个视图都应该有对应的唯一URL用来区分视图。...动态生成的嵌套视图更应该有成对应的URL - 例如: example.com/products/shoes/101,101是产品id。 路由跳转是指在同步保持浏览器URL的过程中渲染页面中的视图。...Path and match path用来标识路由匹配的URL部分。React Router使用了Path-to-RegExp库将路径字符串转为正则表达式。然后正则表达式会匹配当前路径。...match对象有更多关于URL和path的信息。这些信息可以通过它的属性获取,如下所示: match.url.返回URL匹配部分的字符串。对于创建嵌套的 Link>很有用。

    2.8K20

    滴滴前端二面常考react面试题(持续更新中)_2023-03-01

    (3)使用 Link>、 、 组件 Link> 组件来在你的应用程序中创建链接。...无论你在何处渲染一个Link> ,都会在应用程序的 HTML 中渲染锚()。...(注:这里之所以多次 +1 最终只有一次生效,是因为在同一个方法中多次 setState 的合并动作不是单纯地将更新累加。比如这里对于相同属性的设置,React 只会为其保留最后一次的更新)。...这个问题就设计到了数据持久化, 主要的实现方式有以下几种: Redux: 将页面的数据存储在redux中,在重新加载页面时,获取Redux中的数据; data.js: 使用webpack构建的项目,可以建一个文件...,data.js,将数据保存data.js中,跳转页面后获取; sessionStorge: 在进入选择地址页面之前,componentWillUnMount的时候,将数据存储到sessionStorage

    4.5K10

    用 Jest 进行 JavaScript 测试

    测试分为三大类: 单元测试 集成测试 UI测试 在这个 Jest 教程中,我们将仅涵盖单元测试,但在文章的最后,你将找到更多用于其他类型测试的资源。 什么是Jest?...你可能想知道为什么扩展名是“.spec。”。这是一个借用 Ruby 的约定,用于将文件标记为给定功能的规范。 现在来测试吧! 测试结构和第一次失败的测试 现在创建你的第一次Jest测试。...每次开始为功能编写一套新测试时,都会将其包含在 describe 块中。正如你所看到的,它需要两个参数:一个用于描述测试套件的字符串,还有一个用于包装实际测试的回调函数。..., "link"); 在 Jest 测试中,你应该将函数调用包含在 expect 中,它与匹配器(用于检查输出的Jest函数)一起进行实际测试。...Jest 可以顺利地测试 React 应用(Jest 和 React 均来自 Facebook 的工程师)。Jest 也是 Create React App 中的默认测试器。

    2.7K30

    从零手写react-router_2023-03-01

    将一个字符串变成一个正则表达式 我们知道, react-router的大致原理就是根据路径的不同从而渲染不同的页面, 那么这个过程其实也就是路径A匹配页面B的过程, 所以我们之前会写这样的代码 将地址栏的path值取出来跟该正则表达式进行匹配, 匹配上了就要渲染相应的路由, 匹配不上就渲染其他的逻辑 path-to-regexp就是做这个事情的, 他把我们给他的路径字符串转换为正则表达式...这个是一个hoc, 他的作用非常简单, 就是将路由上下文作为属性注入到组件中 我们在react-router目录下新建一个withRouter.js import React from "react"..., 毕竟人家也就实现了一个无刷新跳转的功能 我们在react-router-dom里新建一个Link.js // react-router-dom/Link.js import React from "...下新建一个NavLink.js // react-router-dom/NavLink.js import React from "react"; import Link from ".

    1.4K30

    从零手写react-router

    将一个字符串变成一个正则表达式我们知道, react-router的大致原理就是根据路径的不同从而渲染不同的页面, 那么这个过程其实也就是路径A匹配页面B的过程, 所以我们之前会写这样的代码将地址栏的path值取出来跟该正则表达式进行匹配, 匹配上了就要渲染相应的路由, 匹配不上就渲染其他的逻辑path-to-regexp就是做这个事情的, 他把我们给他的路径字符串转换为正则表达式...毕竟人家也就实现了一个无刷新跳转的功能我们在react-router-dom里新建一个Link.js// react-router-dom/Link.jsimport React from "react...但是细节非常繁琐, 有非常多的因素需要去考虑到我觉得没必要), 这个库做的事情非常简单: 将一个字符串变成一个正则表达式我们知道, react-router的大致原理就是根据路径的不同从而渲染不同的页面...毕竟人家也就实现了一个无刷新跳转的功能我们在react-router-dom里新建一个Link.js// react-router-dom/Link.jsimport React from "react

    3.1K30

    在你学习 React 之前必备的 JavaScript 基础

    实际上这是 ES6 的一个新特性,这就是为什么正确学习 ES6 可以让你更好地理解 React 代码。 我们将从 ES6 的类开始。...在 React 中使用 现在我们了解了 ES6 的类和继承,我们可以理解 src/app.js 中定义的 React 类。...使用 ES6 中的 let 和 const 来声明变量 因为 JavaScript 的 var 关键字是声明全局的变量,所以在 ES6 中引入了两个新的变量声明来解决这个问题,即 let 和 const...我们还导入另一个 node 模块 react-dom,这使我们能够将 React 组件呈现为 HTML元素。...总结 React 的优点在于它不会像其他 Web 框架一样在 JavaScript 之上添加任何外部抽象层。 这就是为什么 React 变得非常受 JS 开发人员欢迎的原因。

    1.7K10

    从零手写react-router

    将一个字符串变成一个正则表达式我们知道, react-router的大致原理就是根据路径的不同从而渲染不同的页面, 那么这个过程其实也就是路径A匹配页面B的过程, 所以我们之前会写这样的代码将地址栏的path值取出来跟该正则表达式进行匹配, 匹配上了就要渲染相应的路由, 匹配不上就渲染其他的逻辑path-to-regexp就是做这个事情的, 他把我们给他的路径字符串转换为正则表达式...将匹配结果返回出去 // 首先, 如果你读了这个path-to-regex的文档的话, 你会发现一个问题 // 我们在react-router中传递exact为精确匹配, 而在该库中则是使用end...hoc, 他的作用非常简单, 就是将路由上下文作为属性注入到组件中我们在react-router目录下新建一个withRouter.jsimport React from "react";import...毕竟人家也就实现了一个无刷新跳转的功能我们在react-router-dom里新建一个Link.js// react-router-dom/Link.jsimport React from "react

    1.5K50

    从零手写react-router

    将一个字符串变成一个正则表达式我们知道, react-router的大致原理就是根据路径的不同从而渲染不同的页面, 那么这个过程其实也就是路径A匹配页面B的过程, 所以我们之前会写这样的代码将地址栏的path值取出来跟该正则表达式进行匹配, 匹配上了就要渲染相应的路由, 匹配不上就渲染其他的逻辑path-to-regexp就是做这个事情的, 他把我们给他的路径字符串转换为正则表达式...将匹配结果返回出去 // 首先, 如果你读了这个path-to-regex的文档的话, 你会发现一个问题 // 我们在react-router中传递exact为精确匹配, 而在该库中则是使用end...hoc, 他的作用非常简单, 就是将路由上下文作为属性注入到组件中我们在react-router目录下新建一个withRouter.jsimport React from "react";import...毕竟人家也就实现了一个无刷新跳转的功能我们在react-router-dom里新建一个Link.js// react-router-dom/Link.jsimport React from "react

    1.4K40

    手写react-router

    将一个字符串变成一个正则表达式我们知道, react-router的大致原理就是根据路径的不同从而渲染不同的页面, 那么这个过程其实也就是路径A匹配页面B的过程, 所以我们之前会写这样的代码将地址栏的path值取出来跟该正则表达式进行匹配, 匹配上了就要渲染相应的路由, 匹配不上就渲染其他的逻辑path-to-regexp就是做这个事情的, 他把我们给他的路径字符串转换为正则表达式...将匹配结果返回出去 // 首先, 如果你读了这个path-to-regex的文档的话, 你会发现一个问题 // 我们在react-router中传递exact为精确匹配, 而在该库中则是使用end...hoc, 他的作用非常简单, 就是将路由上下文作为属性注入到组件中我们在react-router目录下新建一个withRouter.jsimport React from "react";import...毕竟人家也就实现了一个无刷新跳转的功能我们在react-router-dom里新建一个Link.js// react-router-dom/Link.jsimport React from "react

    1.3K40

    React SSR 简介与 Next.js 使用入门

    访问数据库,拿到数据然后将数据填充到 HTML 模板上,比如 Node.js 中的 pug 模板引擎、ejs 模板引擎等都是服务端渲染的模板。...使用 React 做服务器渲染,主要是通过下面这几个方法来实现: renderToString: 将组件转化为 HTML 字符串,生成的 HTML 的 DOM 会带有额外的属性,比如最外层的 DOM 会有...renderToStaticMarkup: 同样将组件转换成 HTML 字符串,但是生成的 HTML 的 DOM 不会有额外的属性,从而节省 HTML 字符串的大小。...使用这几个方法都是可以将 React 组件转化成 HTML 字符串,而前端不变的去写 React 组件即可。这种前后端共用一套代码的方式被称为同构。...export default Index; next.js 中的 Link 是使用 href 作为跳转的属性。

    9.8K51

    Meteor 1.6.x + Ant Design Table + recompose 实现数据分页效果

    yarn add react react-dom --save 创建 Layout 虽然是个很简洁的项目,但我还是想把创建的整个步骤跟大家描述清楚,避免初学者在学习的过程中遇到各种各样的问题。...yarn add antd --save yarn add react-router-dom --save 在 /imports/startup/client/index.js 中引入 antd 的 css...我们引入了两个组件,一个是 Home,一个是 Links,所以我们还要在 /imports/ui/components/ 下创建 Home.js 和 Links.js,两个文件分别实现为一个简单的组件,...增加数据量 上面我们已经成功显示了所有 links 中的数据,但是数据量有点小,不方便我们测试分页效果,所以修改一下 /imports/startup/server/fixtures.js 的代码,让程序初始化的时候就默认生成...随后我们将两个状态绑定到组件,这样我们就可以在组件中使用这两个状态并且可以调用两个修改状态的方法来修改状态。

    3.3K20

    Meteor 1.6.x + Ant Design Table + recompose 实现数据分页效果

    yarn add react react-dom --save 创建 Layout 虽然是个很简洁的项目,但我还是想把创建的整个步骤跟大家描述清楚,避免初学者在学习的过程中遇到各种各样的问题。...yarn add antd --save yarn add react-router-dom --save 在 /imports/startup/client/index.js 中引入 antd 的 css...我们引入了两个组件,一个是 Home,一个是 Links,所以我们还要在 /imports/ui/components/ 下创建 Home.js 和 Links.js,两个文件分别实现为一个简单的组件,...增加数据量 上面我们已经成功显示了所有 links 中的数据,但是数据量有点小,不方便我们测试分页效果,所以修改一下 /imports/startup/server/fixtures.js 的代码,让程序初始化的时候就默认生成...随后我们将两个状态绑定到组件,这样我们就可以在组件中使用这两个状态并且可以调用两个修改状态的方法来修改状态。

    2.9K30

    Meteor 1.6.x + Ant Design Table + recompose 实现数据分页效果

    yarn add react react-dom --save 创建 Layout 虽然是个很简洁的项目,但我还是想把创建的整个步骤跟大家描述清楚,避免初学者在学习的过程中遇到各种各样的问题。...Layout 我们使用 ant design 的组件来实现,所以首先我们要引入 antd 和 react-router-dom,并在 .meteor/packages 文件中删除项目自带的 kadira...yarn add antd --save yarn add react-router-dom --save 在 /imports/startup/client/index.js 中引入 antd 的 css...我们引入了两个组件,一个是 Home,一个是 Links,所以我们还要在 /imports/ui/components/ 下创建 Home.js 和 Links.js,两个文件分别实现为一个简单的组件,...随后我们将两个状态绑定到组件,这样我们就可以在组件中使用这两个状态并且可以调用两个修改状态的方法来修改状态。

    30020

    初探 MicroApp,一个极致简洁的微前端框架

    借鉴了 WebComponent 的思想,micro-app 通过 CustomElement 结合自定义的 ShadowDom,将微前端封装成一个类 WebComponent 组件,从而实现微前端的组件化渲染...它在 基座应用 和 子应用 之间充当桥梁胶水的作用。 有下面的优势: 使用简单。 将功能封装到 WebComponent 中 零依赖。...__是由micro-app注入的全局变量 if (window....方面使用 Proxy 拦截了用户全局操作的行为,防止对 window 的访问和修改,避免全局变量污染。...插件系统 插件系统的主要作用就是对js进行修改,每一个js文件都会经过插件系统,我们可以对这些js进行拦截和处理,它通常用于修复js中的错误或向子应用注入一些全局变量。

    1.6K30
    领券