logo
分类于: 计算机基础 互联网 云计算&大数据

简介

React Native跨平台移动应用开发

React Native跨平台移动应用开发 7.8分

资源最后更新于 2020-03-29 04:08:26

作者:阙喜涛

出版社:出版社电子工业出版社

出版日期:2016-06

ISBN:9787121287077

文件格式: pdf

标签: 互联网 开发 网络 计算机 移动互联网 应用

简介· · · · · ·

React Native是Facebook公司最新推出的,强大的、开源的跨平台移动应用开发框架,它能大幅减少跨平台移动应用开发的工作量,并且代码结构清晰、简单易懂。同时React Native框架采用模块化结构,使应用版本的更新迭代非常简单。随着它的日趋成熟,React Native必然会成为移动应用开发的主流技术。《React Native跨平台移动应用开发》由浅入深、系统地介绍了使用React Native框架跨平台开发所需要用到的知识。《React Native跨平台移动应用开发》每一章都专注于阐述某一方面的知识,配合若干个原创的、精小的例程,能让读者系统、快速地掌握该方面知识。《React Native跨平台移动应用开发》是按照有基本的编程基础知识,刚学习JavaScript基本语法的读者最佳学习路径来编写的。有一定基础的开发人员也可以将本书作为React Native开发的“字典”来使用,在开发时可以快速查找相关知识点的细节。阙喜涛,湖南省吉首市人,北京邮电大学研究生,专注智能手机应用开发十一年,任职于东信北邮信息技术有限公司,先后参与开发过中国移动POC系统、贵州移动一卡多号系统、浙江移动应用商店系统开发等等。开发移动应用下载量超过25万。

想要: 点击会收藏到你的 我的收藏,可以在这里查看

已收: 表示已经收藏

Tips: 注册一个用户 可以通过用户中心得到电子书更新的通知哦

目录

  1. 前言
  2. 第1章 React Native
  3. 1.1 React Native开发特点
  4. 1.1.1 一次学习,随处编写
  5. 1.1.2 混合开发
  6. 1.1.3 高效的UI开发
  7. 1.1.4 高效的UI调试
  8. 1.1.5 学习门槛低、开发难度低
  9. 1.1.6 开发软硬件要求低
  10. 1.1.7 使用React Native开发的代价
  11. 1.1.8 为什么React Native尚未流行
  12. 1.2 React Native开发环境搭建
  13. 1.2.1 开发环境搭建起点
  14. 1.2.2 Windows操作系统下React Native开发环境搭建
  15. 1.2.3 苹果操作系统下React Native开发环境搭建
  16. 1.2.4 查看与删除使用npm命令安装的软件
  17. 1.3 代码编辑环境搭建
  18. 1.3.1 Sublime Text3
  19. 1.3.2 开发用插件
  20. 1.3.3 Sublime界面风格选择
  21. 1.3.4 键盘使用习惯
  22. 1.4 React Dev tool安装
  23. 第2章 状态机思维与状态机变量
  24. 2.1 初始化项目
  25. 2.2 运行项目
  26. 2.2.1 使用Android手机进行调测
  27. 2.2.2 使用iPhone手机或模拟器进行调测
  28. 2.2.3 修改JSX代码
  29. 2.2.4 ES6语法与ES5语法
  30. 2.2.5 启动调试工具
  31. 2.3 构建注册页面
  32. 2.4 React Native代码执行逻辑
  33. 2.5 UI框架工作基本机制
  34. 2.5.1 状态机思维
  35. 2.5.2 “冒充常量”的状态机变量
  36. 2.5.3 “无处安放”的状态机变量
  37. 2.5.4 “努力瘦身”的状态机变量
  38. 2.6 React Native组件间通信
  39. 2.7 深入理解UI重新渲染的过程
  40. 2.7.1 合并状态机变量
  41. 2.7.2 判断是否渲染
  42. 2.7.3 替换状态机变量
  43. 2.7.4 强制启动渲染
  44. 2.7.5 渲染过程
  45. 2.7.6 合并状态机变量的最简语法
  46. 2.8 React Native组件的成员变量
  47. 2.9 React Native组件的静态变量、静态函数
  48. 第3章 页面导航、弹出框及深入理解属性
  49. 3.1 分离注册组件、组件平台自适配
  50. 3.1.1 分离注册组件
  51. 3.1.2 组件平台自适配
  52. 3.1.3 平台检测
  53. 3.2 导航组件、挂接注册组件
  54. 3.3 挂接注册等待组件
  55. 3.4 Navigator组件工作机制
  56. 3.4.1 push与pop
  57. 3.4.2 replace函数
  58. 3.5 自定义组件
  59. 3.5.1 “弹出一切框”的实现
  60. 3.5.2 React Native中颜色类型的值
  61. 3.5.3 挂接自定义组件
  62. 3.6 BackAndroid API的bug与解决办法
  63. 3.7 属性确认
  64. 3.8 指定属性默认值
  65. 3.9 Alert应用程序编程接口
  66. 3.9.1 弹出确认框
  67. 3.9.2 弹出选择框
  68. 3.10 带导航栏的页面导航
  69. 第4章 混合开发基础篇
  70. 4.1 iOS平台混合开发
  71. 4.1.1 与iOS侧原生代码消息互通
  72. 4.1.2 React Native代码到iOS原生代码的消息
  73. 4.1.3 iOS原生代码到React Native代码的消息
  74. 4.1.4 与iOS OC原生代码界面的切换
  75. 4.1.5 应用初始界面设定
  76. 4.1.6 iOS混合开发中传递的参数类型
  77. 4.1.7 混合开发中的多线程使用
  78. 4.1.8 原生代码实现Promise机制
  79. 4.1.9 跨语言常量
  80. 4.2 Android平台混合开发
  81. 4.2.1 与Android原生代码消息互通
  82. 4.2.2 React Native代码到Android原生代码的消息
  83. 4.2.3 与Android原生代码界面的切换
  84. 4.2.4 Android原生代码到React Native代码的消息
  85. 4.2.5 应用初始界面设定
  86. 4.2.6 传递的参数类型
  87. 4.2.7 回调函数与Promise机制
  88. 4.2.8 监听ActivityResult与Android生命周期事件
  89. 4.2.9 混合开发中的多线程机制
  90. 4.2.10 跨语言常量
  91. 第5章 flexbox布局、View、Image与可触摸组件
  92. 5.1 flexbox布局
  93. 5.1.1 位置及宽、高相关样式键
  94. 5.1.2 决定子组件排列规则的键
  95. 5.1.3 决定组件显示规则的键
  96. 5.1.4 边框、空隙与填充
  97. 5.1.5 组件多样式声明与动态样式声明
  98. 5.2 View组件
  99. 5.2.1 View组件的颜色与边框
  100. 5.2.2 View组件的阴影与其他视觉效果
  101. 5.2.3 View组件的变形
  102. 5.2.4 View组件的回调函数
  103. 5.2.5 View组件的其他属性
  104. 5.2.6 设备放置状态、根View与onLayout回调函数
  105. 5.2.7 pointerEvents属性
  106. 5.3 Image组件
  107. 5.3.1 加载网络图片
  108. 5.3.2 加载静态图片资源
  109. 5.3.3 加载资源文件中的图片
  110. 5.3.4 动态加载手机中的图片资源
  111. 5.3.5 Image组件的样式
  112. 5.3.6 Image组件显示特性
  113. 5.3.7 Image组件的其他属性
  114. 5.4 可触摸组件
  115. 5.4.1 可触摸组件类型
  116. 5.4.2 TouchableOpacity组件
  117. 5.4.3 TouchableHighlight组件
  118. 5.4.4 其他属性
  119. 5.5 加深理解三大组件
  120. 5.5.1 使用导航栏的导航框架
  121. 5.5.2 等比放大无丢失显示图片
  122. 5.5.3 宽、高动态变化的组件呈现
  123. 第6章 Text、TextInput等相关知识
  124. 6.1 Text组件
  125. 6.1.1 样式键设置
  126. 6.1.2 其他属性
  127. 6.1.3 Text组件的嵌套
  128. 6.1.4 文本显示的阴影效果
  129. 6.1.5 Text居中显示
  130. 6.1.6 在字符串中插入图像
  131. 6.2 Text组件在两个平台上的不同表现
  132. 6.2.1 只指定fontSize,不指定height
  133. 6.2.2 只指定height,不指定fontSize
  134. 6.2.3 fontSize等于height
  135. 6.2.4 height大于fontSize
  136. 6.2.5 边框在两个平台上的不同表现
  137. 6.3 TextInput组件
  138. 6.3.1 TextInput组件样式键
  139. 6.3.2 TextInput组件的属性
  140. 6.3.3 TextInput组件iOS平台专有属性
  141. 6.3.4 TextInput组件Android平台专有属性
  142. 6.3.5 TextInput组件的成员函数
  143. 6.4 TextInput组件在两个平台上的不同表现
  144. 6.4.1 Android平台的输入下画线
  145. 6.4.2 父组件的alignItems键失效
  146. 6.4.3 只指定fontSize、不指定height
  147. 6.4.4 height等于fontSize
  148. 6.4.5 height大于fontSize
  149. 6.4.6 边框在两个平台上的不同表现
  150. 6.5 TextInput组件的生命周期
  151. 6.5.1 获得焦点
  152. 6.5.2 用户输入
  153. 6.5.3 用户按下提交键
  154. 6.5.4 失去焦点
  155. 6.6 软键盘与键盘事件
  156. 6.7 组件的引用
  157. 6.7.1 定义组件引用
  158. 6.7.2 得到系统定义的组件引用
  159. 6.7.3 调用组件的公开成员函数
  160. 6.7.4 重新设定组件的属性
  161. 6.7.5 获得组件的位置
  162. 6.8 跨平台状态栏组件
  163. 6.8.1 StatusBar组件属性
  164. 6.8.2 StatusBar组件使用示例
  165. 6.8.3 手机状态栏在开发中的处理
  166. 6.8.4 StatusBarIOS API
  167. 6.9 高度自增长的扩展TextInput组件
  168. 6.10 访问操作系统剪贴板
  169. 第7章 组件生命周期、数据存储及React Native应用实现步骤
  170. 7.1 组件生命周期
  171. 7.1.1 getInitialState
  172. 7.1.2 getDefaultProps
  173. 7.1.3 componentWillMount
  174. 7.1.4 componentDidMount
  175. 7.1.5 componentWillReceiveProps
  176. 7.1.6 shouldComponentUpdate
  177. 7.1.7 componentWillUpdate
  178. 7.1.8 componentDidUpdate
  179. 7.1.9 componentWillUnmount
  180. 7.2 读取JSON文件
  181. 7.3 数据持久化操作
  182. 7.3.1 flow语法检查器
  183. 7.3.2 写入数据、错误捕捉
  184. 7.3.3 读取数据
  185. 7.3.4 AsyncStorage API存储数据的无序性
  186. 7.3.5 删除数据
  187. 7.3.6 修改数据
  188. 7.3.7 JSON对象存储
  189. 7.3.8 读取JSON对象
  190. 7.4 数据表操作
  191. 7.5 React Native应用实现步骤、日记例程(上)
  192. 7.5.1 应用原型
  193. 7.5.2 基础组件结构设计
  194. 7.5.3 使用React Native组件搭建静态界面
  195. 7.5.4 React Native组件分层
  196. 7.5.5 实现各组件业务逻辑
  197. 7.5.6 日记例程(上)总结
  198. 第8章 ScrollView和ListView
  199. 8.1 ScrollView组件
  200. 8.1.1 ScrollView组件属性
  201. 8.1.2 ScrollView组件iOS平台专有属性
  202. 8.1.3 ScrollView组件Android平台专有属性
  203. 8.1.4 ScrollView组件的公开成员函数
  204. 8.1.5 RefreshControl组件
  205. 8.1.6 ScrollView组件基本用法
  206. 8.2 ListView组件
  207. 8.2.1 ListView组件的回调函数
  208. 8.2.2 ListView组件的其他属性
  209. 8.2.3 ListView组件的成员函数
  210. 8.3 简单的列表
  211. 8.3.1 准备列表的数据源
  212. 8.3.2 声明状态机变量
  213. 8.3.3 将数据源中的数据拷贝到DataSource中
  214. 8.3.4 定义如何渲染列表中的每一行
  215. 8.3.5 实现简单的列表
  216. 8.3.6 列表栏的高级处理
  217. 8.4 带分段标志的列表
  218. 8.4.1 准备数据源
  219. 8.4.2 声明状态机变量
  220. 8.4.3 将数据源中的数据拷贝到DataSource中
  221. 8.4.4 定义如何渲染每个分栏
  222. 8.4.5 定义如何渲染首、尾栏
  223. 8.4.6 列表间隔渲染
  224. 8.4.7 实现带分段标志的列表
  225. 8.4.8 总结
  226. 8.5 日记例程(下)总结
  227. 第9章 等待提示条、进度条和Switch
  228. 9.1 ProgressBarAndroid组件
  229. 9.1.1 ProgressBarAndroid组件样式设置
  230. 9.1.2 ProgressBarAndroid其他属性
  231. 9.1.3 Android平台等待提示条
  232. 9.1.4 React Native框架中定时器的使用
  233. 9.1.5 Android平台进度条
  234. 9.2 iOS进度条组件
  235. 9.2.1 ProgressViewIOS组件样式设置
  236. 9.2.2 ProgressViewIOS其他属性
  237. 9.2.3 iOS平台进度条
  238. 9.3 iOS平台等待提示条
  239. 9.3.1 ActivityIndicatorIOS组件样式设置
  240. 9.3.2 ActivityIndicatorIOS其他属性
  241. 9.3.3 iOS平台等待提示条例程
  242. 9.4 Switch组件
  243. 9.4.1 Switch组件样式设置
  244. 9.4.2 Switch其他属性
  245. 9.4.3 Switch组件的使用
  246. 第10章 导航组件
  247. 10.1 导航组件的属性
  248. 10.1.1 回调函数
  249. 10.1.2 其他属性
  250. 10.2 导航器
  251. 10.3 NavigationBar
  252. 第11章 手势识别
  253. 11.1 PanResponder API
  254. 11.2 监视器
  255. 11.2.1 指定监视区域
  256. 11.2.2 定义监视器相关变量
  257. 11.2.3 准备监视器的事件处理函数
  258. 11.2.4 建立监视器
  259. 11.2.5 将监视器与监视区域挂接
  260. 11.3 监视事件的生命周期
  261. 11.3.1 单次点击事件的生命周期
  262. 11.3.2 单次点击事件处理
  263. 11.3.3 移动手势事件的生命周期
  264. 11.3.4 监视器异常事件
  265. 11.4 手势识别处理例程
  266. 11.4.1 单点手势——点击、拖动选择百分比参数
  267. 11.4.2 单点手势——带导槽的滑动来电接听或拒接界面
  268. 11.4.3 单点手势——滑动解锁屏幕界面
  269. 11.4.4 单点手势——单点任意方向拉动选择界面
  270. 11.4.5 两点手势
  271. 第12章 网络
  272. 12.1 获取网络状态
  273. 12.1.1 得到当前网络状态
  274. 12.1.2 监听网络状态改变事件
  275. 12.1.3 简单判断是否有网络连接
  276. 12.1.4 判断当前连接是否收费
  277. 12.2 通过HTTP、HTTPS与网络侧交换数据
  278. 12.2.1 发送请求
  279. 12.2.2 接收响应
  280. 12.3 在React Native开发中使用AJAX技术
  281. 第13章 网页浏览器、音视频媒体播放
  282. 13.1 WebView组件样式设置
  283. 13.2 WebView组件其他属性
  284. 13.2.1 非回调函数属性
  285. 13.2.2 回调函数属性
  286. 13.2.3 平台独有属性
  287. 13.2.4 WebView组件成员函数
  288. 13.3 网页浏览器使用例程
  289. 13.3.1 浏览网页例程
  290. 13.3.2 加载本地网页例程
  291. 13.4 音视频媒体播放
  292. 第14章 图片的遍历、存取与显示
  293. 14.1 React Native开发中iOS平台链接库的使用
  294. 14.2 获取手机中所有的图片信息
  295. 14.3 图片信息详解
  296. 14.3.1 Android平台图片信息
  297. 14.3.2 iOS平台图片信息
  298. 14.4 显示从CameraRoll API得到的图片
  299. 14.5 为用户提供图片选择界面
  300. 14.6 图片的保存与读取显示
  301. 14.6.1 保存图片数据
  302. 14.6.2 读取并显示图片
  303. 第15章 选择器、位置相关和应用状态
  304. 15.1 日期、时间选择器
  305. 15.1.1 DatePickerAndroid API
  306. 15.1.2 TimePickerAndroid API
  307. 15.1.3 DatePickerIOS组件
  308. 15.2 Picker组件
  309. 15.2.1 Picker组件的样式设置
  310. 15.2.2 Picker组件的属性
  311. 15.2.3 Picker.Item组件属性
  312. 15.2.4 Picker组件例程
  313. 15.3 PickerIOS
  314. 15.4 MapView组件
  315. 15.4.1 MapView组件样式设置
  316. 15.4.2 MapView组件特有的跨平台属性
  317. 15.4.3 MapView组件例程
  318. 15.5 AppState API
  319. 15.5.1 AppState API用途与用法
  320. 15.5.2 AppState API例程
  321. 15.6 获取地理位置
  322. 15.7 VibrationIOS API
  323. 第16章 使用ES6语法开发
  324. 16.1 React Native组件导入
  325. 16.2 属性声明
  326. 16.3 成员变量声明
  327. 16.4 状态机变量声明
  328. 16.5 回调函数绑定
  329. 16.6 类的静态成员变量与静态成员函数
  330. 第17章 混合开发高级篇
  331. 17.1 使用Objective-C语言创建私有的React Native组件
  332. 17.1.1 增加FLAnimatedImage链接库
  333. 17.1.2 创建视图管理类
  334. 17.1.3 封装开源代码中的视图类
  335. 17.1.4 在React Native侧调用私有组件
  336. 17.1.5 例程运行效果
  337. 17.2 使用Swift语言创建私有的React Native组件
  338. 17.2.1 整合开源项目
  339. 17.2.2 建立组件管理者和桥接头文件
  340. 17.2.3 Objective-C与React Native接口部分
  341. 17.2.4 使用Swift语言实现组件控制
  342. 17.2.5 在React Native侧调用私有组件
  343. 17.2.6 例程运行效果
  344. 17.3 使用Android SDK创建私有的React Native组件
  345. 17.3.1 准备原生代码UI组件
  346. 17.3.2 实现原生UI管理类
  347. 17.3.3 创建原生UI实例
  348. 17.3.4 实现对属性的支持
  349. 17.3.5 建立原生UI包
  350. 17.3.6 注册原生UI管理类
  351. 17.3.7 对应的React Native侧实现
  352. 17.3.8 运行俯视视图例程
  353. 第18章 项目配置、生成发布版本安装包及其他
  354. 18.1 iOS平台项目配置
  355. 18.2 iOS平台应用发布
  356. 18.3 Android平台项目配置
  357. 18.4 Android平台应用生成发布版本安装包
  358. 18.4.1 生成发布密钥
  359. 18.4.2 修改gradle配置文件
  360. 18.4.3 生成发布版本安装包
  361. 18.5 其他组件与API
  362. 18.5.1 动画相关
  363. 18.5.2 其他未讨论的组件与API
  364. 附录A ECMAScript2015语法参考