从这节起我们开始学习 Redux,一种新型的前端“架构模式”.经常和 React.js 一并提出,你要用 React.js 基本都要伴随着 Redux 和 React.js 结合的库 React-redux. 要注意的是,Redux 和 React-redux 并不是同一个东西.Redux 是一种架构模式(Flux 架构的一种变种),它不关注你到底用什么库,你可以把它应用到 React 和 Vue,甚至跟 jQuery 结合都没有问题.而 React-redux 就是把 Redux 这种架构模式…
接下来两节某些地方可能会稍微有一点点抽象,但是我会尽可能用简单的方式进行讲解.如果你觉得理解起来有点困难,可以把这几节多读多理解几遍,其实我们一路走来都是符合“逻辑”的,都是发现问题.思考问题.优化代码的过程.所以最好能够用心留意.思考我们每一个提出来的问题. 细心的朋友可以发现,其实我们之前的例子当中是有比较严重的性能问题的.我们在每个渲染函数的开头打一些 Log 看看: function renderApp (appState) { console.log('render app...')…
上一节 的我们有了 appState 和 dispatch: let appState = { title: { text: 'React.js 小书', color: 'red', }, content: { text: 'React.js 小书内容', color: 'blue' } } function dispatch (action) { switch (action.type) { case 'UPDATE_TITLE_TEXT': appState.title.text = act…
经过了这么多节的优化,我们有了一个很通用的 createStore: function createStore (state, stateChanger) { const listeners = [] const subscribe = (listener) => listeners.push(listener) const getState = () => state const dispatch = (action) => { state = stateChanger(state,…
我们接下来会继续优化我们的 createStore 的模式,让它使我们的应用程序获得更好的性能. 但在开始之前,我们先用一节的课程来介绍一下一个函数式编程里面非常重要的概念 —— 纯函数(Pure Function). 简单来说,一个函数的返回结果只依赖于它的参数,并且在执行过程里面没有副作用,我们就把这个函数叫做纯函数.这么说肯定比较抽象,我们把它掰开来看: 函数的返回结果只依赖于它的参数. 函数执行过程里面没有副作用. 函数的返回结果只依赖于它的参数 const a = 1 const fo…
不知不觉地,到这里大家不仅仅已经掌握了 Redux,而且还自己动手写了一个 Redux.我们从一个非常原始的代码开始,不停地在发现问题.解决问题.优化代码的过程中进行推演,最后把 Redux 模式自己总结出来了.这就是所谓的 Redux 模式,我们再来回顾一下这几节我们到底干了什么事情. 我们从一个简单的例子的代码中发现了共享的状态如果可以被任意修改的话,那么程序的行为将非常不可预料,所以我们提高了修改数据的门槛:你必须通过 dispatch执行某些允许的修改操作,而且必须大张旗鼓的在 acti…
bbs.chinaunix.net/thread-965755-1-1.html 5.   获得/修改共享互斥量属性:    #include<pthread.h>    intpthread_mutexattr_getpshared(const pthread_mutexattr_t *restrictattr, int    *restrictshared );   //!> 获得共享互斥量属性,由shared带出    intpthread_mutexattrattr_ setps…
win10下: kettle_Spoon 修改共享DB连接带汉字引发的错误: Unexpected problem reading shared objects from XML file : null 处理方式: 在目录:C:\Users\lj96\.kettle   或者  C:\Users\Administrator\.kettle  里 找到:shared.xml 将里面的汉字去掉保存即可: <connection> <name>dbConectName配置</nam…
1.如何在线上环境优雅的修改配置文件? 原配置文件 #原配置文件 global log 127.0.0.1 local2 daemon maxconn 256 log 127.0.0.1 local2 info defaults log global mode http timeout connect 5000ms timeout client 50000ms timeout server 50000ms option dontlognull listen stats :8888 stats e…
Unstated Next readme 的中文翻译 前言 这个库的作者希望使用 React 内置 API ,直接实现状态管理的功能.看完这个库的说明后,没有想到代码可以这个玩.短短几行代码,仅仅使用 React Hooks ,就实现了状态管理的功能. 看完之后,第一想法就是翻译成中文,分享给其他人.提交 Pull Request 后,库作者将我的翻译合并了.同时作者欢迎将 README 翻译成其他语言,以下是全部翻译内容,不妥之处欢迎指正或 Pull Request. Unstated Nex…