1. 创建 demo 目录

  mkdir demo

2. 初始化应用

  npm init

  工程信息

  package name : tetris-class-demo

  version:

  description: tetris game

  entry point:

  test command:

  git repository:

  keywords:tetris, game

  author: zonehoo

  license: MIT

3.在 demo 下 创建 src , webpack 文件夹 .babelrc (编译代码配置)  index.html 文件 (入口页面)

  mkdir src webpack

  touch .babelrc  index.html

  webpack 文件夹下 创建 build.js (webpack 打包用)  develop.js (调试用)

  touch webpack/build.js  webpack/develop.js

  src 文件夹下 创建 index.js(js 入口文件)

  touch src/index.js

4. 编写 .babelrc

{

"presets": [

[

"env",

{

"targets": {

"browsers": ["last 2 versions","ie >= 10"]

},

"debug": false

}

]

],

"plugins": [

"transform-class-properties",

"transform-decorators-legacy",

[

"transform-react-jsx",

{

"pragma": "React.createElement"

}

],

[

"transform-runtime",

{

"helpers": true,

"polyfill": true,

"regenerator": true,

"moduleName": "babel-runtime"

}

]

]

}

5. 安装 webpack 和 babel 编译工具 并 添加 webpack 指令

  编写 package.json

  #package.json

{

"name": "tetris-class-demo",

"version": "1.0.0",

"description": "tetris game",

"main": "index.js",

"scripts": {

"start": "webpack-dev-server --config ./webpack/develop.js --hot --inline",

"build": "webpack --color --config ./webpack/build.js"

},

"keywords": [

"tetris",

"game"

],

"author": "zonehoo",

"license": "MIT",

"dependencies": {

"shortid": "^2.2.12",

"webpack-require-http": "^0.4.3"

},

"devDependencies": {

"babel-cli": "^6.26.0",

"babel-loader": "^7.1.5",

"babel-plugin-syntax-dynamic-import": "^6.18.0",

"babel-plugin-transform-class-properties": "^6.24.1",

"babel-plugin-transform-decorators-legacy": "^1.3.5",

"babel-plugin-transform-runtime": "^6.23.0",

"babel-preset-env": "^1.7.0",

"babel-preset-react": "^6.24.1",

"css-loader": "^1.0.0",

"html-webpack-plugin": "^3.2.0",

"less": "^3.7.1",

"less-loader": "^4.1.0",

"style-loader": "^0.21.0",

"svg-inline-loader": "^0.8.0",

"webpack": "^3.10.0",

"webpack-bundle-analyzer": "^2.13.1",

"webpack-cli": "^3.0.8",

"webpack-dev-server": "^2.11.2"

}

}

  安装拓展包

    npm install   

6. 编写 webpack/build.js 文件

var path = require('path')

var webpack = require('webpack')

var BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin

var UglifyJSPlugin = webpack.optimize.UglifyJsPlugin

module.exports = {

entry: path.resolve(__dirname, '../src/index.js'),

output: {

path: path.resolve(__dirname, '../.package'),

filename: 'bundle.min.js'

},

externals: {

react: 'React',

'react-dom': 'ReactDOM'

},

module: {

rules: [

{

test: /\.jsx?$/,

exclude: /node_modules/,

use: [

'babel-loader'

]

},

{

test: /\.css$/,

exclude: /node_modules/,

loader: 'style-loader!css-loader'

},

{

test: /\.less$/,

exclude: /node_modules/,

loader: 'style-loader!css-loader!less-loader'

},

{

test: /\.svg$/,

loader: 'svg-inline-loader'

}

]

},

plugins: [

new UglifyJSPlugin({

mangle: {

// Skip mangling these

except: ['exports', 'require']

},

sourceMap: true

}),

new BundleAnalyzerPlugin({

analyzerMode: 'static',

reportFilename: 'BundleReportRelease.html',

logLevel: 'info'

})

]

}

8. 编写 webpack/develop.js

var path = require('path')

const HtmlWebpackPlugin = require('html-webpack-plugin')

module.exports = {

entry: path.resolve(__dirname, '../src/index.js'),

output: {

path: path.resolve(__dirname, './'),

filename: 'index.js',

publicPath: '/'

},

devtool: 'inline-source-map',

externals: {

react: 'React',

'react-dom': 'ReactDOM'

},

module: {

rules: [

{

test: /\.jsx?$/,

exclude: /node_modules/,

loader: 'babel-loader'

},

{

test: /\.css$/,

exclude: /node_modules/,

loader: 'style-loader!css-loader'

},

{

test: /\.less$/,

exclude: /node_modules/,

loader: 'style-loader!css-loader!less-loader'

},

{

test: /\.svg$/,

loader: 'svg-inline-loader'

}

]

},

plugins: [

new HtmlWebpackPlugin({

filename: 'index.html',

template: './index.html'

})

],

devServer: {

hot: true,

port: 9000

}

}

9 写首页 index.html

<!DOCTYPE html>

<html>

<head>

<meta charset="utf-8" />

<meta http-equiv="X-UA-Compatible" content="IE=edge">

<title>Demo</title>

<meta name="viewport" content="width=device-width, initial-scale=1">

</head>

<body>

<div id='app'></div>

</body>

</html>

10. 引入 MVC

  在 src 下 创建 view.js  controller.js model.js

    touch src/view.js src/controller.js src/model.js

  创建 游戏 运行 js tetris.js

    touch src/tetris.js

11. 编写 index.js

  alert(1);

12. 使用 npm start 并访问 127.0.0.1:9000 弹出1即可

  npm start






2. react 编程实践 俄罗斯方块-环境搭建的更多相关文章

  1. 1. react 编程实践 俄罗斯方块-需求分析

    1. 需求分析 俄罗斯方块的要素 界面展示 定时刷新 键盘响应 方块模型 游戏规则 俄罗斯方块 比 "电商购物车" 好在哪? 业务比较简单, 人人都了解, 不需要过多前置知识 技术 ...

  2. React Native IOS ---基础环境搭建(前端架构师)

    React Native -IOS 开发环境搭建 web架构(基础) 安装依赖 * 必须安装的依赖有:Node.Watchman 和 React Native 命令行工具以及 Xcode. npm 镜 ...

  3. 从零开始针对 .NET 应用的 DevOps 运营实践 - 运行环境搭建

    一.Overview 最近的一段时间,在公司里我都在进行基于 Jenkins 和 SonarQube 配合已有的 Gitlab 搭建部门的持续集成环境的工作,虽然之前有使用过 GitHub Actio ...

  4. 1. react 基础 简介 及 环境搭建

    一.简介 由 Facebook 推出 2013 年 开源 的 函数式编程的 使用人数最多的 前端框架 拥有健全的文档与完善的社区 ( 官网 ) react 16 称为 React Fiber ( 底层 ...

  5. 3D游戏编程大师技巧──环境搭建

    刚开微博,想借助这个平台与大家交流,写下自己的学习记录,希望得到大家的批评指正. 好了,进入主题.这段时间对游戏编程很感兴趣,于是在网友的推荐下开始学习<3D游戏编程大师技巧>这本书.今天 ...

  6. jni 入门 android的C编程之旅 --->环境搭建&&helloworld

    需要进行jni的开发有一下几个条件: 1:能初步使用C/C++如果不会,请参读 谭浩强的  C编程语言 2:android应用开发已经基本入门,如果没有,请先行学习 这两个条件基本满足后,我们开始了: ...

  7. React .js框架的环境搭建

    React学习笔记(一)- 环境搭建   最近在学习react相关的知识,刚刚起步,一路遇坑不断.自己做个笔记,方便日后总结,也供相同趣味的小伙伴一起交流探讨. 学习时主要参考官网的教程:https: ...

  8. Forward团队-爬虫豆瓣top250项目-团队编程项目开发环境搭建过程

    本次结对编程和团队项目我都需要用python环境,所以环境的搭建是一样的.(本文部分内容引用自己博客:http://www.cnblogs.com/xingyunqi/p/7527411.html) ...

  9. React.js学习之环境搭建

    1 工欲善其事必先利其器:前端开发工具 1.1 WebStorm和Sublime Text Sublime Text:作为代码编辑器,Sublime Text的优点如下: 主流前端开发编辑器 体积较小 ...

随机推荐

  1. 51nod 1293:球与切换器

    1293 球与切换器 题目来源: Codility 基准时间限制:1 秒 空间限制:131072 KB 分值: 80 难度:5级算法题  收藏  取消关注 有N行M列的正方形盒子.每个盒子有三种状态0 ...

  2. .nerCore-RabbitMQDemo消息队列

    1.定义:MQ全称为Message Queue, 消息队列(MQ)是一种应用程序对应用程序的通信方法.应用程序通过读写出入队列的消息(针对应用程序的数据)来通信,而无需专用连接来链接它们.MQ是消费- ...

  3. BZOJ 4853 [Jsoi2016]飞机调度

    题解: 我严重怀疑语文水平(自己的和出题人的) 把航线按照拓扑关系建立DAG 然后最小路径覆盖 为什么两条首尾相接航线之间不用维护???? #include<iostream> #incl ...

  4. Vulkan SDK之 FrameBuffer

    The Vulkan Framebuffer Framebuffers represent a collection of memory attachments that are used by a ...

  5. (六--一)scrapy框架简介和基础应用

    一 什么是scrapy框架 官方解释 Scrapy是一个为了爬取网站数据,提取结构性数据而编写的应用框架. 可以应用在包括数据挖掘,信息处理或存储历史数据等一系列的程序中. 其最初是为了 页面抓取 ( ...

  6. [ACTF2020 新生赛]Exec

    0x00 知识点 命令执行 这里见了太多了..以前也写过: https://www.cnblogs.com/wangtanzhi/p/12246386.html 命令执行的方法大抵是加上管道符或者分号 ...

  7. UVA - 1606 Amphiphilic Carbon Molecules(两亲性分子)(扫描法)

    题意:平面上有n(n <= 1000)个点,每个点为白点或者黑点.现在需放置一条隔板,使得隔板一侧的白点数加上另一侧的黑点数总数最大.隔板上的点可以看做是在任意一侧. 分析:枚举每个基准点i,将 ...

  8. PL/SQL表结构/数据的导出

    1.表结构导出 方法一:在sql页面点击表名,进入表编辑页面,点击右下角“查看SQL”按钮,即可看到表结构 方法二:工具--导出用户对象 去掉所有者勾选项,即***.表名:用户名字在其他用户导入数据库 ...

  9. 15 —— npm —— package.json 与 package-lock.json 的作用

    一,package.json  是 npm init 时创建的一个文件,会记录当前整个项目中的一些基础信息. 二,package-lock.json 是 node_modules 文件夹或者 pack ...

  10. 1 ~ express ~ 初始化。安装第三方模块express。中间件

    一,初始化 二,安装第三方模块express 三,安装中间件 1,bodyParser : 解析 post 请求数据 2,cookies : 读写 cookie 3,swig :模板解析引擎 4,mo ...