-
Notifications
You must be signed in to change notification settings - Fork 47.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Added findDOMNode, as we move toward deprecating g #2646
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
/** | ||
* Copyright 2013-2014, Facebook, Inc. | ||
* All rights reserved. | ||
* | ||
* This source code is licensed under the BSD-style license found in the | ||
* LICENSE file in the root directory of this source tree. An additional grant | ||
* of patent rights can be found in the PATENTS file in the same directory. | ||
* | ||
* @emails react-core | ||
*/ | ||
|
||
"use strict"; | ||
|
||
var React = require('React'); | ||
var ReactTestUtils = require('ReactTestUtils'); | ||
|
||
describe('findDOMNode', function() { | ||
it('findDOMNode should return null if passed null', function() { | ||
expect(React.findDOMNode(null)).toBe(null); | ||
}); | ||
|
||
it('findDOMNode should find dom element', function() { | ||
var MyNode = React.createClass({ | ||
render: function() { | ||
return <div><span>Noise</span></div>; | ||
} | ||
}); | ||
|
||
var myNode = ReactTestUtils.renderIntoDocument(<MyNode />); | ||
var myDiv = React.findDOMNode(myNode); | ||
var mySameDiv = React.findDOMNode(myDiv); | ||
expect(myDiv.tagName).toBe('DIV'); | ||
expect(mySameDiv).toBe(myDiv); | ||
}); | ||
|
||
it('findDOMNode should reject random objects', function() { | ||
expect(function() {React.findDOMNode({foo: 'bar'});}) | ||
.toThrow('Invariant Violation: Element appears to be neither ' + | ||
'ReactComponent nor DOMNode (keys: foo)' | ||
); | ||
}); | ||
|
||
it('findDOMNode should reject unmounted objects with render func', function() { | ||
expect(function() {React.findDOMNode({render: function(){}});}) | ||
.toThrow('Invariant Violation: Component contains `render` ' + | ||
'method but is not mounted in the DOM' | ||
); | ||
}); | ||
|
||
}); | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
/** | ||
* Copyright 2013-2014, Facebook, Inc. | ||
* All rights reserved. | ||
* | ||
* This source code is licensed under the BSD-style license found in the | ||
* LICENSE file in the root directory of this source tree. An additional grant | ||
* of patent rights can be found in the PATENTS file in the same directory. | ||
* | ||
* @providesModule findDOMNode | ||
* @typechecks static-only | ||
*/ | ||
|
||
"use strict"; | ||
|
||
var ReactComponent = require('ReactComponent'); | ||
var ReactInstanceMap = require('ReactInstanceMap'); | ||
var ReactMount = require('ReactMount'); | ||
|
||
var invariant = require('invariant'); | ||
var isNode = require('isNode'); | ||
|
||
/** | ||
* Returns the DOM node rendered by this element. | ||
* | ||
* @param {ReactComponent|DOMElement} element | ||
* @return {DOMElement} The root node of this element. | ||
*/ | ||
function findDOMNode(componentOrElement) { | ||
if (componentOrElement == null) { | ||
return null; | ||
} | ||
if (isNode(componentOrElement)) { | ||
return componentOrElement; | ||
} | ||
if (ReactInstanceMap.has(componentOrElement)) { | ||
return ReactMount.getNodeFromInstance(componentOrElement); | ||
} | ||
invariant( | ||
!(componentOrElement.render != null && typeof(componentOrElement.render) === 'function'), | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think this might read a lot better if we demorganize it. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. ok, done. You guys seem to really like the inverted form of if statements. Personally, I tend to think it's easier to understand "if the component has a render function, throw an error" rather than "assert that render is null OR that the render property is not a function". The former is closer to the semantic reasoning, while the latter feels like There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I kind of agree that I used to think of it as "if...then...throw". However, the invariant model has a long standing tradition at Facebook since the early PHP days. It's also similar to It's nice an declarative in a TDD kind of way. It has grown on me. At the end of the day, it doesn't really matter which inversion you chose. Different people will have different mental models here. That said, the worst kind is the double negative. To think this one through, you might have to do two conversions! Demorganizing is hard enough already. People (me) screw this up all the time. I'd go as far as to say that it's objectively worse to have double negatives like this. |
||
'Component contains `render` method but is not mounted in the DOM', | ||
Object.keys(componentOrElement) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. There is no There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Excellent catch, thanks! |
||
); | ||
invariant( | ||
false, | ||
'Element appears to be neither ReactComponent nor DOMNode (keys: %s)', | ||
Object.keys(componentOrElement) | ||
); | ||
} | ||
|
||
module.exports = findDOMNode; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Unused.