Подтвердить что ты не робот

React 'findNodeHandle перестает работать

После обновления до версии 0.26.0-rc эта строка:

React.findNodeHandle(this.refs.myRef)

Выдает это сообщение об ошибке:

Необработанное исключение JS: _react2.default.findNodeHandle не является функция.

Я импортирую React с этим:

import React from 'react';

Docs все еще говорят: "Как всегда, чтобы получить собственный конструктор node для компонента, вы можете использовать React.findNodeHandle(компонент)."

4b9b3361

Ответ 1

Вам также нужно импортировать ReactNative.

import ReactNative from 'react-native';
...
ReactNative.findNodeHandle(...)

Ответ 2

Теперь функция может использоваться без объекта:

import {
  ...
  findNodeHandle,
  ...
} from 'react-native';

И назовите его напрямую:

findNodeHandle(this.refs[refName])

Ответ 3

import {
  ...
  findNodeHandle,
} from 'react-native';

var RCTUIManager = require('NativeModules').UIManager;

var view = this.refs['yourRef']; // Where view is a ref obtained through <View ref='ref'/>
RCTUIManager.measure(findNodeHandle(view), (fx, fy, width, height, px, py) => {
  console.log('Component width is: ' + width)
  console.log('Component height is: ' + height)
  console.log('X offset to frame: ' + fx)
  console.log('Y offset to frame: ' + fy)
  console.log('X offset to page: ' + px)
  console.log('Y offset to page: ' + py)
})