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
}
}
@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]
を使用しています。
.html
のtest
で、 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-loader
とhtml-loader
も必要です。 詳細: https ://github.com/esvit/ng-table/issues/969#issuecomment -703458126
最も参考になるコメント
ヨ、プロジェクトへのng-tableのインポート方法を変更することで、これを解決することができました。 バンドルから直接インポートすると、修正されました。
import 'ng-table/bundles/ng-table';