Сервер Phoenix 1.4 поставляет HTML по умолчанию вместо запрошенных файлов JS - PullRequest
0 голосов
/ 28 октября 2019

Я пытаюсь визуализировать Vue.js прямо в моем приложении Phoenix 1.4. Но после установки Vue-router возникает следующая ошибка:

Отказался выполнять скрипт из 'http://localhost:4000/0.app.js', потому что его MIME-тип (' text / html ') не является исполняемым и строгимПроверка типа MIME включена.

Мой файл Phoenix router.ex выглядит следующим образом:

scope "/", Web do
 pipe_through :browser
 get "/*path", PageController, :index
end

Мой webpack.config.js:

const path = require('path');
const glob = require('glob');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
const UglifyJsPlugin = require('uglifyjs-webpack-plugin');
const OptimizeCSSAssetsPlugin = require('optimize-css-assets-webpack-plugin');
const CopyWebpackPlugin = require('copy-webpack-plugin');
const VueLoaderPlugin = require('vue-loader/lib/plugin')

module.exports = (env, options) => ({
  resolve: {
    alias: {
      'vue$': 'vue/dist/vue.esm.js'
    },
    extensions: ['*', '.js', '.vue', '.json']
  },
  optimization: {
    minimizer: [
      new UglifyJsPlugin({ cache: true, parallel: true, sourceMap: false }),
      new OptimizeCSSAssetsPlugin({})
    ]
  },
  entry: {
    './js/app.js': glob.sync('./vendor/**/*.js').concat(['./js/app.js'])
  },
  output: {
    filename: 'app.js',
    path: path.resolve(__dirname, '../priv/static/js')
  },
  module: {
    rules: [
      {
        test: /\.js$/,
        exclude: /node_modules/,
        use: {
          loader: 'babel-loader'
        }
      },
      {
        test: /\.css$/,
        use: [MiniCssExtractPlugin.loader, 'css-loader']
      },
      {
        test: /\.vue$/,
        loader: 'vue-loader'
      },
      {
        test: /\.s(c|a)ss$/,
        use: [
          'css-loader',
          {
            loader: 'sass-loader',
            // Requires sass-loader@^7.0.0
            options: {
              implementation: require('sass'),
              fiber: require('fibers'),
              indentedSyntax: true // optional
            }
          }
        ]
      },
      { test: /\.(png|woff|woff2|eot|ttf|svg)$/, use: 'url-loader' }
    ]
  },
  plugins: [
    new MiniCssExtractPlugin({ filename: '../css/app.css' }),
    new CopyWebpackPlugin([{ from: 'static/', to: '../' }]),
    new VueLoaderPlugin()
  ]
});

В настоящее время я вижу проблему с (я думаю) манифестом кэша, из-за которого мой сайт правильно доставляет файлы HTML и CSS, но для файлов JS доставляется шаблон HTML по умолчанию, что приводит к ошибке.

Я могуна вкладке Сеть Chrome Dev Tools см. ответ на этот запрос http://localhost:4000/0.app.js - файл app.html.eex.

enter image description here

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8"/>
    <meta http-equiv="X-UA-Compatible" content="IE=edge"/>
    <meta name="viewport" content="width=device-width, initial-scale=1.0"/>
    <title>Phoenix Framework</title>
  </head>
  <body>
    <div id="vue-app"></div>
    <script type="text/javascript" src="<%= Routes.static_path(@conn, "/js/app.js") %>"></script>
  </body>
</html>

Любая помощь с благодарностью.

1 Ответ

0 голосов
/ 29 октября 2019

Если вы используете универсальный маршрут для отображения страницы индекса, и запросы к ресурсам попадают на этот маршрут, это означает, что Plug.Static настроен неправильно в вашем endpoint.ex.

Наш выглядит примерно так:

plug Plug.Static,
  at: "/", from: :my_app_name, gzip: true,
  only: ~w(css images js favicon.ico robots.txt fonts)

поместите это куда угодно, прежде чем вы plug MyApp.Router.

Другая причина может заключаться в том, что 0.app.js просто не существует в priv/static/js. Проверьте там, чтобы увидеть, действительно ли он называется app.js или к его имени добавлен хеш.

...