当前位置: 首页 > news >正文

温州网站策划建立网站的详细步骤

温州网站策划,建立网站的详细步骤,摄影图片网站,南通做企业网站我们现在主要是使用Mobx,但是Mobx的易于上手和灵活度也带来了很多预期以外的问题,随着项目的增长我们的代码技术债变得愈加沉重,不同的模块杂糅一起、单一store无限膨胀。 为此我们的调研是希望能找到一个更好的state配置、数据流的约定方案。…

我们现在主要是使用Mobx,但是Mobx的易于上手和灵活度也带来了很多预期以外的问题,随着项目的增长我们的代码技术债变得愈加沉重,不同的模块杂糅一起、单一store无限膨胀。
为此我们的调研是希望能找到一个更好的state配置、数据流的约定方案。
我们预期解决的问题:

  1. 更好地控制Mobx的复杂度,正确地拆分Store和管理内部的state。
  2. 虽然做不到单向数据流,但是数据流走向可追溯。
  • 是否能借鉴其他方案的分层管理、人为约定出一个更清晰的处理方案?
  1. 如何调试组件内Mobx的管理?
  • mobx dev tool。
  • mobx本身提供的spy API的能力。
  1. 特殊场景下的方案:
  • 能否做到compute 缓存之前的记忆,或者之前的数据和之后对比。
  • 主动订阅场景(已解决:通过mobx的reaction)

查阅的相关文章

浅谈React数据流管理
Mvvm 前端数据流框架精讲
前端数据流选型
React 体系下关于 Mobx 与 Redux 的一些思考

数据流管理方案的调研投票

目前来说主要有以下几个投票方案。

react-redux

现有比较火的是react-redux-toolkit,国内常用的umi+dva的方案也是redux的一个封装。

结论

在下面的redux vs mobx

Mobx

Mobx的文档
Mobx-长篇源码解读,一文搞懂原理
MobX State Tree数据组件化开发
浅析了一些源码处理,可作为入门读物:一次搞懂Mobx,项目再也不踩坑_(:3」∠)_

  • Mobx
  • Mobx-state-tree
  • Mobx+immer
结论

经过调研,Mobx-state-tree不就是mobx+immer嘛。然后immer的调研结论在下面,为了不让我们的改造变得更复杂,这些东西都可以以后考虑,因此就不扩展了。

Immer

(讲了使用方式和一些注意事项,但是没有源码解析,推荐阅读) Immer 最佳实践(走心教程)
重构利器:如何用 Immer 优雅地管理应用状态
为什么说 90% 的情况下,immer 完胜 immutable?
(一般)[ Immer 源码 ] 来聊聊 Immer 实现不可变数据结构
不可变数据流的完美解决方案——Immer 源码解读
(一个基础的todolist demo)不可变数据 - Immer.js 改造 reducer
在这里插入图片描述

结论

很好的东西,是为了解决副作用问题,但是我们项目应该用不太上,或者说不是必须的。可以先改重要的东西,不要太着急引入新技术栈,否则反而增加开发负担+增加改造的复杂度。

zustand

类似于轻量级的context+redux结合体。有中间件可以方便处理数据。
不过觉得有一个数据流管理就行啦,多了增加开发心智负担,因此不引入。

jotai

懒得看了。

Redux vs Mobx

经过组内讨论,Redux使用起来实在更复杂步骤更多,我们的项目已经很成熟了,转换过去一是浪费大量时间,二是Redux也不一定能解决我们项目现有的技术债问题。
因为我们的问题主要是历史原因,导致store无限膨胀、不同的模块杂糅。

而且相较而言,Mobx有如下优点:

  1. 作为响应式编程,渲染更快;
  2. 同一改动的代码量更少。
  3. 使用高阶hook自动进行浅比较优化性能。

综上,再加上我们原本就是用的mobx,就酱紫了。

Mobx使用约定

  1. 明确规定不同的模块在不同的mobx store中。
  2. 非必要不提升状态。页面业务级的数据应当考虑放在context中。明确我们的数据类型,暂时将数据类型分为两部分:1. 业务数据。2. UI状态数据。

mobx存放的是:

  • @action需处理和的公共业务数据。
  • 涉及多个组件的公共业务数据。
  • 控制页面的UI状态数据。

除此之外,下面数据将考虑放置在context / state中。

  • 涉及当前组件的UI状态数据。
  • 涉及当前组件及子组件的UI状态数据、非公共业务数据。
  1. 降低复杂度,数据可追溯:一个observable的变量对应一个action,参考redux的形式。

调试Mobx

使用mobx-devtool查看mobx内的数据如何流转,进行调试

  • 安装谷歌插件MobX Developer Tools,可以看到具体的数据变化和字段值。比较可视化。(还有不要下错了还有一个Pro的插件,我试了一点用没有)
  • mobx spy观察。
import { spy } from 'mobx';
spy(e=>console.log(e))
http://www.wangmingla.cn/news/133049.html

相关文章:

  • 贵阳金阳网站建设公司怎么做好网站方式推广
  • wordpress 图站句容市网站seo优化排名
  • 简洁 手机 导航网站模板下载百度关键词优化和百度推广
  • dede门户网站模板济南最新消息今天
  • 网站定制开发微信运营长沙seo外包平台
  • 网站建设需要哪些人短视频营销策划方案
  • 大连辰熙大厦做网站杭州10大软件开发公司
  • 用ai做网站论坛发帖
  • 上海网站哪个比较好潮州seo
  • 免费招聘网站哪个好uc推广登录入口
  • 网站建设和数据库维护关键词名词解释
  • 网站做动态图片不显示自己怎么制作网站
  • 阿坝县建设局网站怎样做好销售和客户交流
  • 网站建设需要哪些专业技术如何让产品吸引顾客
  • 聊城集团网站建设价格全国十大婚恋网站排名
  • 东莞阳光网站小辉seo
  • 百度网站优化软件google本地搜索
  • 个人网站域名快速备案开发一个网站需要哪些技术
  • 贵州省住房城乡建设部网站全网营销国际系统
  • 做的最好的网站企业策划咨询公司
  • 响水做网站哪家最好各行业关键词
  • 做网站选云服务器内核微信指数官网
  • 免费照片裁剪工具优化大师的作用
  • 淘宝请人做网站被骗广州seo优化排名推广
  • 鸡泽专业做网站销售新人怎么找客户
  • 网站开发工程师 下载免费推广网站有哪些
  • 粘贴以下代码到网站首页代码的与标签之间搜索指数分析
  • 厦门建设局电话百度seo怎么做网站内容优化
  • 在网上做效果图网站大数据是干什么的
  • 网页制作与网站建设宝典 第2版google搜索首页