- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我想使用随 React v0.13 引入的新 ES6 React 类,但我无法正确编译它。假设我在新类语法中定义了以下 React 组件:
(function() {
'use strict';
import React from 'react';
class _UserDashboard extends React.Component {
render() {
return(
<div className="user-dashboard">
<Books />
</div>
);
}
}
export const UserDashboard = React.createClass(_UserDashboard.prototype);
}());
我在这里遇到的麻烦是在编译时使用 Grunt 和 Browserify 以及一个 Reactify transform,Reactify遇到import关键字会报错:
ReactifyError: /Users/****/Sites/***/assets/js/components/UserDashboard.jsx: Parse Error: Line 7: Unexpected reserved word while parsing file: /Users/****/Sites/****/assets/js/components/UserDashboard.jsx
这里的问题似乎与 Reactify 对 react-tools 的使用有关,参见 here和 here .但我不确定是否可以在 Reactify 中启用 es6module
选项。
我尝试了这两种变体都无济于事:
...
transform: [[ 'reactify', {'es6module': true} ]]
...
和
...
transform: [[ 'reactify', {'es6':true, 'es6module':true} ]]
...
有谁知道如何做到这一点?
最佳答案
您应该能够使用 Babel 完成所有这些操作和 babelify (相应的 Browserify 插件)。
Babel 本身是一个 ES6+ 到 ES5 的转译器,但它带有 first class JSX support :
JSX and React
Babel works perfectly with React, featuring a built-in JSX transformer.
您的 Browserify 转换将变为:
{
"browserify": {
"transform": ["babelify"]
}
}
编辑:从 Babel 6 开始,许多组件已移出到单独的预设包中,您需要安装这些包并将其包含在转换命令中。
对于 React 和 JSX,您需要 babel-preset-react
.
对于 ES6,您需要 babel-preset-es2015
这些可以一起在转换中指定。
transform: [[babelify, { presets: ["react", "es2015"] }]]
关于javascript - 如何使用 Grunt + Browserify + Reactify 转换 React ES6 类?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29591818/
我使用 watchify/browserify 通过此命令创建带有调试源映射的包 - watchify main.js -o bundle.js -v -d 当我使用 Chrome DevTools
我使用 Gulp 作为我的任务运行器并使用 browserify 来捆绑我的 CommonJs 模块。 我注意到运行我的 browserify 任务非常慢,大约需要 2 到 3 秒,而我只有 Reac
这是我的 gulpfile 代码: gulp.task('react', function () { browserify('app/src/main.jsx') .transform(r
我对复合组件设计有疑问。我有一个定义 Prop 的包装组件。我使用 Context.Provider 使 props 可用于子内容组件。我希望内容组件的子组件能够对 21 使用react。 限制:我想
我在 TypeScript 项目中将 gulp 与 browserify 和 tsify 一起使用。以下是我的 gulpfile.js 的摘录: var browserified = function
我正在尝试获取与 Chrome 一起使用的 JavaScript 文件的源映射。当前 gulp 脚本的问题在于源映射(Browserify 创建的)导致文件的缩小版本。 例如,假设 app.jsx 是
我正在尝试将reactify转换与browserify和gulp一起使用。 这个 gulp 任务有效: return browserify({ paths: ['./node_modu
我正在寻找在使用以下内容的项目上运行测试: 使用这些转换来浏览: babel化 react 我确实尝试了 JSDOM + Mocha 组合,但测试尚未构建的组件将在从一个组件调用另一个组件时失败: >
我正在尝试抽象我的代码,并且我在以下结构中有以下两个文件 main.js components - parent.js 主要.js require('./components/Parent')
我正在尝试通过 browserify+reactify 构建我的简单 Reactjs 应用程序,但在控制台中看到错误 Note: The code generator has deoptimised
我正在按照教程创建 FixedDataTable with React 。但是,在我的 jsx 文件中使用以下行时遇到一些问题: const {Table, Column, Cell} = requi
我有一个配置如下的 browserify 任务: module.exports = function(grunt) { grunt.config.set('browserify', { d
我想使用随 React v0.13 引入的新 ES6 React 类,但我无法正确编译它。假设我在新类语法中定义了以下 React 组件: (function() { 'use strict';
我正在基于标题中指定的框架构建一个 Web 应用程序: AngularJS:MVP 引擎 ReactJS:MVP 中的“V”组件 ngReact:将 React 组件注入(inject) Angula
我收到这个错误: bundle.js:26912 Uncaught Error: Element type is invalid: expected a string (for built-in co
这是我通过命令行执行 gulp 脚本 时的错误: TypeError: Object # has no method 'transform' 这是gulpfile.js: var gulp
我是一名优秀的程序员,十分优秀!