首页
学习
活动
专区
圈层
工具
发布
    • 综合排序
    • 最热优先
    • 最新优先
    时间不限
  • 来自专栏前端知否

    React Hooks - 缓存记忆

    应该使用缓存记忆吗? 在大多数情况下,React速度非常快。如果您的应用程序足够快并且没有任何性能问题,那么本文不适合您。 解决"虚幻"的性能问题是一件实用的事情,在开始优化之前,请先熟悉React Profiler。 ? 如果您确定了渲染速度较慢的场景,那么使用缓存记忆可能是最好的选择。 如果您的函数组件在相同的Props属性下呈现相同的结果,React将会使用缓存,跳过这次渲染,并重用最后一次渲染的结果。 默认情况下,它将仅对props对象中的复杂对象进行浅层比较。 不使用缓存记忆 让我们看一个不使用缓存记忆的示例,和理解为什么这会导致性能问题。 简单的缓存记忆 const List = React.memo(({ items }) => { console.log('renderList'); return items.map((item

    4.2K10发布于 2020-03-23
  • 来自专栏ArcGIS JS API开发

    React基础-5React Hook

    本文是【React基础】系列的第五篇文章,这篇文章中我们介绍一下在react的函数组件中如何使用类组件中的state和生命周期之类的东西。 Hook简介 hook说白了其实就是一些react中特殊的函数,只不过这些函数允许我们通过钩子的形式钩入一些react的特性,例如我们想要在函数组件中使用state的话就不用将其转为类组件,直接使用useState import React, { useState } from "react"; //对应第一步 const StateHook = () => { const [count, setCount import React, { useState, useEffect } from "react"; //对应第一步 const EffectHook = () => { const [count useCallback 缓存函数的引用。 useMemo 缓存函数的值。 useRef 每次渲染时返回同一个ref对象。

    1.3K10编辑于 2022-02-21
  • 来自专栏兜兜毛毛

    MyBatis 缓存5

    跟Hibernate一样,Mybatis也有一级缓存、二级缓存,并预留了集成第三方的缓存接口。 除了基础缓存之外,MyBatis也定义了很多装饰器,同样实现了Cache接口,通过这些装饰器可以额外实现很多功能。 ? 所有缓存可以分为三大类:基本缓存、淘汰算法缓存、装饰器缓存。 策略缓存缓存达到上限时,删除最先入队的缓存 evication="FIFO" SoftCache \ WeakCache 带清理策略的缓存 通过JVM的软引用和弱引用来实现缓存,当JVM内存不足时 事务缓存 在二级缓存中使用,可一次存入多个缓存,移除多个缓存 在TransactionalCacheManager中用Map维护对应关系 一级缓存 一级缓存也叫本地缓存(Local Cache),MyBatis 而一级缓存是在SqlSession内部的,所以肯定是工作在一级缓存之前,也就是只有取不到二级缓存的情况下才到一个会话中去取一级缓存。 二级缓存是在哪里维护的呢?

    65420发布于 2021-04-19
  • 来自专栏一个执拗的后端搬砖工

    springboot(5)--缓存

    它具有内存和磁盘存储,缓存加载器,缓存扩展,缓存异常处理程序,一个gzip缓存servlet过滤器,支持REST和SOAP api等特点。 Object queryUser(@PathVariable("id") Long id) { return this.userService.findById(id); } } 5. springboot2.0.5依赖的基础库是spring5.x,而spring5中已经取消了对guava缓存的支持。 1.添加caffeine依赖 <! spring.cache.caffeine.spec=initialCapacity=50,maximumSize=500,expireAfterWrite=100s,refreshAfterWrite=5s : @Configuration public class CaffeineConfiguration { /** * 必须要指定这个Bean,refreshAfterWrite=5s

    65510发布于 2020-11-19
  • 来自专栏web技术开发分享

    react-live-route(react的组件缓存)使用

    开题:之前用了react-keeper但是有BUG(scroll的位置不准确,而且onscroll的事件也无法监听到), 所以抛弃之! 太坑了, 于是乎,找到了react-live-router,完美解决我们的问题: 下面是是使用方法: 1.下载库: npm i react-live-route 2.在外面的routes中配置使用 不需要改变我们之前的 router结构(比如我之前用的react-router-dom) 开箱即用! 之外,相当于另外单独写了一个缓存的路由组件 需要缓存的路由的component也需要在LiveRoute中引用   

            <Suspense > 注意存在的一个BUG:使用了react-live-route 路由缓存之后,再使用import lazy懒加载引入路由 会造成bug (缓存的路由 和其它的路由同时存在) 大概的开箱使用说明就这么多

    1.5K10编辑于 2022-08-11
  • 来自专栏Java实战博客

    5、Openresty本地缓存

    Openresty本身也支持开辟内存添加共享缓存的空间,操作api与redis一致 本地缓存的作用 减少查询redis、mysql的操作,实际redis也很快,但是毕竟有网络开销。 本地缓存会更快一些! so;;"; # ① 开启本地共享缓存,会占用内存:150mb 缓存名mycache,自定义 lua_shared_dict mycache 128m; # 在这里配置 也就是不会超时 ngx.say('缓存设定成功!') -- 读取数据 local name = getCache:get('name') ngx.say('第二次读取本地缓存!' ,name) -- 删除数据 --getCache:delete('name') -- 特别说明 -- 1、重载配置文件,缓存不会消失 -- 2、nginx重启才会删除缓存数据 特殊说明: 以上文章

    1.4K20编辑于 2022-08-24
  • 来自专栏天天

    H5缓存

    1.sessionStorage <script type="text/javascript"> var txt = document.querySelector('input'); var btns = document.querySelectorAll('button'); //存储数据 btns[0].onclick=function(){ sessionStorage.setItem('userName',txt.value); ses

    1.3K10发布于 2018-09-29
  • 来自专栏漫漫架构路

    5. 缓存模块

    缓存概述 对于缓存功能,相信大家都十分熟悉了。一旦我们发现系统的性能存在瓶颈需要优化时,可能第一时间想到的方式就是加缓存。 MyBatis 内部有所谓的一级缓存和二级缓存,这个会在后面的章节中详细阐述,本次仅讨论缓存的内部实现。 MyBatis 缓存定义 我们首先来看下 MyBatis 的 Cache 接口,它定义了缓存的基本行为: /** * MyBatis缓存接口 */ public interface Cache { 设置缓存内的元素数量上限为 512 个。 缓存淘汰策略是 LRU。 需要每隔 60s 需要对缓存进行清空。 小结 本篇详细介绍了 MyBatis 缓存模块的底层原理,包括缓存的基础实现、具备各种扩展功能的缓存装饰器,以及缓存 Key 的设计思想。

    39420编辑于 2023-10-12
  • 来自专栏Web 技术

    缓存】HTML5缓存的那些事

    ; 数据库:mySql\mongoDB…关系\非关系数据库; 内存:通常放置频繁要使用到的东西,能够提高读取效率;缓存(cache)也是存放在内存里的; HTML的存储-cookies 在HTML5出生之前 HTML的存储-UserData 只有IE支持,有微软提供API,但不符合W3C标准; 存储在XML文件中; HTML5的存储 针对以上问题,HTML5的出现,需要解决以下问题: 解决4K的大小问题; 解决请求头常带存储信息的问题; 解决关系型存储的问题; 跨浏览器平台问题; ##HTML5存储形式 本地存储——localstorage \sessionstorage 离线缓存——application v=1会被认为是不同文件,分别缓存; app cache适用场景 单地址页面 对实时性要求不要的业务 离线web应用 总结 在实际应用中,我们需要根据业务的需要来采取相应的缓存措施,如上所述,html5 关于HTML5缓存我们就介绍到这里。 参考 HTML5之IndexedDB使用详解

    1.2K50编辑于 2023-10-07
  • 来自专栏全栈程序员必看

    react js清除浏览器缓存

    定位之后,发现查询走的是浏览器缓存… F12已接收那显示(来自缓存),时间0秒。 下面就是清缓存的方法:加上这句 Pragma: ‘no-cache’, headers: { Pragma: ‘no-cache’, //解决IE 11走缓存无法刷新问题 [‘Token’], ‘Content-Type’: ‘application/json’ } 这样就可以清理掉IE浏览器的缓存

    8.2K40编辑于 2022-09-09
  • 来自专栏一Li小麦

    react 同构初步(5

    本笔记系列进度已更新到:https://github.com/dangjingtao/react-ssr 服务端性能优化思路 ssr把原来在客户端做的渲染工作摆到了服务端。 -- scr 模版,和ssr基本一致 --> <html> <head> <meta charset="UTF-8"> <title>react ssr->csr</title> <body _mode=csr,就会发现网络请求走的scr路径(title由react ssr变成了 react ssr->csr) 此时浏览器有一个报错: Warning: Expected server HTML true } }] } 然后尝试测试一下,新建index.css: .title{ color:red; } .container{ background: #f5f5f5 return

    react ssr

    {/* ...

    1K20发布于 2020-01-02
  • 来自专栏海仔技术驿站

    React-day5

    运行cnpm i babel-plugin-import --save-dev 修改.babelrc文件: { "presets":["es2015", "stage-0", "react 使用react-router-dom实现路由跳转 HashRouter:是一个路由的跟容器,一个应用程序中,一般只需要唯一的一个HashRouter容器即可! // 其中path指定了路由匹配规则,component指定了当前规则所对应的组件 <Route path="" component={}></Route> 注意:react-router中的路由匹配 来表示当前的Route是进行精确匹配的 可以使用Redirect实现路由重定向 // 导入路由组件 import {Route, Link, Redirect} from 'react-router-dom

    86410发布于 2021-05-06
  • 来自专栏用户9715713的专栏

    React源码解读之React Fiber5

    facebook为什么要使用重构ReactReact Fiber是什么React Fiber的核心算法 - react是如何中断重启任务的react fiber部分源码简化版前言该文章涉及的源码部分基于 React v17.0.2why React Fiber浏览器渲染过程从浏览器的运行机制谈起。 而React执行是要进行两棵树的diff,虽然React根据html的特性对diff算法做了优化,但是如果两棵树比对的层级较深,依旧会远远超过16ms。React Fiber基于此,那如何解决问题呢? 在上图中,React作为js,所有的同步操作执行在最开始,在React执行完成后,后续的html解析,布局渲染等操作才会执行。 在React执行中,最耗时的就是diff算法,React针对html这种场景下做了优化,业界已经没有更好的算法可以缩短diff算法的时间,所以当树的层次很深时,执行时间依旧很长。

    46930编辑于 2023-01-09
  • 来自专栏前端人人

    React技巧5(TodoList实现)

    本教程总共5篇,每日更新一篇,请关注我们!你可以进入历史消息查看以往文章,也敬请期待我们的新文章! 1.React 技巧1(状态组件与无状态组件的使用) ----2018.01.04 2.React 技巧2(避免无意义的父节点)----2018.01.05 3.React 技巧3(如何优雅的渲染一个List )----2018.01.06 4.React 技巧4(如何处理List里面的Item)----2018.01.07 5.React 技巧5(TodoList实现)----2018.01.08 开发环境 from 'react'; import TodoList from '. TodoList.jsx import React from 'react'; class TodoList extends React.Component { constructor(props

    1.4K60发布于 2018-04-11
  • 来自专栏Micro_awake web

    HTML5 Web缓存&运用程序缓存&cookie,session

    在介绍HTML5 web缓存前,来认识一下cookie和session: session: 由于HTTP是无状态的,你是谁?你干了什么?抱歉服务器都是不知道的。 HTML5 web存储支持情况: IE8以上,现代浏览器。 HTML5运用程序缓存(Application Cache): 通过创建cache manifest文件,web运用可被缓存,并且无网络状态可以进行访问! Manifest文件: manifest是简单的文本文件,它告知浏览器被缓存的内容以及不被缓存的内容! manifest可分为三部分: CACHE MANIFEST:此项列出的文件将在首次下载后进行缓存! NETWORK:此项列出的文件需要与服务器进行网络连接,不会被缓存

    2.8K70发布于 2018-01-11
  • 来自专栏itclanCoder

    React基础(5)-React中组件的数据-props

    [React学习(5)-React组件中的数据-props.png] 前言 开发一个React应用,更多的是在编写组件,而React组件最小的单位就是React元素,编写组件的最大的好处,就是实现代码的复用 每个定义的React组件应该都是独立存在的模块,组件之外的一切都是外部世界(组件),外部世界(组件)就是通过prop来和组件进行对话数据传递的 在React中,你可以将prop类似于HTML标签元素的属性 , { Fragment, Component } from 'react'; import ReactDOM from 'react-dom'; // 函数式组件,定义一个Button组件,首字母大写 进行实现 import React, { Fragment, Component } from 'react'; import ReactDOM from 'react-dom'; // 类组件,通过 到当前的实例对象上 将该组件实例的方法进行this坏境绑定是React常用手段 代码如下所示: import React, { Fragment, Component } from 'react'; import

    8.5K00发布于 2019-09-28
  • 来自专栏逸鹏说道

    探索ASP.NET MVC5系列之~~~5.缓存篇(页面缓存+二级缓存

    dunitian/p/4822808.html#mvc 本章Demo:https://github.com/dunitian/LoTCodeBase/blob/master/NetCode/6.网页基础/BMVC5/ MVC5Base/Controllers/CacheController.cs 这次来篇放松的,咱们不要老是说安全相关的东西。 缓存这东西并不是MVC独有的,N年前就有了,简单介绍一下平时项目里面使用的(Redis,Memcache等下次说) 1.页面缓存: ? 2.3数据库依赖缓存 1.启动一下数据库缓存依赖:管理员身份打开VS开发人员命令(参数详解:https://msdn.microsoft.com/zh-cn/library/ms229862) aspnet_regsql ,当里面数据发生改变则缓存失效,这样就可以及时自动更新缓存了(我这边只是做个演示) ?

    1.2K50发布于 2018-04-11
  • 来自专栏技术博文

    H5缓存机制浅析

    1 H5 缓存机制介绍 H5,即 HTML5,是新一代的 HTML 标准,加入很多新的特性。离线存储(也可称为缓存机制)是其中一个非常重要的特性。 H5 引入的离线存储,这意味着 web 应用可进行缓存,并可在没有因特网连接时进行访问。 根据标准,到目前为止,H5 一共有6种缓存机制,有些是之前已有,有些是 H5 才新加入的。 还有,浏览器,如 X5,在使用缓存文件时,是没有对缓存文件内容进行校验的,这样缓存文件内容被修改的可能。 分析发现,浏览器的缓存机制还不是非常完美的缓存机制。 在实际应用中,为了解决 Cache-Control 缓存时长不好设置的问题,以及为了”消灭304“,Web前端采用的方式是: 在要缓存的资源文件名中加上版本号或文件 MD5值字串,如 common.d5d02a02

    2.2K80发布于 2018-04-16
  • 来自专栏前端大白专栏

    HTML5离线缓存技术

    原理和环境 如上面提到的HTML5的离线存储是基于一个新建的.appcache文件的,通过这个文件上的解析清单离线存储资源,这些资源就会像cookie一样被存储了下来。 就像cookie一样,html5的离线存储也需要服务器环境。 这里提供一个小工具——简易iis服务器,把它放在项目更目录下,双击运行即可模拟服务器环境。 : * FALLBACK 下面的 FALLBACK 小节规定如果无法建立因特网连接,则用 "offline.html" 替代 /html5/ 目录中的所有文件: ALLBACK: /html5/ /404 缓存立即执行 我们的产品已经更新了用户却要第二次进来才能够看到,这样用户体验也太差了吧,有什么方式能够解决呢?好在html5给javascript提供了相关的API。 注意事项 站点离线存储的容量限制是5M 如果manifest文件,或者内部列举的某一个文件不能正常下载,整个更新过程将视为失败,浏览器继续全部使用老的缓存 引用manifest的html必须与manifest

    4.4K70发布于 2018-06-15
  • 来自专栏黯羽轻扬

    5 行代码理解 React Suspense

    所以,姑且狭义地认为组件代码已就绪的组件就是安全的,包括同步组件和已加载完的异步组件(React.lazy),例如: // 同步组件,安全 import OtherComponent from '. /OtherComponent'; // 异步组件,不安全 const AnotherComponent = React.lazy(() => import('. /MyErrorBoundary'; const OtherComponent = React.lazy(() => import('. /OtherComponent')); const AnotherComponent = React.lazy(() => import('. AnotherComponent /> </Suspense> </MyErrorBoundary>

    ); 二.手搓一个 Suspense 开篇的 5

    1.6K20发布于 2019-12-16
领券