首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

react-native之undefined is not an object

开搞: 刚学习rn,有很多不理解的地方,常常会报undefined is not an object这个错,然后在不断的修改和试错的情况下,发现只要发生这个情况就有this存在,先贴出一段错误的代码 ?...这让我这个初入rn的初学者头疼了,后来我想,会不会和这个this有关呢,我试着删除{this.state.header},随便加点固定值,是完全可以的,后来我想,这个_header函数是FlatList组件的一个子组件...,会不会是_header()函数的this指向的是FlatList组件呢?...总结: 1、子组件指向的this属于子组件,与父组件无关 2、子组件不能去父组件更新状态 3、如果要在子组件更新父组件的状态,给子组件绑定父组件的this

1.2K40

让你在WebView中用JS调Native Object

背景 之所做这个东西,源于之前项目中需要把一些页面用webView来呈现,但是web中需要调用native的方法,比如获取本地存的某些数据、调用摄像头等等,这里也就是说JS要和OC能够互通有无。...ViewController就相当于是本地对象在JS中存的一个key。通过UIWebView执行JS,向JS中创建了一个名为ViewController的对象,它拥有一系列本地拥有的方法。...但是这里有个问题,我通过class_copyMethodList去获得一个Class以及它的父类上的方法,这样子的遍历其实是很耗性能的,尤其是当你需要注入的类特别多的时候。...调用过程: 注入相对来说比较简单,无非就是在JS中创建一个对象,然后将方法名写进去,重点是调用,比如我本地有这样的一个方法- (void)passArrayFromJS:(NSArray*)arr,在JS...本地如果判断到了最后一个参数是个callback,那么就会异步去调用本地的方法,完成之后再会通过callback把值给回JS中。 那么是如何实现JS向本地传递一个callback的呢?

2.4K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    React.js基础知识 函数组件和类组件(二)

    组件销毁之前 ===== 组件的属性是只读的:只能调取组件时候传递进来,不能自己在组件内部修改(但是可以设置默认值和规则) 组件的状态是可读写的:状态改变会引发组件的重新更新(状态是基于...函数式组件和类组件 // 函数式组件 一般用来完成一些静态的组件,不需要从后端获取数据 export defalut function Component (props){...// props 是传递过来的属性 是一个对象 return //jsx语法 } // 类组件 一般用来做比较复杂的页面从服务端获取数据...,有生命周期函数,es6 类的一些继承,封装 export defalut class Component extends React.Component{ constructor.../reactjs.org/blog/2019/08/08/react-v16.9.0.html) componentWillMount → UNSAFE_componentWillMount componentWillReceiveProps

    1.2K20

    如何在 React Native 实现类微信小程序平台:WebView 调用原生组件

    在《我们是如何将 Cordova 应用嵌入到 React Native 中》 一文中,我们简单地介绍了『React Native 重写 Cordova 插件:复杂插件的调用』步骤: WebView 调用...RN 方法,并监听 React Native 返回的相应事件 React Native 接收到 WebView 的调用,调用原生代码,并监听原生代码返回的相应事件 原生代码执行 React Native...调用的方法,并响应事件给 React Native React Native 接收到原生代码的值,执行 injectJavaScript 注入代码到 WebView 里并执行 注入的 JavaScript...步骤1:WebView 调用 RN 方法,并监听 React Native 返回的相应事件 这里,我们和《React Native + Cordova WebView 演进:Plugin 篇》中一样,仍然以...Native 调用的方法,并响应事件给 React Native 如上,由于 iOS 的日期插件是异步的,并且它只能通过方法,而非组件的方式来唤醒 UI,故而需要 sendEventWithName

    3.6K100

    react-native自定义原生组件

    使用react-native的时候能够看到不少函数调用式的组件,像LinkIOS用来呼起url请求 LinkIOS.openUrl('http://www.163.com'); actionSheetIOS...,通过声明一个native module,然后在这个组件内部通过底层实现方法的具体内容 像ActionSheetIOS在使用的时候,首先需要在工程的pod库中添加ActionSheetIOS对应的RCTActionSheet...pod 'React', :path => 'node_modules/react-native', :subspecs => ['Core','RCTActionSheet'# Add any other...http://blog.cnbang.net/tech/2698/ 所以我们自己实现一个原生的react-native组件的时候,完全可以照着actionSheetIOS来做 在前端自定义一个js,通过...require('NativeModules').XXX 引入 然后在底层实现RCTBridgeModule的类,在类里把RCT_EXPORT_MODULE、RCT_EXPORT_METHOD加上即可

    1.2K10

    ReactJs和React Native的那些事

    3,ReactJs和React Native的原理是相同的,都是由js实现的虚拟dom来驱动界面view层渲染。...2、原生组件:使用HTML5/JavaScript实现的组件比起原生组件总是让人感觉差一截,而React Native由于采用了原生UI组件自然没有此问题。 ...React Native既综合了Web布局的优势,采用了FlexBox和JSX,又使用了Native原生组件。 ...2、React 允许将代码封装成组件(component),然后像插入普通 HTML 标签一样,在网页中插入这个组件。React.createClass 方法就用于生成一个组件类。...所有组件类都必须有自己的 render 方法,用于输出组件。注意(组件类的第一个字母必须大写,否则会报错;组件类只能包含一个顶层标签,否则也会报错。)

    1.9K100

    5000字的React-native源码解析

    写在开头 近期公众号主攻下React-native,顺便我也复习下React-native,后续写作计划应该是主攻Node.js和跨平台方向、架构、Debug为主 如果你感兴趣,建议关注下公众号,系统的学习下...我们打开主入口的index.js文件 /** * @format */ import {AppRegistry} from 'react-native'; import App from '....(今天不对原理做过多讲解,有兴趣的可以自己搭建一个React-native脚手架,你会对整套运行原理、流程有一个真正的了解) 接下来看APP组件 import React from 'react'; import...from '@react-native-community/art' instead of 'react-native'. " + 'See https://github.com/...脚手架应该根据是react-native run ios 还是 安卓,选择加载对应js,我们找到Image.ios.js文件,只有200行,今天重点主攻下 默认暴露 module.exports = (

    2.4K10

    NodeGui源码学习

    } ... } 可以看到,构造函数会创建一个native对象,用于管理组件,而C++层则通过 Napi::Object QMainWindowWrap::init(Napi::Env env, Napi...; type:组件类型,可以是 HTML 标签名(如 'div'、'span' 等)或 React 组件类。...对于原生 UI 框架(如 React * Native),这可能涉及调用原生 API 创建视图。 设置属性:根据组件的 props 设置宿主节点的属性、样式和类名等。...初始化组件:对于类组件,调用其构造函数进行初始化;对于函数组件,执行函数体以创建组件实例。 返回节点引用:返回对新创建的宿主节点的引用,以便在后续操作中使用。...type:组件类型(如 HTML 标签名或 React 组件类)。 props:组件的属性(props)。 rootContainerInstance:根容器实例。

    14400

    ReactJS到React-Native,架构原理概述

    React是一个纯JS的UI库,只能干HTML/CSS/JS 提供的Web服务(新的H5 API不一定支持), React-Native厉害在于它能打通JS和Native Code, 让JS能够调用丰富的原生接口...对于 React Native ,React Native 调用Objective-C 的API 去渲染iOS 组件,调用Java API 去渲染Android 组件,而不是渲染到浏览器DOM 上。...这些组件因平台而不同,因此在使用React Native 时,如何组织你的组件变得尤为重要。...引擎JSCoreV8框架React.js组件化,数据绑定 Virtual DOM JSX模板学习使用有一定的成本Vue.JS 组件化,数据绑定 Virtual DOM 模板就是普通的html,数据绑定使用...Object-C与js的交互是通过各端的Bridge和ModuleConfig来进行的,实际过程可分为两个阶段:初始化阶段和方法调用阶段。

    5.4K10

    ReactJS到React-Native,架构原理概述

    React是一个纯JS的UI库,只能干HTML/CSS/JS 提供的Web服务(新的H5 API不一定支持), React-Native厉害在于它能打通JS和Native Code, 让JS能够调用丰富的原生接口...对于 React Native ,React Native 调用Objective-C 的API 去渲染iOS 组件,调用Java API 去渲染Android 组件,而不是渲染到浏览器DOM 上。...这些组件因平台而不同,因此在使用React Native 时,如何组织你的组件变得尤为重要。...引擎JSCoreV8框架React.js组件化,数据绑定 Virtual DOM JSX模板学习使用有一定的成本Vue.JS 组件化,数据绑定 Virtual DOM 模板就是普通的html,数据绑定使用...Object-C与js的交互是通过各端的Bridge和ModuleConfig来进行的,实际过程可分为两个阶段:初始化阶段和方法调用阶段。

    6.2K10

    怎么理解React Native的新架构?

    API 越来越多,而且很多组件设计和架构上比 React Native 要好,而且官方组件因为资源问题,投入度并不够,对于一些社区问题的反馈,响应和解决问题也不太及时。...标准化的 JS 引擎接口,React Native 可以替换 v8、Hermes 等引擎。...它是架起 JS 和原生 java 或者 Objc 的桥梁,类似于老的 JSBridge 架构的作用,但是不同的是采用的是内存共享、代理类的方式,JS 所有的运行环境都是在 JSRuntime 环境下的,...原有 JS 与 Native 的数据沟通,更多的是采用 JSON 和基础类型数据,但有了 JSI 后,数据类型更丰富,支持 JSI Object。...具体工具参看:https://github.com/facebook/react-native/tree/main/packages/react-native-codegen 2、以下是代码生成的大概流程

    2.1K20
    领券