React Mobile 搭建记录
- __dirname 总是指向被执行 js 文件的绝对路径,./ 会返回你执行 node 命令的路径,例如你的工作路径。
- path.join()方法可以连接任意多个路径字符串。要连接的多个路径可做为参数传入。path.join()方法在接边路径的同时也会对路径进行规范化。
- path.resolve()方法可以将多个路径解析为一个规范化的绝对路径。其处理方式类似于对这些路径逐一进行cd操作,与cd操作不同的是,这引起路径可以是文件,并且可不必实际存在(resolve()方法不会利用底层的文件系统判断路径是否存在,而只是进行路径字符串操作)。
- config.devtool 选择方案config.devtool
- webpack2.x 中过滤错误new webpack.NoErrorsPlugin()在4.x中需要使用new webpack.NoEmitOnErrorsPlugin()
- webpack4 中的babel配置需要
"@babel/cli": “^7.4.3”,
“@babel/core”: “^7.4.3”,
“@babel/preset-env”: “^7.4.3”,
“@babel/preset-react”: “^7.0.0”,
“babel-loader”: “^8.0.5” - wepack4 自带代码分割功能 new webpack.optimize.CommonsChunkPlugin()此处需要注释
- react16.x Version 中使用上下文context的方法是:
export const {Provider,Consumer} = React.createContext();
<Provider value="dark">
<Header />
</Provider>
import { Consumer } from '@/router/Root'
<Consumer>{
( name ) =>
<div style={{ border: '1px solid blue', width: '60%', margin: '20px auto', textAlign: 'center' }}>
<p>子组件/获取父组件的值:{name}</p>
</div>
}</Consumer> - react16.x Version 中 react 自定义redux实现流程:
// CreateStore
function createStore(reducer, initialState = {}) {
// currentState就是那个数据
let currentState = initialState;
let listener = () => { }; function getState() {
return currentState;
}
function dispatch(action) {
console.log(action)
currentState = reducer(currentState, action); // 更新数据
listener(currentState); // 执行订阅函数
return action;
}
function subscribe(newListener) {
listener = newListener;
// 取消订阅函数
return function unsubscribe() {
listener = () => { };
};
}
return {
getState,
dispatch,
subscribe
};
}
// store && reducer
const store = createStore(function(state={}, action) {
switch (action.type){
case 'update':
return {...state, ...action.data}
default:
return state
}
});
// entry 入口
export default class Root extends Component {
render() {
return (
<Provider value={store}>
<Route path="/" component={Header} />
</Provider>
)
}
}
// Connect
export default function connect(mapStateToProps, mapDispatchToProps) {
return function (WrappedComponent) {
class Connect extends React.Component {
constructor(props) {
super(props)
this.store = {}
this.handleStoreChange.bind(this)
}
componentDidMount() {
// 组件加载完成后订阅store变化,如果store有变化则更新UI
this.unsubscribe = this.store.subscribe(this.handleStoreChange);
}
componentWillUnmount() {
// 组件销毁后,取消订阅事件
this.unsubscribe();
}
handleStoreChange(storeVal) {
// 更新之后的storeVal
console.log(storeVal)
// 更新UI
this.forceUpdate();
}
render() {
return (
<Consumer>{
( store ) => {
this.store = store;
return <WrappedComponent
{...this.props}
{...mapStateToProps(store.getState())} // 参数是store里面的数据
{...mapDispatchToProps(store.dispatch)} // 参数是store.dispatch
/>
}
}</Consumer>
);
}
}
Connect.contextTypes = {
store: PropTypes.object
};
return Connect;
};
}
// Children || Grandson
function mapStateToProps(state) {
return {
}
} function mapDispatchToProps(dispatch) {
return {
updateStore: function(data) {
console.log(data)
dispatch({type: 'update', data})
}
}
} const Header = connect(
mapStateToProps,
mapDispatchToProps
)(_Header); - 使用resolutions可以统一依赖包所引入的控件版本!
"resolutions": {
"antd/moment": "2.18.1",
"rc-calendar/moment": "2.18.1",
"rc-time-picker/moment": "2.18.1"
} - 在react、redux、react-router中使用react-router-redux集中管理路由的时候在react-router4.x以及更新的版本中不推荐使用react-router-redux(按照官方案例会报错Uncaught TypeError: Cannot read property ‘dispatch’ of undefined、at ConnectedRouter._this.handleLocationChange) 此处改用connected-react-router。
- react中可以从React引入Fragment来代替外层元素又或者可以使用数组进行return元素来带到去除多余的div效果。
- react中由于逻辑问题产生重复setState同一个值只会执行后一个,如果需要使用同步写法,可以采用函数式传参、回调、setTimeout加入队列的设置方法使它同步执行。
- react-router4 中如果要使用内嵌route来引入界面且需要传参的话可以使用render来传入自定义组件。
- 若想在jsx语法中使用style样式可引入styled-jsx来实现。
React Mobile 搭建记录的更多相关文章
- faster-rcnn(testing): ubuntu14.04+caffe+cuda7.5+cudnn5.1.3+opencv3.0+matlabR2014a环境搭建记录
python版本的faster-rcnn见我的另一篇博客: py-faster-rcnn(running the demo): ubuntu14.04+caffe+cuda7.5+cudnn5.1.3 ...
- py-faster-rcnn(running the demo): ubuntu14.04+caffe+cuda7.5+cudnn5.1.3+python2.7环境搭建记录
第一次写博客,以此纪念这几天安装caffe,跑faster-rcnn的血泪史.在此特别感谢网络各路大神,来自全球各地,让我能从中汲取营养,吸取经验,总结规律. faster-rcnn分为matlab版 ...
- 转载:用Dreamweave cs 5.5+PhoneGap+Jquery Mobile搭建移动开发
转载地址:http://blog.csdn.net/haha_mingg/article/details/7900221 移动设备应用开发有多难,只要学会HTML5+Javascript就可以.用Dr ...
- React项目搭建与部署
React项目搭建与部署 一,介绍与需求 1.1,介绍 1.1.1,React简介 React 是一个用于构建用户界面的 JAVASCRIPT 库. React主要用于构建UI,很多人认为 React ...
- 生产apollo搭建记录(五)
1. 生产apollo搭建记录(五) 1.1. 目标 搭建两个环境配置,dev和pro,但目前可用服务器限制,打算mysql用同一个,服务器分生产和测试 1.2. 数据库 建三个库 注意注意:在启 ...
- React性能优化记录(不定期更新)
React性能优化记录(不定期更新) 1. 使用PureComponent代替Component 在新建组件的时候需要继承Component会用到以下代码 import React,{Componen ...
- 12.2RAC搭建记录
12.2RAC环境搭建记录 安装前资源检查 资源限制要求/etc/security/limits.conf Table 6-1 Installation Owner Resource Limit Re ...
- RobotFramework测试环境搭建记录
Robotframwork测试环境搭建记录 1.安装Python2.7(https://www.python.org/) 在环境变量path中加入“C:\Python27” 安装后的验证方法为在命令行 ...
- 一、React Native 搭建开发环境(1)(Mac OS - IOS项目篇)
React Native是Facebook推出的一个开发IOS和安卓APP的技术.至于更多的详情,这里不再描述,大家可以自行百度它的定义. 原因:由于我想在一台电脑上同时开发IOS和Android两个 ...
随机推荐
- Effective Modern C++:03转向现代C++
07:在创建对象时注意区分()和{} 自C++11以来,指定初始化值的的方式包括使用小括号,等号,以及大括号: ); // initializer is in parentheses ; // ini ...
- Hdu 4493
题目链接 注意四舍五入,保留到小数点后两位(如果存在的话). 附上代码: /************************************************************** ...
- 错误信息:FATAL: No bootable medium found! System halted.
一.解决方法 先上1张图,显示的错误信息 再上2张图,幸好在之前安装了XP系统,不然还真不好解决.从图中可以看出WIN-XP和Linux系统安装好之后的差异,Linux的的存储信息上显示“第二通道没有 ...
- NEFU 118 n!后面有多少个0【数论】
http://acm.nefu.edu.cn/JudgeOnline/problemShow.php?problem_id=118 求n!后面有多少个0(1<=n<=1000000000) ...
- lavarel box 地址
https://atlas.hashicorp.com/laravel/boxes/homestead download URL https://atlas.hashicorp.com/laravel ...
- 动态设置iframe高度
<%//动态设置iframe高度 %><script language="javascript" type="text/javascript" ...
- iOS之友盟错误统计解决
http://www.cocoachina.com/ios/20150720/12627.html http://lieyunye.github.io/blog/2013/09/10/how-to-a ...
- 【MySQL基础】Mysql获得当前日期的所在月的第一天
Mysql获得当前日期的所在月的第一天 尊重劳动成果,请访问CSDN著者原文链接 http://blog.csdn.net/zixiao217/article/details/51908506 Ste ...
- @codeforces - 1205C@ Palindromic Paths
目录 @description@ @solution@ @accepted code@ @details@ @description@ 这是一道交互题. 现在有一个 n*n 的矩阵,每个位置是 0 或 ...
- concepts
webpack是JS应用程序的静态模块打包工具.webpack在处理你的应用时,会递归的构建依赖项,这些依赖项包括你的应用程序所需要的所有模块,然后把这些模块打包到一个或多个bundles中. 一.E ...