browserify在watchify下能否动态编译.vue文件

以下是我的watchify操作,可以动态编译我的所有.js修改,但我在app.js中引入了一个.vue的组件,一旦在watchify下进行了修改,就会报错,假设这被修改的组件是parent.vue,那么报错如下:

Failed to mount component: template or render function not defined.
(found in <Parent>)`
我想就是因为如上所说,在watchify时候不能动态编译.vue文件输出到bundle.js中去,有什么办法来实现这个目的吗?
因为项目原因,不能采取开启一个localhost server的方法。(所以其他有什么解决办法吗?)

gulp.task('test', function(){
  let entries = ['app.js']
  let opts = Object.assign({}, watchify.args, {entries})
  let w_browser = watchify(browserify(opts))
  function bundle () {
    return w_browser.transform(vueify)
            .transform("babelify", {presets: ["es2015"]})
            .transform(browserifyShim)
            .bundle()
            .pipe(source('bundle.js'))
            .pipe(buffer())
            .pipe(gulp.dest('./'));
  }
  bundle()
  w_browser.on('update', bundle)
});
阅读 4.5k
2 个回答
新手上路,请多包涵

watchify是browserify的进一步封装跟vue没有关系,你用了vue格式的语法须得告诉browserify须得用怎样的方式去解析.vue格式的文件,默认地,他们只认识js这样的语法,所以你得使用watchify时得加上vueify解析它

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题