搭建React环境教程

这次给大家带来搭建React环境教程,搭建React环境的注意事项有哪些,下面就是实战案例,一起来看一下。

前端生态这几年可谓迎来了大发展,在这个生态圈内,不接受新事物学习新技能,等于堕入魔道。

本文尝试对前端开发利器React,以及构建项目过程中涉及的技术栈进行介绍,以期开启整个构建流程上的思考。

有必要指出的是,要弄明白一件事情的原理,首先要知道它的目的是什么。

1、Nodejs & NPM

为什么要提nodejs呢?

与其说nodejs提供了服务端开发的另一种可能,不如说它彻底改变了整个前端开发的生态。nodejs平台上衍生出了强大的npm、grunt、express等,几乎重新定义了前端的工作流程和开发方式。

这里有必要来讲一讲NPM(node package manager)这个包管理器。

npm是javascript包管理器,我们可以在npm上找到、分享和使用来自无数开发者贡献的代码包,而无需自己造轮子。

使用npm,需要安装node。新的版本的nodejs已经集成了npm,安装好nodejs,通过以下命令查看所安装的版本:

$ npm -v

登录后复制

在项目目录内,当在命令行执行

$ npm install

登录后复制

它会识别一个叫package.json的文件,并尝试安装该文件内配置的依赖包。

2、React

React的组建化思想使得代码重用性高,易于测试、更容易分离关注点(separation of concerns)。

React还宣称Learn Once, Write Anywhere。既可运行在客户端浏览器,又能在服务端渲染,同时React Native还使得React开发原生app成为可能。

第一步:新建一个package.json文件,指定项目所需的依赖包。

{ "name": "react-tutorials", "version": "1.0.0", "description": "", "author": "yunmo", "scripts": {   "start": "webpack-dev-server --hot --progress --colors --host 0.0.0.0",   "build": "webpack --progress --colors --minimize"  }, "dependencies": {   "react": "^15.4.0",   "react-dom": "^15.4.0" }, "devDependencies": {   "webpack": "^2.2.1",   "webpack-dev-server": "^2.4.2" }, "license": ""}

登录后复制

这是npm包管理器的必要文件,定义了该项目的名称、版本、启动命令、生产环境依赖包(dependencies)和开发环境依赖包(devDependencies)。

第二步:新建一个index.html文件。

       yunmo      

登录后复制

第三步:写一段简单的React代码。

var React = require('react');var ReactDOM = require('react-dom');var element = React.createElement( 'h1', {className: 'yunmo'}, '云陌,欢迎来到react的世界!' );ReactDOM.render ( element, document.getElementById('yunmo'));

登录后复制

第四步:运行。

那么如何在浏览器里运行呢?这里我们需要借助强大的webpack-dev-server来开启本地服务器。

我们可以看到上面的package.json里面有webpack和webpack-dev-server依赖包。下面会介绍webpack。

当然我们还可以通过nodejs来建立一个本地服务器,但这里其实webpack-dev-server是一个小型的nodejs Express服务器,它使用webpack-dev-middleware中间件来服务于webpack包。

webpack.config.js文件配置如下:

var webpack = require('webpack');module.exports = { entry: ['./app/main.js'], output: {  path: dirname + '/build',  filename: 'bundle.js' }, module: {  loaders: [] }}

登录后复制

这样我们在命令行通过npm install安装好依赖包以后,敲打命令

$ npm start

登录后复制

运行服务后,在浏览器中输入http://localhost:8080/

一个简单的React项目便运行起来了。

3、Webpack

webpack是一款现代JavaScript应用的模块加载兼打包工具,它不仅仅可以打包JavaScript,还可以打包styles,images等资源。

来看一个典型的webpack配置:

var webpack = require('webpack');var path = require('path')module.exports = { entry: ['./app/main.js'], output: {  path: path.resolve(dirname, '/build'),  filename: 'bundle.js' }, module: {  loaders: [   {    test: /.js$/,    exclude: /node_modules/,    loader: 'babel-loader'   },   {    test: /.scss$/,    loaders: ["style-loader", "css-loader", "sass-loader"]   },   {    test: /.(otf|eot|svg|ttf|woff|png|jpg)/,    loader: 'url-loader?limit=8192&name=images/[hash:8].[name].[ext]'   }  ] }, plugins: [  new webpack.optimize.UglifyJsPlugin() ]}

登录后复制

从上面webpack配置里面可以看出来有一些基本的配置点,也反映了webpack的四个理念:

entry——webpack会根据应用的依赖关系,创建一个关系表。该表的起始点便是所谓的entry point(入口点)。entry point会告诉webpack从哪入手,webpack会以该表的依赖关系作为打包依据。

output——用于配置打包后的文件放置路径。

loader——webpack把每个文件都看作组建(如.css, .html, .scss, .jpg, .png等),但是webpack只能识别JavaScript。这时候loaders便可以把这些文件转换成组建,进而被添加到依赖关系表。

plugins——因为loaders作用方式是以单一文件为基础的,所以plugins更广泛的用来对打包组建形成的集合(compilations)进行自定义操作。

这样,一个完整的模块打包体系就建立起来了。

4、ES6

ES6,即ECMAScript 6.0,是 JavaScript的下一代标准。ES6里面新增了很多语法特性,使得编写复杂的应用更加优雅自然。

ES6中引入了诸如let和const、箭头函数、解构赋值、字符串模版、Module、Class、Promise等特性,使得前后端编程语言在语法形式上的差异越来越小。

我们来看一下:

import React from 'react'  //模块引入import '../styles/reactStack.scss'class ReactStack extends React.Component { //class特性 render() {  const learner = {name: '云陌', age: 18} //const定义变量  const mainSkills = ['React', 'ES6', 'Webpack', 'Babel', 'NPM',]  const extraSkills = ['Git', 'Postman']  const skillSet = [...mainSkills, ...extraSkills]  const { name } = learner  //解构赋值  let greetings = null  //let定义变量  if (name) {   greetings = `${name},欢迎来到${mainSkills[0]}的世界!` //字符模版  }  //以下用了箭头函数  return (   

{greetings}

    {skillSet.map((stack, i) =>
  1. {stack}
  2. )}

) }}export default ReactStack //模块导出

登录后复制

当然,并非所有浏览器都能兼容ES6全部特性,但看到这么优雅的书写方式,只能看怎么行呢?因此,这里又引出了一个神器,Babel!

5、Babel

Babel是一款JavaScript编译器。

Babel可以将ES6语法的代码转码成ES5代码,从而在浏览器环境中实现兼容。

Babel内置了对JSX的支持,所以我们才能向上面那样直接return一个JSX形式的代码片段。

具体用法不在本文过多讲述。

6、Styles引入

在上面的代码中,有以下样式引入方式:

import '../styles/reactStack.scss'

登录后复制

样式文件如下:

body { background: #f1f1f1;}.skills { h3 {  color: darkblue; } ol {  margin-left: -20px;  li {   font-size: 20px;   color: rgba(0, 0, 0, .7);   &:first-child {    color: #4b8bf5;   }  } }}

登录后复制

样式文件要在项目中起作用,还需要在package.json里面添加相应的loader依赖,如css-loader, sass-loader, style-loader等,别忘了package.json里还需要node-sass依赖,然后安装即可。

webpack.config.js中相应配置如下:

module: { loaders: [  {   test: /.js$/,   exclude: /node_modules/,   loader: 'babel-loader'  },  {   test: /.scss$/,   loaders: ["style-loader", "css-loader", "sass-loader"]  } ]}

登录后复制

再将main.js中的内容作如下更改:

import React from 'react'import ReactDOM from 'react-dom'import ReactStack from './pages/ReactStack'ReactDOM.render ( , document.getElementById('yunmo'));

登录后复制

结语

至此,一个简单的React项目便搭建起来了。

在后续的文章中,我将对本文涉及到的React技术栈做专门的讲解,不仅限于硬性技能。当然更多的是实践做法上的总结,因为如果要掌握它们的理论,细看官方文档和源码是最好不过的做法。

相信看了本文案例你已经掌握了方法,更多精彩请关注【创想鸟】其它相关文章!

推荐阅读:

以上就是搭建React环境教程的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2772047.html

(0)
上一篇 2025年3月8日 13:08:38
下一篇 2025年3月8日 13:08:49

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • React全家桶怎样搭建后台管理系统

    这次给大家带来React全家桶怎样搭建后台管理系统,React全家桶搭建后台管理系统的注意事项有哪些,下面就是实战案例,一起来看一下。 引子 学生时代为了掌握某个知识点会不断地做习题,做总结,步入岗位之后何尝不是一样呢?做业务就如同做习题,…

    编程技术 2025年3月8日
    200
  • React Native实现验证码倒计时功能

    这次给大家带来React Native实现验证码倒计时功能,React Native实现验证码倒计时功能的注意事项有哪些,下面就是实战案例,一起来看一下。 因为以前直接用定时器,没去计算当前的时候,每次退出程序的时候,定时器一直不走,这个工…

    编程技术 2025年3月8日
    200
  • React Native实现地址选择器功能

    这次给大家带来React Native实现地址选择器功能,React Native实现地址选择器功能的注意事项有哪些,下面就是实战案例,一起来看一下。 import React, { Component, PropTypes } from …

    编程技术 2025年3月8日
    200
  • React Native组件的生命周期多长

    这次给大家带来React Native组件的生命周期多长,React Native组件生命周期的注意事项有哪些,下面就是实战案例,一起来看一下。 这里有一篇React Native组件生命周期简介为大家带来,相信这对于大家在React Na…

    编程技术 2025年3月8日
    200
  • 使用React将组件渲染到指定DOM节点

    这次给大家带来使用React将组件渲染到指定DOM节点,使用React将组件渲染到指定DOM节点的注意事项有哪些,下面就是实战案例,一起来看一下。 众所周知React优点之一就是他的API特别简单。通过render 方法返回一个组件的基本结…

    编程技术 2025年3月8日
    200
  • jquery引用React步奏详解

    这次给大家带来jquery引用React步奏详解,jquery引用React的注意事项有哪些,下面就是实战案例,一起来看一下。 在React中引用Jquery比较好玩,获取元素的数据更多 引入方法举例: import $ from ‘jqu…

    编程技术 2025年3月8日
    200
  • react native悬浮按钮组件图文教程

    这次给大家带来react native悬浮按钮组件图文教程,使用react native悬浮按钮组件的注意事项有哪些,下面就是实战案例,一起来看一下。 React Native悬浮按钮组件:react-native-action-butto…

    2025年3月8日
    200
  • react实现移动端数据输出与显示

    这次给大家带来react实现移动端数据输出与显示,react实现移动端数据输出与显示的注意事项有哪些,下面就是实战案例,一起来看一下。 要求如下 输入框输入内容数据长度大于0,展示出预览信息 光标离开关闭预览信息 预览信息每隔4位插入一个特…

    编程技术 2025年3月8日
    200
  • react做出按需加载效果

    这次给大家带来react做出按需加载效果,react做出按需加载效果的注意事项有哪些,下面就是实战案例,一起来看一下。 虽然一直有做 react 相关的优化,按需加载、dll 分离、服务端渲染,但是从来没有从路由代码分割这一块入手过,昨天在…

    2025年3月8日
    200
  • Vue项目分环境打包步奏详解

    这次给大家带来Vue项目分环境打包步奏详解,Vue项目分环境打包的注意事项有哪些,下面就是实战案例,一起来看一下。 在项目开发中,我们的项目一般分为开发版、测试版、Pre版、Prod版。Vue-cli的默认环境一只有dev和prod两个,之…

    编程技术 2025年3月8日
    200

发表回复

登录后才能评论