Skip to content

Latest commit

 

History

History
355 lines (330 loc) · 13.5 KB

readme.md

File metadata and controls

355 lines (330 loc) · 13.5 KB

5/20

  • 接着
  • 执行 yarn android 或者 yarn react-native run-android
  1. 启动Metro服务: 对 js 代码进行实时打包处理(类似 webpack)
  2. 应用自动安装到本机android设备上并开始运行

5/21

  • 将代码拉到笔记本上,
  • 继续查看官方文档

5/22

  • 在设备上运行(android 和 window设备)
  • android
  1. 开启设备 usb 调试

打开usb才能安装开发版本的app,默认只能从应用商店安装

  1. 连接设备

adb devices 控制台打印右边那列: 看到device说明你的设备已经被正确连接

  1. 运行应用

npx react-native run-android

If you get a "bridge configuration isn't available" error, see Using adb reverse. 提示:你还可以运行npx react-native run-android --variant=release来安装 release 版的应用。当然你需要先配置好签名,且此时无法再开启开发者菜单。注意在 debug 和 release 版本间来回切换安装时可能会报错签名不匹配,此时需要先卸载前一个版本再尝试安装。

  • 从设备上访问开发服务器
  1. android 5.0以下需要操作(通过无线网链接)(5.0,15年的拉吧)
  • 接下来快速刷新(应该就是热更新吧)(上面的还没有实操)

5/23

  • 快速刷新

就是react的快速刷新机制(热更新)

  1. 编辑组件(刷新当前组件)
  2. 编辑非组件(刷新关联的所有组件,文件)
  3. 编辑非组件并且,没有被组件树引用, (完全刷新)
  • 快速刷新(本地的 state 被重置的情况)
  1. class组件的state被重置(函数组件和hooks会保持)
  2. 当前模块有其他导出(非react组件)
  3. 返回一个class组件的情况
  • 强制重置

在文件中添加@refresh reset

5/25

  • 试验:连接手机
  1. 手机确认打开开发者模式,并且usb可以进行文件管理,但是无法通过adb devices 获取
  • 使用强制刷新
  1. 使用失败,无法证实使用方法正确

已经添加了// @refresh reset

  • 接下来进入调试
  1. To reload the app press "r"(刷新)
  2. To open developer menu press "d"(打开开发者菜单)
  3. LogBox: 生产环境自动禁用
  import { LogBox } form 'react-native';
  LogBox.ignoreLogs(['warning: ...']); // Ignore log notification by message: 忽略指定的日志
  LogBox.ignoreAllLogs(); // Ignore all log notifications(忽略所有日志)
  1. Chrome 开发者工具

开发者菜单中选择Debug JS Remotely,开启谷歌开发调试(最好是localhost不是ip)

  1. React Developer Tools

安装react-devtools npm install -g react -devools 依赖electron 安装完成后在命令行中执行react-devtools即可启动此工具:react-devtools

提示:如果你不想全局安装react-devtools,可以把它单独加入项目中。 用npm install --save-dev react-devtools命令把react-devtools包安装到你的项目中, 并在package.json的scripts中添加 "react-devtools": "react-devtools", 接着在项目根目录下运行npm run react-devtools命令即可。

  • 看了调试,但是很多不是特别理解,也没有去做.

5/26

  • 使用第三方库

大部分是英文,不是很了解,如果需要使用第三方,自行百度

  • 使用ts (已有项目添加ts)
yarn add --dev typescript @types/jest @types/react @types/react-native @types/react-test-renderer
# or for npm
npm install --save-dev typescript @types/jest @types/react @types/react-native @types/react-test-renderer
  1. 根目录添加tsconfig.json
{
  "compilerOptions": {
    "allowJs": true,
    "allowSyntheticDefaultImports": true,
    "esModuleInterop": true,
    "isolatedModules": true,
    "jsx": "react",
    "lib": ["es6"],
    "moduleResolution": "node",
    "noEmit": true,
    "strict": true,
    "target": "esnext"
  },
  "exclude": [
    "node_modules",
    "babel.config.js",
    "metro.config.js",
    "jest.config.js"
  ]
}
  1. 创建jest.config.js
module.exports = {
  preset: 'react-native',
  moduleFileExtensions: ['ts', 'tsx', 'js', 'jsx', 'json', 'node']
};
  1. js改名ts(保留./index.js入口文件)
  2. 类型检验yarn tsc

#### 5/27

  • 第三方库

npm install react-native-webview

  1. 尝试使用webview
  2. 发现无法启动项目(回复到昨天,重新启动)

报错内容: Unable to load script.Make sure you're either running a metro server( run 'react-native start' ) or that your bundle 'index.android.bundle' is packaged correctly for release. 无法加载脚本。请确保您运行的是Metro服务器(运行'react-native start')或者 您的软件包'index.android.bundle'已正确打包以供发布。

  1. https://blog.csdn.net/qq_36228442/article/details/92799579

应该是版本问题 直接使用方法2不行(可能是因为版本问题, 原文是0.59.4版本) 方法1,本地无法把react-native作为可运行程序

在前面增加yarn 才能执行(但也报错了,微博并没有解释这种情况)

  1. 过了
  • npx react-native info,查看当前版本的信息
  • 更新
  1. React Native CLI

https://www.react-native.cn/docs/upgrading

5/28

  • 重新启动 发现并无异常

没有上次的报错

  1. 尝试再次安装 webview

yarn add react-native-webview 再次执行yarn android 出现上次报错

  1. 关闭vs code,重新启动尝试

通过 npm scripts 快速启动成功(没有报错) 通过 yarn android

启动成功没有报错 和启动没有太大关系看来就是需要vscode重新起动就好了

  • 记性

index.android.bundle 报错解决办法

再次确认,遇到这样的问题,需要重新启动vscode就可以 yarn 比 npm 要快一些

  • 更新
  1. 博客更新文章

https://www.jianshu.com/p/ba0d68380906 通过官方推荐的升级助手 最好不要直接在package中修改版本号,引起很多问题

  1. 手动升级

已有的项目进行升级,可以init一个新项目,把代码拷过去 可以省去很多第三方库的升级问题

  • 设计-样式

当作react来写

  1. 行内样式建议写法

使用StyleSheet.creact来写组件的样式 疑问: 引入样式文件不好么? 文档: react native 的样式都是写在js文件里面的 文档: 和css有区别,不能使用'background-color'要使用驼峰

  1. 宽高

文档: 宽高都是无单位的 文档: Dimensions 这个对象用来获取设备宽高

  1. 布局

Flexbox 不同设备下的统一布局结构

flexbox直接使用,flex的常用属性 默认值不同1:direction默认colum 2: flex只能赋值数字 和flex布局相似, 使用 Align Self

  1. 图片

使用方法require(./xxx.jpg) 和flutter一样,会对 文件后缀进行区别引入

my-icon.ios.png和my-icon.android.png webview 还没用

5/29

  • 图片

Packager 会大保所有图片,并且根据屏幕精度提供对应资源 iphone7会使用[email protected],7 plus会使用[email protected] 如果没有图片恰好满足屏幕分辨率,则会自动选中最接近的一个图片 注意

  1. require(string)括号里面的值必须是字符串,不能写表达式
  2. 只有实际被require到的图片才会被打包
  3. 如果需要动态缩放图片,必须设置width:null和height:null(不理解)
  4. 网络图片需要设置宽高(加style)
  5. base64数据,使用'data:'格式来显示图片,并且手动设置图片的尺寸
  6. 背景图片组件<ImageBackground source={...} style={{width: '100%', height: '100%'}}> metro(即packager)配置文件 require可以引入的其他文件: 声音、视频或者文档文件

5/31

  • 颜色

React Native 支持 rgb() 和 rgba() 两种十六进制与函数方法 支持 hsl() 和 hsla() 函数方法: transparent

  • 交互 终于要开始写组件了
  1. Button
  2. Touchable系列组件

特点: 样式固定(如果需要自定义使用: TouchableOpacity/TouchableNativeFeedback)

TouchableHighlight 点击背景变色 TouchableOpacity 点击字体变色 TouchableWithoutFeedback 不显示任何视觉反馈 TouchableNativeFeedback 安卓下涟漪效果 onLongPress 属性上述组件都可以用

6/1

  • 导航

React Navigation

原生视图 性能优秀 动画方便 并没有说明用法,需要自己去官方查看 地址: https://reactnavigation.org/

  • 动画
  1. 必要性: 流畅有意义的动画对于移动端用户体验非常重要.现实生活中的惯性,可以通过动画实现
  2. 介绍: react native 提供了两个互补的系统

用于精细动画的Animated 全局动画的LayoutAnmated

  1. 复制第一个示例, ** 报错: Delete **

表示 行尾换行符不正确手动把CRLF换成LF就好了

使用yarn run lint --fix(或者全局替换:目前没有找到替换的方法,需要学习editorconfig) 动画还差一点就实现了

6/2

  • 继续动画
  1. 警告解除

**useNativeDriver is not supported ** 简单实现了渐变效果, toValue设置最终值(Animated.Value(x),x为初始值), duration为持续时间 Easing 它的作用是来设置我们要动画改变的value要以什么状态来改变

默认: easeInOut 曲线传达一个对象的逐渐加速到全速,最后逐渐减速到停止。

6/4

  • 继续动画
  1. 这一过程经过特别优化,执行效率会远高于反复调用setState和多次重渲染。
  • Animated.timing() 最常用的动画, 推动一个值按照一个缓动曲线而随时间变化

默认加速在减速

  1. 组合动画

Animated.parallel Animated.sequence Animated.stagger Animated.delay  示例 如果有一个动画发生停止中断,其他的动画也会被中断 项目无法启动

  1. 报错: system ui isn't responding

执行: 把虚拟机数据清空wipe data 重新启动 android 报错,(模拟器没有提示,控制台报错) Failed to install the app. Make sure you have the Android development environment set up: 重新启动 ,没有控制台报错,模拟器上爆红 貌似端口被占用的原因 重启成功

6/5

  • 启动项目之前先看端口号没有没有被占用

  • 合成

了解了,动画还可以自己

  • 插值

指将一定范围的输入值映射到另一组不同的输出值 interpolate()

  • 跟踪动态值

动画中的值,可以跟踪别的动态值的变化而变化

  • 跟踪手势

Animated.event 允许手势或其它事件直接绑定到动态值上。

  • LayoutAnimation

全局范围内创建和更新动画

  • 响应当前的动画值(获取当前动画的值 具体查看官网)

spring.stopAnimation(callback) spring.addListener(callback)

6/6

  • 手势响应系统 用户的一次触摸操作的真实意图是什么,App 要经过好几个阶段才能判断。
  1. 原生和 web app 得体验上,触摸响应就是一个关键因素
  2. 一般操作:

反馈/高亮- 用户看到按到了啥,松开手后会发生什么 取消功能- 当用户正在触摸操作时,应该是可以通过把手指移开来终止操作

  • TouchableHighlightTouchable 组件
  1. 响应者

Touchable 抽象响应系统,处理触控 onStartShouldSetResponder

View.props.onStartShouldSetResponder: (evt) => true,开始触摸时,返回是否成为响应者 View.props.onMoveShouldSetResponder: (evt) => true,开始移动时,是否愿意响应触摸交互呢(不是view得情况) 这一块有点不好消化, 目的只是了解, 后期再慢慢来

  • js运行环境
  • 定时器
  1. InteractionManager 执行需要长时间同步执行的任务(会等到当前所有得交互和动画执行完,再去执行)
  2. setImmediate requestAnimationFrame
  • 网络
  1. Fetch

如果你之前使用过XMLHttpRequest(即俗称的 ajax)或是其他的网络 API,那么 Fetch 用起来将会相当容易上手

fetch('https://mywebsite.com/endpoint/', {
  method: 'POST',
  headers: {
    Accept: 'application/json',
    'Content-Type': 'application/json'
  },
  body: JSON.stringify({
    firstParam: 'yourValue',
    secondParam: 'yourOtherValue'
  })
});
async function getMoviesFromApi() {
  try {
    // 注意这里的await语句,其所在的函数必须有async关键字声明
    let response = await fetch(
      'https://facebook.github.io/react-native/movies.json'
    );
    let responseJson = await response.json();
    return responseJson.movies;
  } catch (error) {
    console.error(error);
  }
}

WebSocket 支持

const ws = new WebSocket('ws://host.com/path');

ws.onopen = () => {
  // connection opened
  ws.send('something'); // send a message
};

ws.onmessage = (e) => {
  // a message was received
  console.log(e.data);
};

ws.onerror = (e) => {
  // an error occurred
  console.log(e.message);
};

ws.onclose = (e) => {
  // connection closed
  console.log(e.code, e.reason);
};

6/7

  • android 原生模块

有时候 App 需要访问平台 API,但 React Native 可能还没有相应的模块包装;或者你需要复用一些 Java 代码,而不是用 Javascript 重新实现一遍;又或者你需要实现某些高性能的、多线程的代码,譬如图片处理、数据库、或者各种高级扩展等等。 我们把 React Native 设计为可以在其基础上编写真正的原生代码,并且可以访问平台所有的能力。这是一个相对高级的特性,我们并不认为它应当在日常开发的过程中经常出现,但具备这样的能力是很重要的。如果 React Native 还不支持某个你需要的原生特性,你应当可以自己实现该特性的封装。

  1. 后面看的内容: 原生模块和原生ui组件, 都不是react语言,使用java开发,所以,只是看了看
  2. 接下来重点 全部放在,flutter,没找到rn项目之前,别想太多