首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >将hyperhtml-元素与browserify/babelify捆绑起来不起作用

将hyperhtml-元素与browserify/babelify捆绑起来不起作用
EN

Stack Overflow用户
提问于 2018-09-30 17:09:46
回答 1查看 89关注 0票数 0

也许我做错了什么,但是我似乎不能让hyperhtml元素和babel玩得很好。

如果我从‘hyperhtml-元素’导入HyperHTMLElement,那么我在包中得到了原始的es6。如果我从'hyperhtml-element/es5‘导入HyperHTMLElement,那么我得到了未定义的TypeError:超级表达式必须为null或函数。

我使用@babel/预设-env

在过去的几个月里,我一直在一个电子应用程序中使用hyperhtml元素,我很喜欢它。但现在我正试图在网上使用它,我甚至不知道如何将它捆绑在一起。我已经尝试了将近一个月的时间来完成这个任务。

这是我的gulpfile.js

代码语言:javascript
复制
var gulp = require('gulp')

var browserify = require('browserify')
var watchify = require('watchify')
var babelify = require('babelify')

var source = require('vinyl-source-stream')
var buffer = require('vinyl-buffer')
var merge = require('utils-merge')

var rename = require('gulp-rename')
var uglify = require('gulp-uglify')
var sourcemaps = require('gulp-sourcemaps')


/* nicer browserify errors */
var gutil = require('gulp-util')
var chalk = require('chalk')

function map_error(err) {
  if (err.fileName) {
    // regular error
    gutil.log(chalk.red(err.name)
      + ': '
      + chalk.yellow(err.fileName.replace(__dirname + '/src/js/', ''))
      + ': '
      + 'Line '
      + chalk.magenta(err.lineNumber)
      + ' & '
      + 'Column '
      + chalk.magenta(err.columnNumber || err.column)
      + ': '
      + chalk.blue(err.description))
  } else {
    // browserify error..
    gutil.log(chalk.red(err.name)
      + ': '
      + chalk.yellow(err.message))
  }

  this.emit('end');
}

gulp.task('watchify', function () {
  var args = merge(watchify.args, { debug: true })
  var bundler = watchify(browserify('./src/js/index.js', args)).transform(babelify, { /* opts */ })
  bundle_js(bundler)

  bundler.on('update', function () {
    bundle_js(bundler)
  })
})

function bundle_js(bundler) {
  return bundler.bundle()
    .on('error', map_error)
    .pipe(source('index.js'))
    .pipe(buffer())
    .pipe(gulp.dest('build/static/js'))
    .pipe(rename('index.min.js'))
    .pipe(sourcemaps.init({ loadMaps: true }))
      // capture sourcemaps from transforms
      .pipe(uglify())
    .pipe(sourcemaps.write('.'))
    .pipe(gulp.dest('build/static/js/'))
}

// Without watchify
gulp.task('browserify', function () {
  var bundler = browserify('./src/js/index.js', { debug: true }).transform(babelify, {/* options */ })

  return bundle_js(bundler)
})

// Without sourcemaps
gulp.task('browserify-production', function () {
  var bundler = browserify('./src/js/index.js').transform(babelify, {presets: ["@babel/preset-env"]})

  return bundler.bundle()
    .on('error', map_error)
    .pipe(source('index.js'))
    .pipe(buffer())
    .pipe(rename('index.min.js'))
    .pipe(uglify())
    .pipe(gulp.dest('build/static/js/'))
})

如能提供任何帮助,我们将不胜感激。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-10-01 09:09:35

如果我是import HyperHTMLElement from 'hyperhtml-element',那么我的包中就会有原始的es6。

这正是应该发生的事,对吧?您正在使用ES6语法,您可以得到它。

但是在这里,您需要使用浏览器化,而AFAIK甚至不理解ES6,只有CommonJS。

因此,如果您希望require HyperHTMLElement for CommonJS,您必须更加具体一点:

代码语言:javascript
复制
// explicit 
const HyperHTMLElement = require('hyperhtml-element/cjs').default;

如果您的绑定器足够聪明,能够自动理解.default,并且在场景后面有一些从ES6到ES5/CJS的转换,那么您可以尝试以下操作,仍然指向正确的文件夹:

代码语言:javascript
复制
// implicit CJS
import HyperHTMLElement from 'hyperhtml-element/cjs';

如果目标env是CJS,这两种方法中的一种肯定会起作用的。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52580223

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档