gpt4 book ai didi

javascript - 将 hyperhtml-element 与 browserify/babelify 捆绑在一起不起作用

转载 作者:行者123 更新时间:2023-12-03 01:02:07 25 4
gpt4 key购买 nike

也许我做了一些非常错误的事情,但我似乎无法让 hyperhtml-element 与 babel 很好地配合。

如果我从“hyperhtml-element”导入 HyperHTMLElement,那么我的包中将获得原始 es6。如果我从 'hyperhtml-element/es5' 导入 HyperHTMLElement,则会出现 Uncaught TypeError: Super expression Must Either be null or a function

我正在使用@babel/preset-env

过去几个月我一直在 Electron 应用程序中使用 hyperhtml-element 并且喜欢它。但现在我尝试在网络上使用它,我什至不知道如何捆绑它。我已经尝试完成这项工作近一个月了。

这是我的gulpfile.js

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/'))
})

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

最佳答案

If I import HyperHTMLElement from 'hyperhtml-element' then I get raw es6 in my bundle.

这正是应该发生的事情,对吧?你正在使用 ES6 语法,你明白了。

但是这里你与 browserify 捆绑在一起,据我所知,它甚至不理解 ES6,只理解 CommonJS。

因此,如果您想要 CommonJS require HyperHTMLElement,则必须更加具体:

// explicit 
const HyperHTMLElement = require('hyperhtml-element/cjs').default;

如果您的捆绑程序足够智能,可以自动理解 .default 并且您在后台进行了从 ES6 到 ES5/CJS 的一些转换,那么您可以尝试以下操作,仍然指向正确的文件夹:

// implicit CJS
import HyperHTMLElement from 'hyperhtml-element/cjs';

如果目标环境是 CJS,则两者之一肯定会起作用。

关于javascript - 将 hyperhtml-element 与 browserify/babelify 捆绑在一起不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52580223/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com