文档章节

使用node.js启动React

p
 piz__
发布于 2016/11/29 19:34
字数 1068
阅读 78
收藏 0

React简介

本文内容参考:菜鸟教程 http://www.runoob.com/react/react-install.html 。 React 使用 JSX 来替代常规的 JavaScript。而JSX 是一个看起来很像 XML 的 JavaScript 语法扩展。 通过 React 构建组件,使得代码更加容易得到复用,能够很好的应用在大项目的开发中。 新建一个html文件,引入了三个库: react.min.js 、react-dom.min.js 和 browser.min.js:

  1. react.min.js - React 的核心库
  2. react-dom.min.js - 提供与 DOM 相关的功能
  3. browser.min.js - 用于将 JSX 语法转为 JavaScript 语法 这三个文件可以在官网:https://facebook.github.io/react/ 下载react包。

###HelloWorld 这是一个html文件,导入相关的js即可以运行。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="lib/react.js"></script>
    <script src="lib/react-dom.js"></script>
    <script src="lib/browser.min.js"></script>
</head>
<body>
<div id="example">

</div>

</body>
<script type="text/babel">
    var HelloWord = React.createClass({
        render:function(){
            return(<h1>HelloWorld !!</h1>);
        }
    });

    ReactDOM.render(<HelloWord/>,document.getElementById("example"));

</script>
</html>

###使用nodejs创建react工程

这个就需要通过 npm 使用 React了。npm是安装nodejs后的一种工具。详情可以先去百度一下。 下面的操作都是在windows下的cmd窗口中操作完成。 ####第一步、安装全局变量

npm install babel -g
npm install webpack -g
npm install webpack-dev-server --save-dev

####第二步、创建根目录

mkdir reactApp
cd reactApp/

####第三步、生成package.json 文件

npm init
//出现下面一段东西,我们需要填写name,description和最后一个yes。
This utility will walk you through creating a package.json file.
It only covers the most common items, and tries to guess sensible defaults.

See `npm help json` for definitive documentation on these fields
and exactly what they do.

Use `npm install <pkg> --save` afterwards to install a package and
save it as a dependency in the package.json file.

Press ^C at any time to quit.
name: (react) react-test
version: (1.0.0)
description: 测试react
entry point: (index.js)
test command:
git repository:
keywords:
author:
license: (ISC)
About to write to D:\test\react\package.json:

{
  "name": "react-test",
  "version": "1.0.0",
  "description": "测试react",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "",
  "license": "ISC"
}

Is this ok? (yes) yes

####第四步、添加依赖包及插件

npm install react --save
npm install react-dom --save

同时我们也要安装一些 babel 插件

npm install babel-core
npm install babel-loader
npm install babel-preset-react
npm install babel-preset-es2015

####第五步、创建一些必要文件 创建文件是使用的cmd指令,也可以直接创建文件。

cd.>index.html
cd.>App.js
cd.>main.js
cd.>webpack.config.js

####第六步、设置编译器,服务器,载入器 打开webpack.config.js写入一下代码

 var config = {
   entry: './src/main',
	
   output: {
      path:'./',
      filename: 'index.js',
   },
	
   devServer: {
      inline: true,
      port: 8080
   },
	
   module: {
      loaders: [ {
         test: /\.jsx?$/,
         exclude: /node_modules/,
         loader: 'babel',

         query: {
            presets: ['es2015', 'react']
         }
      }]
   }
	
}

module.exports = config;
  1. entry: 指定打包的入口文件 main.js。
  2. output:配置打包结果,path定义了输出的文件夹,filename则定义了打包结果文件的名称。
  3. devServer:设置服务器端口号为 8080,端口后你可以自己设定 。
  4. module:定义了对模块的处理逻辑,这里可以用loaders定义了一系列的加载器,以及一些正则。当需要加载的文件匹配test的正则时,就会调用后面的loader对文件进行处理,这正是webpack强大的原因。

####第七步、修改 package.json

"start": "webpack-dev-server --hot"

修改后文件

{
  "name": "react-test",
  "version": "1.0.0",
  "description": "测试react",
  "main": "index.js",
  "scripts": {
    "start": "webpack-dev-server --hot"
  },
  "author": "",
  "license": "ISC",
  "dependencies": {
    "react": "^15.4.1",
    "react-dom": "^15.4.1"
  }
}

现在我们可以使用 npm start 命令来启动服务。--hot 命令会在文件变化后重新载入,这样我们就不需要在代码修改后重新刷新浏览器就能看到变化。这个就是实现实现自动编译的功能。 ####第八步、编写文件内容 index.html

<!DOCTYPE html>
<html>

   <head>
      <meta charset = "UTF-8">
      <title>React App</title>
      <link rel="stylesheet" type="text/css" href="lib/bootstrap-3.3.7-dist/css/bootstrap.min.css">
      <link rel="stylesheet" type="text/css" href="css/login.css">
      <script src="lib/jquery-3.1.1/jquery-3.1.1.min.js"></script>
   </head>

   <body>
      <div id = "app">

      </div>
      <script src = "index.js"></script>
   </body>

</html>

App.js

import React from 'react';

class App extends React.Component {
   render() {
      return (
          <h1>Hello World!</h1>
      );
   }
}
export default App;

main.js

import React from 'react';
import ReactDOM from 'react-dom';

import App from './App';
ReactDOM.render(<App/>, document.getElementById("app"));

如果想要组件可以在任何的应用中使用,需要在创建后使用 export 将其导出,在使用组件的文件使用 import 将其导入。 ####第九步、运行服务器

npm start

访问浏览器地址:http://localhost:8080/

####第十步、导入开发工具 目前测试了idea、WebStorm工具。直接导入,即可使用。导入后启动如下图:

WebStorm工具

© 著作权归作者所有

共有 人打赏支持
p
粉丝 4
博文 28
码字总数 15580
作品 0
上海
私信 提问
《React Native 精解与实战》书籍连载「Node.js 简介与 React Native 开发环境配置」

此文是我的出版书籍《React Native 精解与实战》连载分享,此书由机械工业出版社出版,书中详解了 React Native 框架底层原理、React Native 组件布局、组件与 API 的介绍与代码实战,以及 ...

Parry
08/10
0
0
ReactNative环境搭建问题小札

直接进入正题... ----------win7系统 + android studio工具 按照reactnative的官方介绍搭建开发环境 - React Native 中文网,使用Chocolatey,简单方便一些,但是会有一些小问题,不是因为...

害虫_84f3
05/23
0
0
react-webpack-antd--环境篇

Tips [React Error]: Target container is not a DOM element 原因: 在 index.html中将绑定的js文件写在了header中,在渲染组件时需要找到页面上的根节点去渲染 ,绑定在header中还没有根节点...

jdkwky
04/12
0
0
OSC 第 80 期高手问答 — 使用 React Native 开发原生 App

OSCHINA 本期高手问答(6月29日- 7月5日)我们请来了 @vczero(王利华)为大家解答关于 使用 React Native 开发原生 App 方面的问题。 王利华,@vczero ,携程框架研发部,无线框架高级研发工...

叶秀兰
2015/06/29
9.6K
30
express配置webpack-dev-server 启动时报错

//--------------------报错---------------------- D:\A_Code\GitHub\React_Antd_Demo\node_modules\webpack-dev-server\lib\Server.js:34 this.hot = options.hot || options.hotOnly; ^ T......

boy_is_god
2017/07/14
228
0

没有更多内容

加载失败,请刷新页面

加载更多

EOS官方钱包keosd

EOS官方钱包的名称是keosd,它负责管理你的私钥,并且帮你进行交易的签名。 不过不幸的是,keosd钱包对普通用户并不友好,它是一个命令行程序,目前还没有像以太坊的mist那样的图形化界面,而...

汇智网教程
43分钟前
2
0
ArrayList的实现原理以及实现线程安全

一、ArrayList概述 ArrayList是基于数组实现的,是一个动态的数字,可以自动扩容。 ArrayList不是线程安全的,效率比较高,只能用于单线程的环境中,在多线程环境中可以使用Collections.syn...

一看就喷亏的小猿
59分钟前
2
0
Netty 备录 (一)

入职新公司不久,修修补补1个月的bug,来了点实战性的技术---基于netty即时通信 还好之前对socket有所使用及了解,入手netty应该不是很难吧,好吧,的确有点难,刚看这玩意的时候,可能都不知道哪里...

_大侠__
昨天
5
0
Django简单介绍和用户访问流程

Python下有许多款不同的 Web 框架。Django是重量级选手中最有代表性的一位。许多成功的网站和APP都基于Django。 Django是一个开放源代码的Web应用框架,由Python写成。 Django遵守BSD版权,初...

枫叶云
昨天
8
0
Spring Cloud Stream消费失败后的处理策略(四):重新入队(RabbitMQ)

应用场景 之前我们已经通过《Spring Cloud Stream消费失败后的处理策略(一):自动重试》一文介绍了Spring Cloud Stream默认的消息重试功能。本文将介绍RabbitMQ的binder提供的另外一种重试...

程序猿DD
昨天
7
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部