react细节

北城以北 提交于 2019-12-06 13:54:19

1.在函数式组件中使用 类型和默认值

function App({ name }) {
  return (
    <div>
      <h1>{name}</h1>
    </div>
  )
}

App.prototype = {
  name: types.string.isRequired        func / number / symbol / object
}
App.defaultProps = {
  name: "wanglei1234"
}

 

当父组件的render函数被运行时,的子组件render函数也会重新执行

 

 

虚拟DOM的好处

 

1.性能提升了

2.它使得跨端应用得以实现(虚拟DOM不生成真实DOM生成原生的应用的组件)

 

 

 

 

 

Diff算法 比对虚拟DOM(js对象)

 

同级比对  +  key值比对

 

一致继续比较第二层

 

不一致:不再进行下一步比较

 

 

 

好处是比对算法非常简单

 

 

 

为什么setState要设计成异步函数

 

多次短时间的操作合并成一次操作  减少比对虚拟DOM的次数

 

 

 

 

 

循环的时候 key的意义  比对key值做关联

 

为什么key值不要设置为index

 

因为插入数组的时候,divindex可能变成其他divindex

 

导致key值不稳定,失去了存在的意义

 

 

 

 

 

Redux设计使用的三项原则

 

1.store是唯一的

 

2.只有store改变自己的内容   

 

3.reducer必须是函数

 

 

 

store拿到reducer返回的数据,然后store来进行更新的,这也是为什么reducer一定不要直接改变store里面的内容

 

 

 

Reducer必须是纯函数,所以里面不能有异步操作和时间相关的操作

 

 

 

中间指的是 actionstore的中间,redux-thunk只是dispatch的升级

 

 

 

background-size: contain;  表示让图片包含在div正常大小

 

&::placeholder {
    color: #999;
  }
改变placeholder 的字体颜色

 

 

获取动态路由参数: this.props.match.params.id  

 

回到顶部功能

window.scrollTo(0,0)

 

函数式编程给测试带来了便捷

bind(this,index) 可以bind里面传递参数

 

解析html    可能存在XSS攻击
<li  dangerouslySetInnerHTML={{__html:item}} />

label扩大点击区域
<label   htmlFor=’inputa’>输入内容</label>
<input   id=”inputa”  />

只要父组件的render函数重新被执行了,子组件的该函数就会被执行

 

//如果这个组件第一次存在父组件中,不会被执行

 

//如果这个组件之前已经存在于父组件中,才会被执行

 

 

registerServiceWorker的作用

 

PWA   progressive web application 写手机app应用

 

第二次访问会缓存

 

 

 

sagas文件(saga.js)一定要导出generator函数
function* getInitData(){
  try{
    const res = yield axios.get('/api/getList.json');
    const action = initListData(res.data);
    yield put(action);
  }catch(e){
    console.log('网络请求失败');
  }
}

function* mySaga() {
  yield takeEvery(actionTypes.Get_Init_Data, getInitData);
}
  // 后面执行的函数 可以是普通函数
export default mySaga;
import { takeEvery,put } from ‘redux-saga/effects’;
put 相当于store.dispatch()

 

 

把state 数据对象转化成immutable 对象 fromJS方法
import { fromJS } from 'immutable';

const defaultState = fromJS({  把js对象转化成immutable对象
  focused:false
});

export default (state = defaultState,action)=>{
    return state.set('focused',!state.get('focused'));
  }
  return state;
}

const mapStateToProps = (state)=>({
  focused:state.header.get('focused')  immutable数据调用方法
});


redux-immutable 模块的使用  yarn add redux-immutable
const mapStateToProps = (state)=>({
  focused:state.header.get('focused') immutable数据调用方法
});   

import { combineReducers } from 'redux';
const reducer = combineReducers({
  header: HeaderReducer
});
export default reducer;

只需要把 import { combineReducers } from 'redux';
改为 import { combineReducers } from 'redux-immutable';
即可
const mapStateToProps = (state)=>({
  focused:state.get(‘header’).get('focused') //immutable数据调用方法
});  
也可以
const mapStateToProps = (state)=>({
  focused:state.getIn([‘header’,’focused’]) 
});
里面的 list也是 immutable数组  所以不能这么改
在前面将其转化为不可变的  fromJS(data)
import { fromJS} from ‘immutable’

list.toJS()  immutable 不能直接进行 下标操作

 

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!