Unknown Option Mnt C Dev Teachly Node_modules React Index.js.children

  • ReactJS Tutorial
  1. Unknown Option Mnt C Dev Teachley Node_modules React Index.js.children
  2. Unknown Option Mnt C Dev Teachly Node_modules React Index.js.children 2

React makes it painless to create interactive UIs. Design simple views for each state in your application, and React will efficiently update and render just the right components when your data changes. Declarative views make your code more predictable and easier to debug.

  • ReactJS Useful Resources
  • Selected Reading

In this chapter, we will show you how to set up an environment for successful React development. Notice that there are many steps involved but this will help speed up the development process later. We will need NodeJS, so if you don't have it installed, check the link from the following table.

Sr.No.Software & Description
1

NodeJS and NPM

NodeJS is the platform needed for the ReactJS development. Checkout our NodeJS Environment Setup.

After successfully installing NodeJS, we can start installing React upon it using npm. You can install ReactJS in two ways

  • Using webpack and babel.

  • Using the create-react-app command.

Installing ReactJS using webpack and babel

Webpack is a module bundler (manages and loads independent modules). It takes dependent modules and compiles them to a single (file) bundle. You can use this bundle while developing apps using command line or, by configuring it using webpack.config file.

Babel is a JavaScript compiler and transpiler. It is used to convert one source code to other. Using this you will be able to use the new ES6 features in your code where, babel converts it into plain old ES5 which can be run on all browsers.

Step 1 - Create the Root Folder

Create a folder with name reactApp on the desktop to install all the required files, using the mkdir command.

To create any module, it is required to generate the package.json file. Therefore, after Creating the folder, we need to create a package.json file. To do so you need to run the npm init command from the command prompt.

This command asks information about the module such as packagename, description, author etc. you can skip these using the –y option.

Unknown Option Mnt C Dev Teachley Node_modules React Index.js.children

Step 2 - install React and react dom

Since our main task is to install ReactJS, install it, and its dom packages, using install react and react-dom commands of npm respectively. You can add the packages we install, to package.json file using the --save option.

Or, you can install all of them in single command as −

Step 3 - Install webpack

Since we are using webpack to generate bundler install webpack, webpack-dev-server and webpack-cli.

Or, you can install all of them in single command as −

Step 4 - Install babel

Install babel, and its plugins babel-core, babel-loader, babel-preset-env, babel-preset-react and, html-webpack-plugin

Or, you can install all of them in single command as −

Step 5 - Create the Files

To complete the installation, we need to create certain files namely, index.html, App.js, main.js, webpack.config.js and, .babelrc. You can create these files manually or, using command prompt.

Step 6 - Set Compiler, Server and Loaders

Open webpack-config.js file and add the following code. We are setting webpack entry point to be main.js. Output path is the place where bundled app will be served. We are also setting the development server to 8001 port. You can choose any port you want.

webpack.config.js

Open the package.json and delete 'test' 'echo 'Error: no test specified' && exit 1' inside 'scripts' object. We are deleting this line since we will not do any testing in this tutorial. Let's add the start and build commands instead.

Step 7 - index.html

This is just regular HTML. We are setting div id = 'app' as a root element for our app and adding index_bundle.js script, which is our bundled app file.

Step 8 − App.jsx and main.js

This is the first React component. We will explain React components in depth in a subsequent chapter. This component will render Hello World.

Unknown Option Mnt C Dev Teachly Node_modules React Index.js.children

App.js

We need to import this component and render it to our root App element, so we can see it in the browser.

main.js

Note − Whenever you want to use something, you need to import it first. If you want to make the component usable in other parts of the app, you need to export it after creation and import it in the file where you want to use it.

Create a file with name .babelrc and copy the following content to it.

Step 9 - Running the Server

Unknown Option Mnt C Dev Teachly Node_modules React Index.js.children 2

The setup is complete and we can start the server by running the following command.

It will show the port we need to open in the browser. In our case, it is http://localhost:8001/. After we open it, we will see the following output.

Step 10 - Generating the bundle

Finally, to generate the bundle you need to run the build command in the command prompt as −

This will generate the bundle in the current folder as shown below.

Using the create-react-app command

Instead of using webpack and babel you can install ReactJS more simply by installing create-react-app.

Step 1 - install create-react-app

Browse through the desktop and install the Create React App using command prompt as shown below −

This will create a folder named my-app on the desktop and installs all the required files in it.

Step 2 - Delete all the source files

Browse through the src folder in the generated my-app folder and remove all the files in it as shown below −

Step 3 - Add files

Add files with names index.css and index.js in the src folder as −

In the index.js file add the following code

Step 4 - Run the project

Finally, run the project using the start command.

  1. Module build failed: ReferenceError: [BABEL] I:devcodepnpSocialForumfrontendsrcindex.js: Unknown option: I:devcodepnpSocialForumfrontendsrcnode_modulesreactreact.js.Children. Check out http://babeljs.io/docs/usage/options/ for more info
  2. at Logger.error (I:devcodepnpSocialForumfrontendsrcnode_modulesbabel-corelibtransformationfilelogger.js:39:11)
  3. at OptionManager.mergeOptions (I:devcodepnpSocialForumfrontendsrcnode_modulesbabel-corelibtransformationfileoptionsoption-manager.js:267:20)
  4. at I:devcodepnpSocialForumfrontendsrcnode_modulesbabel-corelibtransformationfileoptionsoption-manager.js:349:14
  5. at I:devcodepnpSocialForumfrontendsrcnode_modulesbabel-corelibtransformationfileoptionsoption-manager.js:369:24
  6. at OptionManager.resolvePresets (I:devcodepnpSocialForumfrontendsrcnode_modulesbabel-corelibtransformationfileoptionsoption-manager.js:364:20)
  7. at OptionManager.mergePresets (I:devcodepnpSocialForumfrontendsrcnode_modulesbabel-corelibtransformationfileoptionsoption-manager.js:348:10)
  8. at OptionManager.mergeOptions (I:devcodepnpSocialForumfrontendsrcnode_modulesbabel-corelibtransformationfileoptionsoption-manager.js:307:14)
  9. at OptionManager.init (I:devcodepnpSocialForumfrontendsrcnode_modulesbabel-corelibtransformationfileoptionsoption-manager.js:465:10)
  10. at File.initOptions (I:devcodepnpSocialForumfrontendsrcnode_modulesbabel-corelibtransformationfileindex.js:194:75)
  11. at new File (I:devcodepnpSocialForumfrontendsrcnode_modulesbabel-corelibtransformationfileindex.js:123:22)
  12. at Pipeline.transform (I:devcodepnpSocialForumfrontendsrcnode_modulesbabel-corelibtransformationpipeline.js:45:16)
  13. at transpile (I:devcodepnpSocialForumfrontendsrcnode_modulesbabel-loaderindex.js:14:22)
  14. at Object.module.exports (I:devcodepnpSocialForumfrontendsrcnode_modulesbabel-loaderindex.js:88:12)