RN原生封装组件

Android代码:

创建组件WebViewManager类

继承:extends SimpleViewManager

public class WebViewManager extends SimpleViewManager<WebView> {

    //返回JS调用时候使用的名称
    @Override
    public String getName() {
        return "RCTWebView";

    }

    //用于创建初始化的实例控件对象
    @Override
    protected WebView createViewInstance(ThemedReactContext reactContext) {
        WebView webView = new WebView(reactContext);
        webView.setWebViewClient(new WebViewClient() {
            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                view.loadUrl(url);
                return true;
            }
        });
        return webView;
    }

    //设置RN中方法属性
    @ReactProp(name = "url")
    public void setUrl(WebView view, @Nullable String url) {
        view.loadUrl(url);
    }
    @ReactProp(name = "html")
    public void setHtml(WebView view, @Nullable String html) {
        view.loadData(html, "text/html; charset=utf-8", "UTF-8");
    }
}

创建ToastPackage.java类

public class ToastPackage implements ReactPackage {

        //创建原生模块
        @Override
        public List<NativeModule> createNativeModules(ReactApplicationContext reactContext) {
            List<NativeModule> list = new ArrayList<NativeModule>();
            list.add(new ToastModule(reactContext));
            list.add(new CommunicationModule(reactContext));
            return list;
        }
    
        //创建原生视图
        @Override
        public List<ViewManager> createViewManagers(ReactApplicationContext reactContext) {
            List<ViewManager> list = new ArrayList<>();
            list.add(new WebViewManager());
            return list;
        }
}

在MainApplication.java类中:

		    @Override
		    protected List<ReactPackage> getPackages() {
		      return Arrays.<ReactPackage>asList(
		              new MainReactPackage(),new ToastPackage()
		      );
		    }

RN代码

创建WebExample.js

	    import PropTypes from "prop-types";
	    import { requireNativeComponent, ViewPropTypes } from "react-native";
	    
	    var iface = {
	      name: "WebView",
	      propTypes: {
	        url: PropTypes.string,
	        html: PropTypes.string,
	        ...ViewPropTypes // include the default view properties
	      }
	    };
	    
	    module.exports = requireNativeComponent("RCTWebView", iface, {
	      nativeOnly: {
	        testID: true,
	        renderToHardwareTextureAndroid: true,
	        accessibilityComponentType: true,
	        accessibilityLabel: true,
	        importantForAccessibility: true,
	        accessibilityLiveRegion: true,
	        onLayout: true
	      }
	    });

在你先要生成原生组件处:

    /**
     * Sample React Native App
     * https://github.com/facebook/react-native
     * @flow
     */
    
    import React, { Component } from "react";
    import { Button, StyleSheet, Text, View } from "react-native";
    import WebView1 from "./WebExample";
    
    export default class WebExampleDemo extends Component {
      render() {
        return (
          <View style={{ flex: 1 }}>
            {/* <WebView1 url="https://www.baidu.com/" style={{ flex: 1 }} /> */}
            <WebView1 html="<h1>发达大厦</h1>" style={{ flex: 1 }} />
          </View>
        );
      }
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你想在 React Native 中调用原生方法,可以使用 React Native 提供的 Native Modules。 首先,在原生代码中创建一个方法,然后将其导出到 React Native 中。例如在 iOS 项目中,可以在 `AppDelegate.m` 文件中添加以下方法: ``` #import <React/RCTBridge.h> #import <React/RCTBridgeModule.h> @interface MyModule : NSObject <RCTBridgeModule> @end @implementation MyModule RCT_EXPORT_MODULE(); RCT_EXPORT_METHOD(myMethod:(NSString *)myArgument callback:(RCTResponseSenderBlock)callback) { // 在这里实现你的方法逻辑 NSString *myResponse = @"这是我的响应"; callback(@[[NSNull null], myResponse]); } @end ``` 在上面的代码中,我们定义了一个名为 `myMethod` 的方法,并将其导出到 React Native 中。此方法接受一个字符串参数 `myArgument` 和一个回调函数 `callback`,并在回调函数中返回一个响应字符串。 接下来,在 React Native 中调用这个方法。可以使用 `NativeModules` 模块来访问原生方法。例如: ``` import { NativeModules } from 'react-native'; const { MyModule } = NativeModules; MyModule.myMethod('这是我的参数', (error, response) => { if (error) { console.error(error); } else { console.log(response); } }); ``` 在上面的代码中,我们使用 `NativeModules` 访问原生模块 `MyModule`,并调用其中的 `myMethod` 方法。此方法接受一个字符串参数和一个回调函数,该回调函数在方法完成后被调用,并传递错误对象和响应字符串作为参数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值