Ng-table: Бтранная ΠΏΡ€ΠΎΠ±Π»Π΅ΠΌΠ° ΠΏΡ€ΠΈ использовании webpack 2

Π‘ΠΎΠ·Π΄Π°Π½Π½Ρ‹ΠΉ Π½Π° 17 янв. 2017  Β·  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')

ΠΊΠΎΠ½Ρ„ΠΈΠ³ Π²Π΅Π±ΠΏΠ°ΠΊΠ°:

'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
  }
}

Π‘Π°ΠΌΡ‹ΠΉ ΠΏΠΎΠ»Π΅Π·Π½Ρ‹ΠΉ ΠΊΠΎΠΌΠΌΠ΅Π½Ρ‚Π°Ρ€ΠΈΠΉ

Yo, я смог Ρ€Π΅ΡˆΠΈΡ‚ΡŒ эту ΠΏΡ€ΠΎΠ±Π»Π΅ΠΌΡƒ, ΠΈΠ·ΠΌΠ΅Π½ΠΈΠ² способ ΠΈΠΌΠΏΠΎΡ€Ρ‚Π° 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 ΠΈΠ»ΠΈ webpack...

Π’Π²Π΅Ρ€Ρ…Ρƒ, Ρ‚Π° ΠΆΠ΅ ошибка

Yo, я смог Ρ€Π΅ΡˆΠΈΡ‚ΡŒ эту ΠΏΡ€ΠΎΠ±Π»Π΅ΠΌΡƒ, ΠΈΠ·ΠΌΠ΅Π½ΠΈΠ² способ ΠΈΠΌΠΏΠΎΡ€Ρ‚Π° ng-table Π² свой ΠΏΡ€ΠΎΠ΅ΠΊΡ‚. Π˜ΠΌΠΏΠΎΡ€Ρ‚ Π½Π°ΠΏΡ€ΡΠΌΡƒΡŽ ΠΈΠ· ΠΏΠ°ΠΊΠ΅Ρ‚Π° исправил это для мСня:

import 'ng-table/bundles/ng-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 Ρ€Π΅ΠΉΡ‚ΠΈΠ½Π³ΠΈ

Π‘ΠΌΠ΅ΠΆΠ½Ρ‹Π΅ вопросы

richtmat picture richtmat  Β·  7ΠšΠΎΠΌΠΌΠ΅Π½Ρ‚Π°Ρ€ΠΈΠΈ

esvit picture esvit  Β·  37ΠšΠΎΠΌΠΌΠ΅Π½Ρ‚Π°Ρ€ΠΈΠΈ

ulise picture ulise  Β·  5ΠšΠΎΠΌΠΌΠ΅Π½Ρ‚Π°Ρ€ΠΈΠΈ

jlebleu picture jlebleu  Β·  3ΠšΠΎΠΌΠΌΠ΅Π½Ρ‚Π°Ρ€ΠΈΠΈ

muhlegg picture muhlegg  Β·  29ΠšΠΎΠΌΠΌΠ΅Π½Ρ‚Π°Ρ€ΠΈΠΈ