我的网站开发技术经验总结 我的网站开发技术经验总结
首页

fangdown

我的网站开发技术经验总结
首页
  • 认识ESM
  • chrome-talend插件,类似postman
  • sequelize 使用及技巧
  • UML工具Power Designer建表
  • sequelize相关操作文档
  • 解决抖音获取签名及并发的问题
  • 记一次解决抖音分享页混淆字体,字体图标转UID解决方案
  • 获取抖音用户作品列表信息
  • 获取抖音用户作品列表信息-进阶
  • 获取抖音用户作品列表信息-进阶3
  • 如何根据抖音号获取用户信息
  • 获取用户最新视频
  • 模块化-import和require的区别
  • eslint规范
  • js容错处理
  • js-数组分组,执行promise
  • reduce使用遇到的问题
  • 正则匹配html的元素内容
  • taro 小程序 弹窗层禁止底部滚动
  • 公众号签名问题
  • CentOS7中MariaDB重置密码
  • nginx多域名配置
  • node访问接口,得到乱码的结果,原因-Accept-Encoding
  • node写文件到json中
  • node抓取html内容
  • Node.js使用ES6语法
  • express 使用cors中间件解决跨域
  • node + express + session + redis 进行持久化缓存
  • node中读取文件夹,获取文件名称
  • pm2常用命令
  • 使用pm2管理后台node服务
  • typescript puppeteer支持window及document属性
  • node读取json文件
  • node中使用redis缓存
  • node + github的webhook完成自动部署
  • vuepress-blog的性能优化-CDN
  • CENTOS7下安装REDIS
  • promise then和catch的学习和使用
  • promise在循环中的串行并行用法
  • puppeteer常用知识
  • centos部署安装puppeteer
  • python的学习和使用
  • Taro+TypeScript - Mobx实践
  • 爬虫系列 --- 反爬机制和破解方法汇总
  • 安全-html转码
  • taro中使用animation动画
  • charles 使用
  • Mac下VSCode设置iTerm2终端样式
  • centos一步步完成站点部署
  • 云闪付做地铁的思路
  • 准备技能
  • 备案pc项目介绍
  • 备案小程序项目介绍
  • 小程序二维码扫码功能
  • 小程序域名组件开发
  • 小程序添加水印
  • 规则引擎优化
    • 背景
    • 分析
    • 实现
    • 总结
  • 记一次hooks代替redux的经历
  • 通过nodejs+koa+stream进行服务端图片代理
  • nodeJs接入log4j日志
  • nodejs+typescript项目中添加全局global属性
  • create-react-app 安装 bizcharts 项目崩溃
  • 使用MutationObserver监控dom的变化
  • 服务器重启后启动相关服务
  • moment国际化的问题
  • 项目经验
fangdown
2021-07-23
目录

规则引擎优化

# 背景

  • 项目中使用了规则引擎(规则类的文件集合)
  • 使用class类进行构建,在项目初始化时进行了实例化
  • 在项目redux中与订单进行了耦合,比较庞大和不利配置化(需解决耦合性的根本问题)

# 分析

  • 将规则和订单分开,分别获取对应数据
  • 再将规则和订单进行有机组合

# 实现

  1. 规则 使用useHooks方式获取规则,并缓存到sessionstorage中
  • sessionstroage 页面刷新时,数据不会丢失,规则不更新的问题 考虑到页面刷新,js文件会更新,规则也需要更新, 此时就要添加辅助行为window.onbeforeunload去主动清除sessionstorage中对应的规则,后面才会再拉取最新规则
export const useFetchRules = () => {
  const [ruleLoading, setRuleLoading] = useState(true);
  const [rules, setRules] = useState([]);
  useEffect(() => {
    fetchRule();
    // 刷新时需重新加载规则
    window.onbeforeunload = () => {
      sessionStorage.removeItem('ba-rules');
    };
  }, []);
  const fetchRule = async () => {
    try {
      const isDev = process.env.NODE_ENV === 'development';
      const rulesStr = sessionStorage.getItem('rules');
      if (rulesStr) {
        setRules(JSON.parse(rulesStr));
      } else {
        const resRules = isDev ? config.Keys : await FetchRuleFeilds();
        setRules(resRules);
        sessionStorage.setItem('ba-rules', JSON.stringify(resRules));
      }
      setRuleLoading(false);
    } catch (error) {
      console.log(error);
    }
  };
  return { ruleLoading, rules };
};
  1. 订单获取(redux)

  2. 规则和订单匹配

采用hooks写法

  • 先获取到规则
  • 暴露getOrderRule方法,参数为order
export const useOrderRules = () => {
  const { rules } = useFetchRules();
  let order
  const getFieldByKey = (field) =>{
    // xx
  }
  const getOrderRule = (data) => {
    order = data;
    return { getFieldByKey };
  };
  return {getOrderRule}
}

# 总结

通过把规则、订单单独获取,再进行结合,就可以实现达到解耦的目的

#技能
上次更新: 2021/12/19, 18:05:42
小程序添加水印
记一次hooks代替redux的经历

← 小程序添加水印 记一次hooks代替redux的经历→

最近更新
01
多分支修复撞车的问题
05-01
02
如何成为架构师
01-23
03
服务器部署全过程
11-23
更多文章>
Theme by Vdoing | Copyright © 2019-2026 fangdown | 粤ICP备19079809号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式