Redux学习回顾

Redux主要提供三个东西来进行状态管理

1. Action

action创建函数

也就是只返回一个action的函数

export const SignUpEmailChange = (value) => ({
type: 'SIGNUP_EMAIL_CHANGE',
value: value,
})

action通常有一个type来进行判断要进行的动作,和任意其它的字段

2. Reducer

const registerChange = (state, action) => {
if (typeof state === 'undefined') {
return initialState
} else if(action.type === 'SIGNUP_NAME_CHANGE') {
return Object.assign({}, state, {
signUpForm: {
signup: true,
signupUsername: action.value,
signupEmail: state.signUpForm.signupEmail,
signupPwd: state.signUpForm.signupPwd,
},
})
}
...
}

Reducer拆分

当reducer膨胀时还可以进行拆分再用Redux提供的combineReducers进行组合

const Reducer = combineReducers({
ChatBar,
Message,
})

3. Store

使用createStore来创建Store

const store = createStore(
Reducer,
Initialize,
applyMiddleware(thunk)
);

第二个第三个参数都是可选的,第一个参数就是进行执行动作的Reducer,第二个是初始化state,第三个为中间件

通过Provider组件来进行分发组件

<Provider store={store}>
<Router history={browserHistory}>
<Route path="/" component={App}>
<IndexRoute component={Login} />
<Route path="/home" component={MainPanel} />
</Route>
</Router>
</Provider>

dispatch函数

store通过提供dispatch函数来对action的派发,流程也就是

dispatch接收一个action创建函数

dispatch(onSignup())

React-Redux

const Login = connect(
mapStateToProps,
mapDispatchToProps
)(SigninCmpt);

接收两个函数参数

mapStateToProps

主要负责把store映射到组件的props上

const mapStateToProps = (state) => ({
signup: state.signup,
})

mapDispatchToProps

一样是负责映射,把分发函数映射到组件的props上

const mapDispatchToProps = (dispatch) => ({
onSignup: () => {
dispatch(onSignup())
},
closeSignup: () => {
dispatch(closeSignup())
}
})

Redux-thunk

const fetchSignUp = (username, email, password) => {
const url = 'http://localhost:8008/api/signup';
const data = {
username: username,
email: email,
password: password,
};
console.log('fetch', data)
return fetch(url, {
method: 'POST', // or 'PUT'
body: JSON.stringify(data), // data can be `string` or {object}!
headers: new Headers({
'Content-Type': 'application/json'
})
}).then(res => res.json())
.then(response => console.log('Success:', response));
} export const SignUpUser = () => {
return (dispatch, getState) => {
// TODO fix parameters
fetchSignUp(getState().signUpForm.signupUsername, getState().signUpForm.signupEmail, getState().signUpForm.signupPwd)
.then(res => {
dispatch({
type: 'SIGNUP_USER',
sign: false,
})
})
}
}

thunk的在于能够将异步执行逻辑内聚在action中,其中实现利用的是Redux的中间件

MongoDB学习回顾

数据库类型

  • 游戏场景,使用 MongoDB 存储游戏用户信息,用户的装备、积分等直接以内嵌文档的形式存储.方便查询、更新- 物流场景,使用 MongoDB 存储订单信息,订单状态在运送过程中会不断更新,以 MongoDB 内嵌数组的形式来存储,一次查询就能将订单所有的变更读取出来。
  • 社交场景,使用 MongoDB 存储存储用户信息,以及用户发表的朋友圈信息,通过地理位置索引实现附近的人、地点等功能
  • 物联网场景,使用 MongoDB 存储所有接入的智能设备信息,以及设备汇报的日志信息,并对这些信息进行多维度的分析
  • 视频直播,使用 MongoDB 存储用户信息、礼物信息等

安装驱动包 && 看文档

今日完成

今天主要完成的就是在注册窗口的信息录入状态更改和到后台的验证录入响应

  1. 注册输入框的状态onChange进行接收action派发更改state更新每个输入框的内容

  2. 发送注册请求,利用redux-thunk先进行服务器请求,再进行dispatch

  3. 服务器端的接收请求和数据库的添加

  MongoClient.connect(url, { useNewUrlParser: true }, function(err, db) {
if (err) throw err;
var dbo = db.db("stackchat");
dbo.collection("user").insertOne(user, function(err, res) {
if (err) throw err;
console.log("insert success");
});
});
}
05-08 08:13