Ng-table: webpack2を使用する際の奇妙な問題

作成日 2017年01月17日  ·  11コメント  ·  ソース: esvit/ng-table

webpack 2にアップグレードしようとすると、ビルドが失敗し、次のエラーが発生します。

ERROR in ./~/ng-table/src/browser/pager.html Module build failed

ライブラリのインポート(失敗):

import * as ngTable from 'ng-table'

バンドルが必要(成功):

require('ng-table/bundles/ng-table.js')

webpack構成:

'use strict';

const webpack = require('webpack');
const NgAnnotatePlugin = require('ng-annotate-webpack-plugin');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const argv = require('yargs').argv;
const path = require('path');

module.exports = {
  watch: false,
  bail: true,
  cache: true,
  devtool: 'source-map',
  entry: './typescript/app/app.ts',
  output: {
    path: path.resolve(__dirname, 'public'),
    filename: 'build/main.bundle.js',
    sourceMapFilename: '[name]-[chunkhash].map'
  },
  resolve: {
    extensions: [
      '.webpack.js',
      '.web.js',
      '.ts',
      '.js'
    ],
    alias: {
      Raven: path.resolve(__dirname, 'node_modules/raven-js/src/raven.js')
    }
  },
  plugins: [
    new webpack.DefinePlugin({
      'process.env.NODE_ENV': JSON.stringify(process.env.NODE_ENV || 'development'),
    }),
    new NgAnnotatePlugin({
      add: true
    }),
    new ExtractTextPlugin('build/[name].css'),
    new HtmlWebpackPlugin({
      filename: 'index.html',
      inject: false,
      hash: true,
      cache: false,
      template: 'ejs-loader!./typescript/index.html',
      locals: {
        environment: ENVIRONMENT,
        production: process.env.PRODUCTION,
        cdnDomain: CDN_DOMAIN,
        backendUrl: BACKEND_URL,
        releaseVersion: RELEASE_VERSION
      }
    }),
    new webpack.SourceMapDevToolPlugin({
      filename: '[file].map', // if no value is provided the sourcemap is inlined
      test: /\.(ts|js)($|\?)/i // process .js and .ts files only
    })
  ],
  module: {
    rules: [
      {
        test: /\.ts$/,
        loader: 'awesome-typescript-loader'
      },
      {
        test: /\.p?css$/,
        loader: ExtractTextPlugin.extract({
          fallbackLoader: 'style-loader',
          loader: [
            'css-loader',
            'postcss-loader'
          ]
        })
      },
      {
        test: /\.html$/,
        exclude: /index.html$/,
        use: [
          {
            loader: 'ngtemplate-loader',
            options: {
              relativeTo: path.resolve(__dirname, 'typescript')
            }
          },
          {
            loader: 'html-loader'
          }
        ]
      }
    ]
  },
  devServer: {
    historyApiFallback: true
  }
}

最も参考になるコメント

ヨ、プロジェクトへのng-tableのインポート方法を変更することで、これを解決することができました。 バンドルから直接インポートすると、修正されました。

import 'ng-table/bundles/ng-table';

全てのコメント11件

@facelegはその問題を解決できましたか? AngularJS1.5アプリをWebpack2にアップグレードしていますが、ブラウザーのログにGET http://app.finderbox.dev/app/ng-table/pager.html 404 (Not Found)が表示されます。

@richtmatいいえ私はあきらめてwebpack1を使用していますが、解決策に非常に興味があります

relativeToを指定する場合、これは実際にはngtemplate-loaderに関連している可能性があると思います。 ただし、 http://app.finderbox.dev/...が見つからないというエラーは発生しません。 関連している可能性があります:webpack-contrib / html-loader#91。 [email protected][email protected]を使用しています。

.htmltestで、 relativeToを削除してWebpackを実行してみてください。 私にとっては、正常にコンパイルされ、ng-tableテンプレートがキャッシュに追加されます。 バンドルをクラックして開いてチェックしてください。

まだプレフィックスが必要なので、アプリ用のローダー/テストブロックとnode_modules用の別のブロックをいじっています。

@mheppner残念ながら、私にとっては何も変わりません(こことhttps://github.com/esvit/ng-table/issues/969)。

唯一の違いは、ローカルテンプレートも間違っていることです。 .devで終わるURLは私のローカル開発URLであり、明らかにそこに行くことはできません。

https://github.com/esvit/ng-table/issues/969で述べたように、バンドルのテンプレートコンテンツをファイルに入れました。 テンプレートは次のようにキャッシュに入れられます: $templateCache.put('ng-table/pager.html', html); 。 ng-tableまたはwebpackの問題かどうかを確認するのにまだ苦労しています...

ここで同じエラー

ヨ、プロジェクトへのng-tableのインポート方法を変更することで、これを解決することができました。 バンドルから直接インポートすると、修正されました。

import 'ng-table/bundles/ng-table';

うまく機能します:import'of-table / bundles / of-table ';

ここで同じ問題。 のようにインポートする場合

import { ngTableModule } from 'ng-table';

その場合、ヘッダーとフッターはバンドルされないため、HTTP404になります。

インポートをに変更する

import 'ng-table/bundles/ng-table';

ヘッダー/フッターの問題を解決しますが、グリッチが欠落しています。^およびvの並べ替えインジケーターは表示されません。 並べ替えは行われますが、視覚的な表示はありません。

何か案は?

@sargueこれは数か月遅れていますが、私自身、^とvの並べ替えで同じ問題が発生しました。

追加

import 'ng-table/bundles/ng-table.css';

:)

@jheimbouchに感謝します、私はもうそのプロジェクトに取り組んでいないので、それを試すことができません。 しかし、とにかく感謝します、私は他の誰かのために役立つかもしれません。

webpack.config.jsに次のように配置することで、WebpackでHTMLファイルを正しくコンパイルすることができました。

    module: {
      rules: [
        // ...
        { test: /ng-table\/.*\.html$/, use: ['ngtemplate-loader?requireAngular&relativeTo=/src/browser/&prefix=ng-table/', 'html-loader'] }
      ]
    }

これには、NPMパッケージngtemplate-loaderhtml-loaderも必要です。 詳細: https ://github.com/esvit/ng-table/issues/969#issuecomment -703458126

このページは役に立ちましたか?
0 / 5 - 0 評価