Skip to main content

React Simplicity

This is just a quick intro to React to show how easy it is on a very basic level. React is often compared to Angular, but the two are very different: Angular is more of a framework, whereas React is more of a library. So, with React, we can make Components, and in so doing, we can intersperse plain Javascript to instill behavior. This article is not showing (or using) best practices, or a recommended structure. It's purpose is only to show how easy the basic mechanics of React are.

Let's grab the getting started cli from React's page
npm install -g create-react-app
create-react-app my-app

cd my-app
npm start

After this is done, and you have the project displayed in your browser, let's experiment. A boiler-plate header we can use for each new class can be as simple as:

/src/Foo.js

import React, { Component } from 'react'; 

class Foo extends Component { 
  render(){ 
    return(); 
  } 
} 
export default Foo;
So, all that we need to change to get started is the name of the class you want to create (replace Foo with that name). And following the convention, the name of the file containing our class is the name of the class, and they're both capitalized. Also note the function, render(). All classes based on React require this method. From this method, a single DOM element is returned. Let's create one more class:

/src/Bar.js

import React, { Component } from 'react';
import Foo  from './Foo';

class Bar extends Component {
  render() {
    return ();
  }
}
export default Bar;

The thing to note here is, I am having Bar include Foo. The reason for this is because Bar is going to render a Foo Component. The structure will be: the main component of our application, "App.js" will contain our component, "Bar.js". And, "Bar.js" will contain our component, "Foo.js". Let's flesh out Foo:

/src/Foo.js

import React, { Component } from 'react';

class Foo extends Component {

  constructor() {
    super();
    this.user = {
        firstName: 'Moe',
        lastName: 'Bettah'
    };
  }

  displayName() {
    return this.user.firstName + ' ' + this.user.lastName;
  }

  render(){
    return(
      <h1>Hello, {this.displayName()}!</h1>
    );
  }
}
export default Foo;

So this simplistic class renders, "Hello, Moe Bettah!". You can see that the larger portion of the class is plain old Javascript. The React portion of the class is just the render() function. Every render() must return a single element. It can be a complex element, like a div containing numerous other elements, but in that case, we are still just returning a single div (and its contents). Now, let's flesh out Bar:

/src/Bar.js

import React, { Component } from 'react';
import Foo  from './Foo';

class Bar extends Component {
  render() {
    return (
      
<h3>Here's a greeting...</h3>
); } } export default Bar;

Here, notice that our Bar class file includes Foo. Bar is just a plain container component. It renders a div, which contain's our Foo component. The Foo component through the magic of React, can now be referred to as, , and so that is how we refer to it in Bar. Notice that we also add some content to Bar's returned div, just above our Foo element. So we have Bar, which renders a bit of text and also renders Foo. All that remains is to add this to our App.

We need to add an import to the top App.js:

import Bar  from './Bar';

And finally, we need to add our component. Note that App follows the rule of only rendering a single element. In this case, a div with the css class of "App". There can be any amount of content within this singly returned div, and here there is indeed content added. Now, just place our tag just above the closing div in App's returned div. As an aside, note that the class attribute's are referred to as className in camel-case. There are some simple rules in attribute naming that React follows, which you can read in the docs. Finally, let's add a couple gratuitous tests to the single test that is autogenerated for us. Open, "App.test.js" and have a look at the file. We're going to add to this, to make testing easier.

On the command line, within the top directory, my-app enter:

npm i --save-dev enzyme

Enzyme allows us to easily test React components. See the included test in App.test.js?

Have a look at how easy it is with enzyme:

it('renders without crashing', () => {
  const app = shallow()
});

That's it! So, let's make two gratuitous test's, just to get an idea of how to access and test components we build.

At the top of "App.test.js" add the following:

import { shallow } from 'enzyme';
import App from './App';
import Foo from './Foo';
import Bar from './Bar';

We're including enzyme and all three of our classes. The App test is already written, let's make a couple test's against Foo and Bar:

it('shows bar\'s text, "Here\'s a greeting..."', () => {
    const bar = shallow();
    const test_content = <h3>Here's a greeting...</h3>
    expect(bar.contains(test_content)).toEqual(true); 
}); 

it('the name Nick is included in the display', () => { const foo = shallow(); 
  const test_content = <h1>Hello, Moe Bettah!</h1>
  expect(foo.contains(test_content)).toEqual(true); 
});

Here, in each case we're grabbing the component we want to test using enzyme's shallow() method. Within our component's, we want to test for included HTML elements. In the case of Bar, we're checking the static text within it's <h3> element. In Foo, we're checking that the dynamic text we are inserting is actually present. All very easy stuff. That's it. Super basic, super easy. There is a great deal more to know of course, but this is a friendly starter to show that it's not complex to begin tackling React.

Comments

Popular posts from this blog

Dead Simple React.js with Meteor

I spent a little time exploring the patterns involved in using React.js with Meteor. It's incredibly easy, it turns out. I'll show some examples here. The setup: meteor add kadira:flow-router npm install react react-dom react-mounter npm install react-addons-pure-render-mixin meteor add react-meteor-data Then of course remove all blaze related meteor packages. Ok, Some basic component patterns: Let's create one that accepts a single argument: Hello.jsx import React from 'react'; export const Hello = ({name}) => ( <div>Hello, {name}</div> ); That's all there is to it. Now, let's see a pattern for a component that takes two arguments. We can see that to add further arguments, we can just tack them on after the first two: TwoArgs.jsx import React from 'react'; export const TwoArgs = ({one, two}) => ( <div> <h2>TwoArgs!</h2> <h3>One is: {one}</h3> <h3>Two is: {two}...

Install current SBCL on OS X

You must have Command Line Tools installed. If you don't , this tutorial is not for you. Google: installation of XCode and Command Line Tools. Normally, I use brew to install things (when it offers a solution), but in this case the keg version was a couple minor version's off. And, there had been sufficient addition's that motivated me to want the current release. So, building from source was the path of least resistance. First, what not to do : The note's caution against using OS X's Terminal , as their make.sh script pukes a shit-ton of text during the build, and according to them, it can slow the build. I did not experience an issue with this, compared to other builds I've done in the past.   BUT , they also say build can be accomplished with other LISP's installed (you must have a lisp installed prior to building). OMFG , unless you want to wait a month of Sunday's, my experience building with CLISP was slower than the Molasses in January.  D...