Ng-table: مشكلة غريبة عند استخدام حزمة الويب 2

تم إنشاؤها على ١٧ يناير ٢٠١٧  ·  11تعليقات  ·  مصدر: esvit/ng-table

أثناء محاولة الترقية إلى حزمة الويب 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
  }
}

التعليق الأكثر فائدة

يو ، لقد تمكنت من حل هذه المشكلة عن طريق تغيير طريقة استيراد ng-table إلى مشروعي. الاستيراد مباشرة من الحزمة أصلحها لي:

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

ال 11 كومينتر

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

هل كانت هذه الصفحة مفيدة؟
0 / 5 - 0 التقييمات

القضايا ذات الصلة

ivyfae picture ivyfae  ·  12تعليقات

ulise picture ulise  ·  5تعليقات

muhlegg picture muhlegg  ·  29تعليقات

penchiang picture penchiang  ·  5تعليقات

zeeshanhanif picture zeeshanhanif  ·  5تعليقات