坑中速记整理! 使用 kotlin 写第一个 ReactNative Android 模块

本文主要是介绍坑中速记整理! 使用 kotlin 写第一个 ReactNative Android 模块,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

预览
Kotlin 和 Swift, 两大新宠! 借 ReactNative 熟悉下 kotlin 的用法,不料掉坑里面了.昨晚花了大半夜,趁这会儿思路清晰,把涉及到的一些关键信息,迅速整理下.

最佳的使用 Kotlin 快速开始写Android模块的方式

  1. react-native init AwesomeProject 生成的 android 目录,是一个标准的 Android Studio 工程,详见: http://facebook.github.io/react-native/docs/getting-started.html
  2. 直接在 Android Studio 中打开 AwesomeProject/android 目录.
  3. 参考文章 http://facebook.github.io/react-native/docs/native-modules-android.html,先用 java 实现
  4. 顶部菜单 –> code –> Convert Java File to Kotlin File ,自动转换为 kotlin .
package com.awesomeproject.AnExampleReactPackageimport android.widget.Toastimport com.facebook.react.bridge.ReactApplicationContext
import com.facebook.react.bridge.ReactContextBaseJavaModule
import com.facebook.react.bridge.ReactMethodimport java.util.HashMap/*** Created by yanfeng on 2017/10/12.*/class ToastModule(reactContext: ReactApplicationContext) : ReactContextBaseJavaModule(reactContext) {override fun getName(): String {return "ToastExample"}override fun getConstants(): Map<String, Any>? {val constants = HashMap<String, Any>()constants.put(DURATION_SHORT_KEY, Toast.LENGTH_SHORT)constants.put(DURATION_LONG_KEY, Toast.LENGTH_LONG)return constants}@ReactMethodfun show(message: String, duration: Int) {Toast.makeText(reactApplicationContext, message, duration).show()}companion object {private val DURATION_SHORT_KEY = "SHORT"private val DURATION_LONG_KEY = "LONG"}
}

一些坑中的经验

  • 如果 ReactNative 初始化慢,可以改用淘宝源,后面的 –verbose 参数,主要用来辨别是否卡住.
npm install -g nrm
nrm use taobao
npm install -g react-native-cli --verbose
react-native init AwesomeProject --verboses
  • RN 与已有项目集成的原理是,把已有的 Android 项目复制到 android 文件夹,然后改下配置.

  • 如果没有已有的运行良好的项目,不要尝试用 Android Studio 直接新建项目,因为 Android Studio 的默认 SDK 版本(25.3.1) 和 ReactNative 的SDK版本(23.0.1) 不一致,所以在根据 RN 文档,改配置,会遇到各种问题.如果非要模拟,建议直接基于 AwesomeProject/android 这个项目改.

  • 改淘宝源,可以加快速度,但是每次安装还是需要 20~40 分钟(取决于网络环境等).如果本地再起一个 sinopia ,这样第二次初始化 RN 时,只需要 3 ~ 5 分钟.详见: https://github.com/rlidwka/sinopia

  • 如果遇到 All com.android.support libraries must use the exact same version specification 一类的错误,又必须解决的话,可以尝试查看依赖关系,看到底是哪里在冲突:

命令是:

./gradlew -q dependencies app:dependencies --configuration compile

可能的输出:

+--- com.android.support.constraint:constraint-layout:1.0.0-beta2
|    \--- com.android.support.constraint:constraint-layout-solver:1.0.0-beta2
\--- com.facebook.react:react-native:+ -> 0.20.1+--- com.google.code.findbugs:jsr305:3.0.0+--- com.facebook.stetho:stetho-okhttp:1.2.0|    +--- com.google.code.findbugs:jsr305:2.0.1 -> 3.0.0|    +--- com.facebook.stetho:stetho:1.2.0|    |    +--- com.google.code.findbugs:jsr305:2.0.1 -> 3.0.0|    |    \--- commons-cli:commons-cli:1.2|    \--- com.squareup.okhttp:okhttp:2.2.0 -> 2.5.0|         \--- com.squareup.okio:okio:1.6.0+--- com.squareup.okhttp:okhttp-ws:2.5.0|    \--- com.squareup.okhttp:okhttp:2.5.0 (*)+--- com.facebook.fresco:fresco:0.8.1|    +--- com.facebook.fresco:imagepipeline:0.8.1|    |    +--- com.nineoldandroids:library:2.4.0|    |    +--- com.facebook.fresco:fbcore:0.8.1|    |    +--- com.android.support:support-v4:21.0.3 -> 23.0.1|    |    |    \--- com.android.support:support-annotations:23.0.1|    |    \--- com.parse.bolts:bolts-android:1.1.4|    +--- com.facebook.fresco:fbcore:0.8.1|    \--- com.facebook.fresco:drawee:0.8.1|         +--- com.facebook.fresco:fbcore:0.8.1|         \--- com.android.support:support-v4:21.0.3 -> 23.0.1 (*)+--- org.webkit:android-jsc:r174650+--- com.fasterxml.jackson.core:jackson-core:2.2.3+--- com.squareup.okhttp:okhttp:2.5.0 (*)+--- com.facebook.fresco:imagepipeline-okhttp:0.8.1|    +--- com.squareup.okhttp:okhttp:2.3.0 -> 2.5.0 (*)|    +--- com.facebook.fresco:imagepipeline:0.8.1 (*)|    \--- com.facebook.fresco:fbcore:0.8.1+--- com.squareup.okio:okio:1.6.0+--- com.android.support:recyclerview-v7:23.0.1|    +--- com.android.support:support-v4:23.0.1 (*)|    \--- com.android.support:support-annotations:23.0.1+--- com.facebook.stetho:stetho:1.2.0 (*)\--- com.android.support:appcompat-v7:23.0.1\--- com.android.support:support-v4:23.0.1 (*)(*) - dependencies omitted (listed previously)
  • kotlin,会自动引入库; java,点击提示不存在的类,然后使用 Alt + 回车 也可以快速引入.

  • RN 的文档可能是错的.如果提示方法名总是不对,可以尝试下手动输入,看下提示,可能真的变了.

  • 执行 react-native run-android 可能比在 Android Studio 中运行方便;但是第二次执行原生 Android 代码时, Android Studio Run Build 的速度非常快,是更好的选择.

  • 如果是真机,可能需要:

adb reverse tcp:8081 tcp:8081
  • 遇到诡异的问题时,可以尝试先: clean build

源码参考:

https://github.com/ios122/kotlin-module-sample-for-reactnative

参考文章

  • Init project hangs forever

这篇关于坑中速记整理! 使用 kotlin 写第一个 ReactNative Android 模块的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/526209

相关文章

使用Redis快速实现共享Session登录的详细步骤

《使用Redis快速实现共享Session登录的详细步骤》在Web开发中,Session通常用于存储用户的会话信息,允许用户在多个页面之间保持登录状态,Redis是一个开源的高性能键值数据库,广泛用于... 目录前言实现原理:步骤:使用Redis实现共享Session登录1. 引入Redis依赖2. 配置R

使用Python的requests库调用API接口的详细步骤

《使用Python的requests库调用API接口的详细步骤》使用Python的requests库调用API接口是开发中最常用的方式之一,它简化了HTTP请求的处理流程,以下是详细步骤和实战示例,涵... 目录一、准备工作:安装 requests 库二、基本调用流程(以 RESTful API 为例)1.

Python按照24个实用大方向精选的上千种工具库汇总整理

《Python按照24个实用大方向精选的上千种工具库汇总整理》本文整理了Python生态中近千个库,涵盖数据处理、图像处理、网络开发、Web框架、人工智能、科学计算、GUI工具、测试框架、环境管理等多... 目录1、数据处理文本处理特殊文本处理html/XML 解析文件处理配置文件处理文档相关日志管理日期和

Python38个游戏开发库整理汇总

《Python38个游戏开发库整理汇总》文章介绍了多种Python游戏开发库,涵盖2D/3D游戏开发、多人游戏框架及视觉小说引擎,适合不同需求的开发者入门,强调跨平台支持与易用性,并鼓励读者交流反馈以... 目录PyGameCocos2dPySoyPyOgrepygletPanda3DBlenderFife

Python标准库datetime模块日期和时间数据类型解读

《Python标准库datetime模块日期和时间数据类型解读》文章介绍Python中datetime模块的date、time、datetime类,用于处理日期、时间及日期时间结合体,通过属性获取时间... 目录Datetime常用类日期date类型使用时间 time 类型使用日期和时间的结合体–日期时间(

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

Python yield与yield from的简单使用方式

《Pythonyield与yieldfrom的简单使用方式》生成器通过yield定义,可在处理I/O时暂停执行并返回部分结果,待其他任务完成后继续,yieldfrom用于将一个生成器的值传递给另一... 目录python yield与yield from的使用代码结构总结Python yield与yield

Go语言使用select监听多个channel的示例详解

《Go语言使用select监听多个channel的示例详解》本文将聚焦Go并发中的一个强力工具,select,这篇文章将通过实际案例学习如何优雅地监听多个Channel,实现多任务处理、超时控制和非阻... 目录一、前言:为什么要使用select二、实战目标三、案例代码:监听两个任务结果和超时四、运行示例五

python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

《python使用Akshare与Streamlit实现股票估值分析教程(图文代码)》入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存... 目录一、前言二、核心知识点梳理1、Akshare数据获取2、Pandas数据处理3、Matplotl

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的