React Native 实现原生模块 实现拨打电话功能

React Native 实现原生模块 实现拨打电话功能


Android js可用标签 IntentAndroid(0.16+)
IOS 可用 LinkingIOS

参考 API :http://react-native.cn/docs/native-modules-android.html#content

在onCreate 中

           mReactInstanceManager = ReactInstanceManager.builder()
            .addPackage(new SpringBoardPackages())

添加模块
我们首先来创建一个原生模块。一个原生模块是一个继承了ReactContextBaseJavaModule的Java类,它可以实现一些JavaScript所需的功能。我们这里的目标是让我们可以在JavaScript里写ToastAndroid.show(‘Awesome’, ToastAndroid.SHORT);,来调起一个Toast通知。

   private class SpringBoard extends ReactContextBaseJavaModule {
        Context context;
        public SpringBoard(ReactApplicationContext reactContext) {
            super(reactContext);
        }
        @ReactMethod
        public void gotoIMS(String number) {
            //用intent启动拨打电话
            Intent intent = new Intent(Intent.ACTION_CALL, Uri.parse("tel:" + number));
            MainActivity.this.startActivity(intent);
        }
        @Override
        public String getName() {
            return "SpringBoard";
        }
    }

定义内部类
我们需要在你的应用的Package类的createNativeModules方法中添加这个模块。如果一个模块没有被注册,它从JavaScript中也无法访问到。

 // 实现跳转功能
    private class SpringBoardPackages implements ReactPackage {
        @Override
        public List<NativeModule> createNativeModules(ReactApplicationContext context) {
            List<NativeModule> modules = new ArrayList<>();

            modules.add(new SpringBoard(context));
            return modules;
        }

        @Override
        public List<Class<? extends JavaScriptModule>> createJSModules() {
            return Collections.emptyList();
        }

        @Override
        public List<ViewManager> createViewManagers(ReactApplicationContext reactContext) {
            return null;
        }
    }

最后在js 中

var {
  //  添加 
NativeModules,
} = React;

    //调用模块方法
  var SpringBoard = NativeModules.SpringBoard;
        // 跳转到 IM 模块
        SpringBoard.gotoIMS("13696891101");

Demo 下载地址

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值