React-Dev React本地开发环境​

程序名称:React-Dev

授权协议: 未知

操作系统: 跨平台

开发语言: JavaScript

React-Dev 介绍

React-Dev基于webpack(打包)&gulp(工作流)&koa(数据mock)的本地开发环境。

执行命令:

  • npm run start
    启用带有hmr功能的本地服务开发环境

  • npm run debug
    启用不带hrm功能的本地服务开发环境

  • npm run mock
    启用带有数据mock功能的本地服务开发环境(不带hmr,因该功能还不稳定Webpack用来做模块热替换

  • npm run build
    执行项目构建,构建至.build文件夹,用于线上发布

  • npm run test
    执行单元测试

数据mock配置说明

  • 目前数据mock功能只能支持mock一个接口(设定为/api/list,所以所有的mock请求都请求这一个接口),在配置中,需要将不同的请求区分配置放在req参数中,然后在配置对象中指定req对应值返回的数据即可。

  • 配置完数据后要想使得mock的数据生效,需要关闭当前本地服务,执行npm run mock重新启动服务,mock数据方可生效。

技术方案

  • reflux + react

  • webpack + gulp + koa(用于mock数据)

  • npm

目录结构

├── .build [项目发布后生成的目录或文件]
└─── sc-radar [前端开发代码目录]
├── app.js [业务js目录]
├── app.css [业务css目录]
└── index.html [入口文件]
├── app [前端开发静态资源]
├── gulp [gulp任务目录]
├── mock [ajax请求数据mock配置]
├── node_modules [依赖]
├── test [测试]
├── .editorconfig [代码格式化小工具配置]
├── .eslintrc [eslint代码检查配置文件]
├── .gitignore [配置git操作会忽略的文件]
├── buildConfig.js [构建配置文件]
├── gulpfile.js [gulp任务执行入口文件]
├── HISTORY.md [修改记录]
├── index.html [spa入口]
├── make-webpack.config.js [webpack-config统一配置文件]
├── package.json [前端项目依赖配置]
├── READMD.md [你在看的文件]
├── routes.js [koa proxy路由]
├── server-with-mock.js [koa利用中间件起本地服务]
├── webpack-dev-mock.config.js [带mock功能的本地服务配置]
├── webpack-dev-server.config.js [不带hmr功能的本地服务配置]
├── webpack-hot-dev-server.config.js [带hmr功能的本地服务配置]
└── webpack-production.config.js [构建用于部署的静态资源文件配置]

依赖说明

lodash “react-router”: “1.0.0-beta3” 不稳定版本,后续要关注下更新

webpack记录

  • output 里的 publicPath: ‘/build/’ 注释掉,此配置会导致生成build中的css引用的字体路径为/build/xxxx (publicPath:’/’)

BUG LIST

console 报错 Invariant Violation: addComponentAsRefTo(…): Only a ReactOwner
can have refs. This usually means that you’re trying to add a ref to a
component that doesn’t have an owner (that is, was not created inside of
another component’s render method). Try rendering this component inside of a
new top-level component which will hold the ref.

解决方法:同时使用了两个版本的react,删除本地的react即可

react-highcharts 用webpack打包,使用babel打包后报错

解决方法:react-highcharts自身已经用webpack打包,二次打包时添加 ‘use strict’; 手动删除 ‘use strict’;
报错消失,通过配置webpack config 的loader,修改{test: /.(js)$/,loader: ‘babel-
loader?loose=all’}, 为 {test: /.(js)$/,exclude: /node_modules/,loader: ‘babel-
loader?loose=all’}, 可以解决此问题。

重构代码组织目录,点击菜单报错

type.toUpperCase() is not a function 由于重构 sideItem ,sideNav
导致了循环引用。webpack并未报错,只是返回了 {} 。导致 React无法识别。

模型: Stroe : state [a:’‘,b:’‘] , onGetA: Ajax , trigger({a:a}) onGetB: Ajax ,
trigger({b:b}) componentsDidMount : Action.getA , Action.getB

问题:组件中的显示情况,当ajax获取到数据a后,组件中的a数据更新,当ajax获取到数据b后,组件中的b数据更新了,但是之前a数据更新的结果消失了。
调试:render中用console.log查看组件的state,一共有三条记录: this.state a:’‘,b:’‘ 第一次渲染
this.state a;’value’ ajax获取到了a的数据,但是state中没有b this.state b:’value’
ajax获取到了b的数据,但是state中没有a 解决方法:
将store中的trigger({a:a}),trigger({b:b})都修改为trigger({a:a,b:b})

jsPlumb 打包

imports-loader exports-loader

webpack.config.js :

module.noParse : /min\.js|jsPlumb.*\.js/  ### 不解析依赖

usage method 1:

var jsPlumb = require('imports-loader?this=>window!exports-loader?jsPlumb!./dom.jsPlumb-1.7.7-min.js');

usage method 2:

require('jsPlumb') ;
// webpack.config.js 
loaders: {test: /\.jsPlumb.*\.js$/, loader: 'imports-loader?this=>window!exports-loader?jsPlumb'}
// or  resolve.alias

React-Dev 官网

https://github.com/abell123456/react-dev

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

相关推荐


BBGestureBack Full screen return gesture(全屏手势返回 滑动返回 pop 动画效果) iOS 侧滑返回
Framework7 或者叫 F7 是全功能的绑定 iOS 7 应用的 HTML 框架。Framework7 是免费开源的 HTML
iOS 调试库,支持 iOS8+,无需添加任何代码,方便 iOS 开发和测试。 屏幕截图 使用教程
DarkModeKit是在Apple官方的深色模式发布之前设计和开发的。 它提供了一种机制来支持iOS 11+(包括iOS 13)上的应用程序的暗模式。
SimpleNote iOS 版客户端。SimpleNote 是一款在多平台上发布的笔记应用。 开发准备条件:
Kivy iOS,此工具旨在为 iOS 编译必要的库以运行应用程序并管理 Xcode 项目的创建。
TYDownloadManager是一个iOS的文件下载管理器包,可以提示下载过程中的最新进展和状态的变化。
mruby是一款轻量级的Ruby实现,遵循ISO标准。它可以以解释的形式或者在VM上编译和执行形式运行。
因为涉嫌危害消费者的隐私问题,苹果公司决定停止使用原有的UDID系统,移动应用软件开发者们正在竞相寻找新的替代方案。移动应用销售平台Appsfire目前推出了OpenUDID,它是一个开源版本的UDID。Appsfire声称他们已
EasyIOS 开源至今已经1周年,全新Swift版本今日发布,支持利用HTML来开发IOS应用,支持模拟器实时预览,基于MVVM思想,HTML数据绑定,反射所有
在 iOS 领域使用 Pod 来进行组件化开发时常常需要手动进行一系列的操作,来实现Pod 组件的更新目的。特别是一些业务关联性比较强的 Pod
PokerCard,一款 iOS 多样式弹窗开源库。 Basic Usage import PokerCard class ViewController: UIViewController {
MiaowShow MiaowShow是高仿《喵播APP》的iOS视频直播项目。 项目具体讲解地址 iOS视频直播初窥:高仿<喵播APP>
ZJAttributedText 是高性能轻量级富文本框架 前言 如果遇到上面一个需求, 你会怎么处理, 若干个 UILabel + UIImageView? NSAttributedString拼接? CoreText?
DynamicCocoa,是滴滴 App 架构组自研的 iOS 动态化方案,可以让现有的 Objective-C 代码转换生成中间代码(JS),下发后动态执行。滴滴客户端 App 架构团队表示正在积极准备相关事项,计划于 2017 年初开源。
ObjectiveSupport aims to bring some of the popular Rubyisms found in ActiveSupport to Objective-C. This project originated as a component of
StyleKit 是能让你使用一个简单的 JSON 文件美化你的应用的微框架。 它如何工作?
XCActionBar 是一个用于 Xcoded 的通用生产工具。
Social Go是一个基于iOS平台,在人群中获取小精灵的雷达和匿名聊天App。它使用Swift
Swift版本最新发布 : https://github.com/EasyIOS/EasyIOS- Swift 全新基于MVVM(Model-View-ViewModel)编程模式架构,开启EasyIOS开发函数式编程新篇章。