Проблема с миниатюрой компонента в реакции - PullRequest
0 голосов
/ 07 июня 2018

Я добавил компонент миниатюры в свой проект.Я увидел следующую ошибку в своем проекте после добавления.Ошибка показана на следующем рисунке.enter image description here

Вот мой код файла webpack.config.js, который может помочь вам разобраться в проблеме.Там должен быть указан загрузчик.Я не знаю, что это за загрузчик.Кто-нибудь сталкивался с такой же проблемой?

Любая помощь?

**/*webpack.config.js*/**

/* eslint comma-dangle: ["error",


{"functions": "never", "arrays": "only-multiline", "objects":
 "only-multiline"} ] */

const webpack = require('webpack');
const pathLib = require('path');

const devBuild = process.env.NODE_ENV !== 'production';

const config = {
  entry: [
    'es5-shim/es5-shim',
    'es5-shim/es5-sham',
    'babel-polyfill',
    './app/bundles/HelloWorld/startup/registration',
  ],

  output: {
    filename: 'webpack-bundle.js',
    path: pathLib.resolve(__dirname, '../app/assets/webpack'),
  },

  resolve: {
    extensions: ['.js', '.jsx'],
  },
  plugins: [
    new webpack.EnvironmentPlugin({ NODE_ENV: 'development' }),
  ],
  module: {
    rules: [
      {
        test: require.resolve('react'),
        use: {
          loader: 'imports-loader',
          options: {
            shim: 'es5-shim/es5-shim',
            sham: 'es5-shim/es5-sham',
          }
        },
      },
      {
        test: /\.jsx?$/,
        use: 'babel-loader',
        exclude: /node_modules/,
      },
      {
        test: /\.css$/,  
        include: /node_modules/,  
        loaders: ['style-loader', 'css-loader'],
      },
    ],
  },
};

module.exports = config;

if (devBuild) {
  console.log('Webpack dev build for Rails'); // eslint-disable-line no-console
  module.exports.devtool = 'eval-source-map';
} else {
  console.log('Webpack production build for Rails'); // eslint-disable-line no-console
}

А вот код, где я назвал компонент:

import React, { Component } from 'react';
import Thumbnail from 'react-native-thumbnail-video';

class VideoThumnail extends Component {
   render() {
     return(
       <div>
         <Thumbnail url="https://www.youtube.com/watch?v=lgj3D5-jJ74" />
       </div>
     );
   }
}

export default VideoThumnail;

1 Ответ

0 голосов
/ 07 июня 2018

У вас есть правило только для jsx.Попробуйте добавить js расширение в веб-пакет также

 {
   test: /\.(js|jsx)$/,
   use: 'babel-loader',
   exclude: /node_modules/,
 }

Также я вижу es6 synax, поэтому попробуйте добавить .babelrc в корневой каталог проекта с этим

{
  "presets": ["stage-0"]
}

и установить babel-preset-env(npm install --save babel-preset-env)

...