أثناء محاولة الترقية إلى حزمة الويب 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')
تهيئة حزمة الويب:
'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 هل تمكنت من حل هذه المشكلة؟ أقوم بترقية تطبيق AngularJS 1.5 إلى Webpack 2 وأرى GET http://app.finderbox.dev/app/ng-table/pager.html 404 (Not Found)
في سجل المتصفح.
richtmat لا استسلمت وكنت أستخدم webpack 1. مهتم جدًا بإيجاد حل بالرغم من ذلك
أعتقد أن هذا قد يكون مرتبطًا بالفعل بـ ngtemplate-loader
عند تحديد relativeTo
. لم أحصل على أي أخطاء بشأن عدم العثور على http://app.finderbox.dev/...
بالرغم من ذلك. قد يكون مرتبطًا بـ: webpack-Contrib / html-loader # 91. أنا أستخدم [email protected]
و [email protected]
.
في test
مقابل .html
، حاول إزالة relativeTo
وتشغيل Webpack. بالنسبة لي ، يتم تجميعه بشكل جيد ، ويتم إضافة قوالب جدول ng إلى ذاكرة التخزين المؤقت. قم بفتح الحزمة الخاصة بك وتحقق منها.
نظرًا لأننا ما زلنا بحاجة إلى بادئة ، فأنا أعبث مع وجود محمل / كتلة اختبار لتطبيقي وكتلة منفصلة للوحدات node_modules.
mheppner للأسف ، بالنسبة لي لا يغير شيئًا (هنا و https://github.com/esvit/ng-table/issues/969).
الاختلاف الوحيد هو أن القوالب المحلية خاطئة أيضًا. عنوان url الذي ينتهي بـ .dev
هو عنوان url الخاص بي للتطوير المحلي ، ومن الواضح أنك لا تستطيع الذهاب إلى هناك.
كما قلت في https://github.com/esvit/ng-table/issues/969 ، أضع محتوى القالب للحزمة في ملفاتي. يتم وضع القوالب في ذاكرة التخزين المؤقت على النحو التالي: $templateCache.put('ng-table/pager.html', html);
. ما زلت أجد صعوبة في معرفة ما إذا كانت مشكلة في الجدول أو حزمة الويب ...
بالأعلى ، نفس الخطأ هنا
يو ، لقد تمكنت من حل هذه المشكلة عن طريق تغيير طريقة استيراد ng-table إلى مشروعي. الاستيراد مباشرة من الحزمة أصلحها لي:
import 'ng-table/bundles/ng-table';
يعمل بشكل رائع: استيراد "of-table / bundles / of-table" ؛
نفس المشكلة هنا. عند استيراد مثل
import { ngTableModule } from 'ng-table';
ثم لا يتم تجميع الرأس والتذييل مما يؤدي إلى HTTP 404.
تغيير الاستيراد إلى
import 'ng-table/bundles/ng-table';
يحل مشكلة الرأس / التذييل ولكن هناك خلل مفقود: لا يتم عرض مؤشرات الفرز ^ و v. يحدث الفرز ولكن لا يوجد مؤشر مرئي.
أيه أفكار؟
sargue هذا متأخر بضعة أشهر ، لكنني واجهت نفس المشكلة مع التصنيف ^ و v لا يظهر.
يضيف
import 'ng-table/bundles/ng-table.css';
:)
شكرًا jheimbouch ، لا يمكنني تجربتها لأنني لم أعد أعمل في هذا المشروع. لكن شكرًا على أي حال ، قد أكون مفيدًا لشخص آخر.
تمكنت من تجميع ملفات HTML بشكل صحيح باستخدام Webpack عن طريق وضع ما يلي في webpack.config.js الخاص بي:
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';