gpt4 book ai didi

ruby-on-rails - Vue.js 应用程序在开发中工作,但在使用 Rails 5.2.0/Webpacker 的生产中不安装模板 - 空白屏幕,控制台中没有错误

转载 作者:搜寻专家 更新时间:2023-10-30 22:12:18 25 4
gpt4 key购买 nike

我正在使用 Rails 5.2.0 和 Webpacker gem 来部署 Vue 应用程序。

show.html.erb 文件非常简单:

<div data-behavior="vue-app"><MyComponent></MyComponent></div>

然后在我的入门包中,packs/my_vue_app.js:

import TurbolinksAdapter from 'vue-turbolinks';
import Vue from 'vue/dist/vue.esm'
Vue.use(TurbolinksAdapter);
import MyComponent from '../components/my_app/index.vue'

document.addEventListener('turbolinks:load', () => {

var element = $('[data-behavior="vue-app"]');

if(!element) { return };

console.log('Initializing Vue');

const app = new Vue({
el: element[0],
data: {

},
components: { MyComponent }
})
})

在开发中,一切正常。该应用程序已安装并正常运行。

但在生产中,页面加载和 JS 运行后,<div data-behavior="vue-app">从分页中移除,只留下<!-- -->在它的地方。

在控制台中,绝对没有错误。我可以使用 DevTools 确认包 js 文件已加载并已解析,因为控制台中打印了 console.log。

哎呀,Vue 正常工作的证据是整个 <div>在 JS 解析后,它被安装的位置从 DOM 中删除。

最奇怪的是,我可以让应用程序挂载一次,方法是在 console.log 行上附加一个调试器,并在调试器暂停执行时将其关闭。即使那次我看到了应用程序的安装,后来我也无法安装它,甚至再次摆弄调试器……真的,真的很奇怪。

这些是 package.json 的版本:


"vue": "^2.5.16",
"vue-loader": "14.2.2",
"vue-template-compiler": "^2.5.16",

Rails 应用是全新的,除了默认配置外没有其他配置。

Webpacker gem 是 3.5.3,Rails 是 5.2.0。

在这上面花了很长时间之后,我只发现了这个 github 问题:https://github.com/rails/webpacker/issues/1520

编辑:我提供了一个指向发生此错误的真实生产应用程序的链接:https://planilha.tramitacaointeligente.com.br/planilhas/ED2sUXz32-R9CJKdkmtf8Q

您会看到它没有安装。这是开发中的同一页面:

screenshot of app mounted

最佳答案

我最终通过更改 Vue 应用程序加载的定义方式设法解决了这个问题。

尝试从'vue'导入Vue(而不是从'vue/dist/vue.esm')然后:

const app = new Vue({
el: domElement,
render: h => h(RootComponent)
})

出现在 Webpacker gem 的 hello_vue.js 脚手架中的注释告诉您,您可以选择使用 DOM 作为模板或使用渲染函数加载组件;他们都在开发中工作,但只有后者(使用渲染函数加载组件,使用 vue 而不是 vue/dist/vue.esm 和 render: h => h(RootComponent) 在生产中为我工作。

到目前为止,这是我一生中最长、最令人沮丧的调试 session ,因为控制台中绝对没有错误,你只是盯着一个空白屏幕,Vue 正在运行,因为它删除了它原来的 DOM 元素从 DOM 安装到。

解决方案来源:https://stackoverflow.com/a/48651338/1290457这是 Webpacker gem 上的 github 问题(当前打开)https://github.com/rails/webpacker/issues/1520

我仍然不知道如何在生产中使用 DOM 作为 Vue 模板。

关于ruby-on-rails - Vue.js 应用程序在开发中工作,但在使用 Rails 5.2.0/Webpacker 的生产中不安装模板 - 空白屏幕,控制台中没有错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50957238/

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