ES6环境搭建及react-router学习

一、起因

ES6新纳入了很多振奋人心的新特性,真的很让人忍不住去尝试一下。不过,由于现在大部分的浏览器对ES6的支持程度都不是很好。所以如果想要放心地使用一些新特性,还需要用一些工具,将ES6或者ES7的代码转为ES5的代码。今天,就配置了一下环境,写了一个react-router,主要是练习自己的编程能力,哈哈。。。在此分享一下!

二、ES6环境搭建

搭建环境的工具有很多种,jspm,webpack,gulp等等。。。我主要是采用gulp+babel+browserify来搭建的。具体步骤如下(以下步骤均在node环境下进行):

①新建项目,打开命令行或者git hash,输入git init.

②安装gulp,输入npm install gulp

③安装一些必须的插件,看个人需要吧。我安装了一些: babel-preset-es2015 browserify gulp-babel gulp-concat gulp-cssnano gulp-uglify vinyl-source-stream gulp-sass

④配置gulpfile文件。

文件目录结构如下:

我的配置如下:

const gulp = require(‘gulp‘);
const babel = require(‘gulp-babel‘);
const uglify = require(‘gulp-uglify‘);
const sass = require(‘gulp-sass‘);
const rename = require(‘gulp-rename‘);
const cssnano = require(‘gulp-cssnano‘);
const concat = require(‘gulp-concat‘);
const browserify = require(‘browserify‘);
const babelify=require(‘babelify‘);
const source = require(‘vinyl-source-stream‘);
// 编译并压缩js
gulp.task(‘convertJS‘, function(){
  return gulp.src(‘app/js/*.js‘)
    .pipe(babel({
      presets: [‘es2015‘,‘react‘]
    }))
    .pipe(uglify())
    .pipe(gulp.dest(‘dist/js‘))
})
// 合并并压缩css
gulp.task(‘convertCSS‘, function(){
  return gulp.src(‘app/style/*.scss‘)
    .pipe(sass())
    .pipe(concat(‘app.css‘))
    .pipe(cssnano())
    .pipe(rename(function(path){
      path.basename += ‘.min‘;
    }))
    .pipe(gulp.dest(‘dist/style‘));
})
// 监视文件变化,自动执行任务
gulp.task(‘watch‘, function(){
  gulp.watch(‘app/style/*.scss‘, [‘convertCSS‘]);
  gulp.watch(‘app/js/*.js‘, [‘convertJS‘, ‘browserify‘]);
})
// browserify
gulp.task("browserify", function () {
    var b = browserify({
        entries: "dist/js/app.js"
    });
    return b.transform(babelify)
       .bundle()
        .pipe(source("bundle.js"))
        .pipe(gulp.dest("dist/js"));
});
gulp.task(‘start‘, [‘convertJS‘, ‘convertCSS‘, ‘browserify‘, ‘watch‘]);

 

注意,即使这些都安装好了,运行gulp命令的时候还是会报一个未定义babel对象的错,如图:

一开始我也不知道为什么,我把编译ES6的环境单独出来(也就是把react相关的内容和插件注释掉),发现是可行的。所以问题就出在编译react的时候了。最终在stackoverflow上面找到了答案。

大概的意思就是,babel在编译react的时候,有一个插件被分离了出来,需要另外安装,类似于补丁之类的东西吧!按照上面这个说法,我又去安装了一下这个,发现真的可以了,不报错了^_^。至此,环境准备好了。

三、路由搭建

首先,你可以点击这里,对react-route有进一步的了解。

其实,只是搭建环境比教耗费时间,搭路由参考官方的例子的话倒是很快的。我就写了一个hello world级别的路由。如下代码:

import React from ‘react‘;
import ReactDOM from ‘react-dom‘;
import { hashHistory, Route, Router } from ‘react-router‘;
import { render } from ‘react-dom‘

import List from ‘./list‘;

class Photo extends React.Component {
  render() {
    return <p>hello, winty!</p>
  }
}

render((
    <Router history={hashHistory}>
      <Route path="/" component={Photo}/>
      {/* add the routes here */}
      <Route path="/list" component={List}/>
    </Router>
), document.getElementById(‘app‘));

引入的List模块代码如下:

import React from ‘react‘

class List extends React.Component {
    render() {
        return <div>hello,List</div>
    }
}

正当我为写这么水的程序而不好意思的时候,打开浏览器,竟然。。。

真的就输出了hello,winty!

好吧。我F12打开控制台的时候,很伤心,报了两个警告:

最伤心的是,我各种找资料,都没有找到解释、各种群上问,都没有人知道的回复我。。。

好吧,抱着警告不影响运行的态度,我尝试改变url,通过路由跳到list那里去。。。

然而。。。

结果又亮瞎了。。。

结果什么都没有,还报错了。。。容我静静啊。。。

于是我又一次各种查、各种查、各种问、各种问。。。

本来想问清楚了,再来写这个博客,然而。。。还是解决不了。。。于是只能到这里来求助了。。。

博客园的大神们。。。有人可以解释一下吗?

详细代码点这里!

 PS:想练习ES6的新特性,又不知道该怎样搭环境的人可以参考gulpfile的代码哦。。。

  

时间: 2024-12-25 16:44:16

ES6环境搭建及react-router学习的相关文章

React+Webpack+ES6环境搭建(自定义框架)

引言 目前React前端框架是今年最火的.而基于React的React Native也迅速发展.React有其独特的组件化功能与JSX的新语法,帮助前端设计有了更好的设计与便捷,而React Native更是扩大了前端的边界. 说道React,那就不得不说一下Webpack凭借它异步加载和可分离打包等优秀的特性,走在取代Grunt和Gulp的路上.而面向未来的ES6,更是支持模块化处理. 下面我就分享一下关于Webpack+React+ES6的环境搭建(通用)[附加发布版] 准备工作 首先需要准

es6环境搭建

1.创建根目录(文件夹)es6: 可以直接创建,也可以 右键-git bush here: mkdir es62.进入es6文件夹:(cd es6)3.es6下创建三个目录 app server tasks 4.在 app下 创建 css js views 5.进入app/js目录 创建一个js类目录class,放置类文件 6.初始化类文件因为空的类没有作用,创建test.js 7.进入app/js目录 创建index.js(js入口文件) 8.进入app/views 创建模板文件(注:ejs是

React开发环境搭建(react,babel,webpack webpack-dev-server)

最终效果: 配置webpack 自动编译脚本, 内容更改后浏览器页面自动刷新,提高效率. 主要靠webpack 的watch 功能. npm 全局安装的包: webpack webpack-cli webpack-dev-server.   项目内2个文件 package.json. webpack.config.js 配置如下.截图不是最简单结构, 后面增加redux, react-redux 包加了点东西.  需要建立这样的目录后, npm install 就会根据package.json安

史上最详细Windows版本搭建安装React Native环境配置 转载,比官网的靠谱亲测可用

史上最详细Windows版本搭建安装React Native环境配置 2016/01/29 |  React Native技术文章 |  Sky丶清|  95条评论 |  33530 views 编辑推荐:稀土掘金 是一个高质量的技术社区,从 React Native 到 RxJava,性能优化到优秀开源库,让你不错过移动开发的每一个技术干货.各大应用市场搜索「掘金」,技术干货尽在掌握中. 说在前面的话: 感谢同事金晓冰倾情奉献本环境搭建教程 之前我们已经讲解了React Native的OS X

史上最详细Windows版本搭建安装React Native环境配置

说在前面的话: 感谢同事金晓冰倾情奉献本环境搭建教程 之前我们已经讲解了React Native的OS X系统的环境搭建以及配置,鉴于各大群里有很多人反应在Windows环境搭建出现各种问题,今天就特意更新一贴来说明.关于os x环境搭建以及react native入门学习资料请移步:http://www.lcode.org/react-native/ 刚创建的React Native技术交流3群(496508742),欢迎各位大牛,React Native技术爱好者加入交流!同时博客右侧欢迎微

Linux测试环境搭建的学习建议

随着Linux应用的扩展许多朋友开始接触Linux,根据学习Windwos的经验往往有一些茫然的感觉:不知从何处开始学起.这里介绍学习Linux测试环境搭建的一些建议. 一.Linux测试环境搭建从基础开始 常常有些朋友在Linux论坛问一些问题,不过,其中大多数的问题都是很基础的.例如:为什么我使用一个命令的时候,系统告诉我找不到该目录,我要如何限制使用者的权限等问题,这些问题其实都不是很难的,只要了解了 Linux 的基础之后,应该就可以很轻易的解决掉这方面的问题.而有些朋友们常常一接触Li

我学React Native开发的经历(一) 第一周学习,环境搭建及demo1,一个导航跳转页面

大家好,这是跋涉者,wadereye,说来惭愧, 我是从2017年8月25日左右开始学习React Native的,因为时间不多, 在学习的过程中,感觉资料非常零散,要趟过的坑巨多,遇到的问题也非常多. 作为新手,文章看的多,但是开始写具体应用的时候,往往一脸迷茫. 所以,我一边学习,一边把学习React_native写过的测试放和看过的资料在这里,供大家参考 . 我整理的要学RN 之前,最好要掌握的基础知识: HTML基础知识 CSS基础知识 Javascript 基础知识 Node JS基础

webpack+babel+ES6+react环境搭建

webpack+babel+ES6+react环境搭建 步骤: 1 创建项目结构 注意: 先创建一个项目目录  react  这个名字自定义,然后进入到这个目录下面 mkdir app //创建app目录 用来存放项目源文件 mkdir dist // 创建dist目录 用来存放打包好的文件 touch .gitignore //创建.gitignore 用来添加git 忽略的文件 touch webpack.config.js //创建webpack的配置文件 cd app //进入到app目

React Native学习笔记(一)Mac OS X下React Native的环境搭建

本文介绍Mac OS X系统下的React Native环境搭建过程. 1.环境要求: 1) Mac OS X操作系统 2) Xcode6.4或以上版本 3) Node.js4.0或以上版本 4) watchman和flow 2.安装过程 1) Node.js的安装可以在Node.js的官网https://nodejs.org/ 中下载最新的版本.这里下载的是node-v4.4.2.pkg版本.直接双击运行安装就可以了.查看是否安装成功可以在终端中输入如下命令: $node -v 如果能够显示版