Не могу прикрепить мой компонент заголовка, используя ответную липкую - PullRequest
0 голосов
/ 05 сентября 2018

Я занимаюсь разработкой веб-сайта и не хочу вставлять свой компонент заголовка. Я разрабатываю с использованием react и react-sticky lib из https://www.npmjs.com/package/react-sticky

Вот мой файл, который я использую sticky.

import React from 'React'
import { StickyContainer, Sticky } from 'react-sticky'

class main extends React.Component {
  render () {
    return (
      <StickyContainer>
        <Sticky>
          {({style}) => (
            <components.common.header style={style}/>
          )}
        </Sticky>
        <components.common..... />
        <components.common..... />
        <components.common..... />
        <components.common.footer />
      </StickyContainer>
    )
  }
}

export default main

Это мой webpack.config.js:

const path = require('path')
const MiniCssExtractPlugin = require('mini-css-extract-plugin')
const merge = require('webpack-merge')
const webpack = require('webpack')
const HtmlWebpackPlugin = require('html-webpack-plugin')
const env = require('./src/env.js')
const TARGET = process.env.npm_lifecycle_event
process.env.BABEL_ENV = TARGET

const PATHS = {
  app: path.join(__dirname, 'src'),
  build: path.join(__dirname, 'build'),
  assets: path.join(__dirname, 'assets')
}

const common = {
  entry: [PATHS.app],
  module: {
    rules: [
      {
        test: /\.json$/,
        loader: 'json-loader'
      },
      {
        test: /\.jsx?$/,
        exclude: /node_modules/,
        include: PATHS.app,
        loaders: ['babel-loader']
      },
      {
        test: /\.css$/,
        use: [MiniCssExtractPlugin.loader, { loader: 'css-loader', options: { modules: true } }],
        include: /flexboxgrid/
      },
      {
        test: /\.scss$/,
        exclude: /flexboxgrid/,
        use: [
          MiniCssExtractPlugin.loader,
          { loader: 'css-loader', options: { modules: true } },
          'sass-loader'
        ]
      },
      {
        test: /\.jpe?g$|\.gif$|\.png$/i,
        loader: 'url-loader?name=[name].[ext]'
      },
      {
        test: /\.otf$|\.eot$|\.svg$|\.ttf|\.woff|\.woff2$/,
        loader: 'url-loader?name=[name].[ext]'
      }
    ]
  },
  resolve: {
    extensions: ['.js', '.jsx'],
    modules: ['node_modules', path.resolve(__dirname, './node_modules')],
    mainFields: ['browser', 'web', 'browserify', 'main', 'style']
  }
}

if (TARGET === 'start' || !TARGET) {
  module.exports = merge(common, {
    module: {
      rules: [
        {
          test: /\.jsx?$/,
          use: ['source-map-loader'],
          enforce: 'pre'
        }
      ]
    },
    devtool: 'inline-source-map',
    devServer: {
      contentBase: PATHS.build,
      historyApiFallback: true,
      hot: true,
      inline: true,
      progress: true,
      stats: 'errors-only',
      https: true,
      host: env.host,
      port: env.port,
      overlay: {
        errors: true
      },
      watchOptions: {
        watch: true
      }
    },
    plugins: [
      new MiniCssExtractPlugin({ filename: 'assets/style.css' }),
      new webpack.HotModuleReplacementPlugin(),
      new HtmlWebpackPlugin({
        template: PATHS.app + '/index.html',
        inject: 'body'
      })
    ],
    output: {
      path: PATHS.build,
      filename: 'bundle.js',
      publicPath: '/'
    }
  })
}

if (TARGET === 'production') {
  module.exports = merge(common, {
    plugins: [
      new MiniCssExtractPlugin({ filename: 'style.css' }),
      new webpack.optimize.OccurenceOrderPlugin(),
      new webpack.DefinePlugin({
        'process.env': {
          NODE_ENV: "'production'"
        }
      })
    ],
    output: {
      path: '/build',
      filename: 'bundle.js'
    }
  })
}

Я не получаю никакой ошибки от консоли, проблема в том, что заголовок не торчит вверху.

Кто-нибудь может мне помочь?

Спасибо!

EDIT

После дополнительного тестирования я вижу, что style пусто. А потом, когда я меняю размер экрана, он заполняется и работает.

Есть один способ принудительно обновить это окно?

1 Ответ

0 голосов
/ 06 сентября 2018

Хорошо, я решил сам, позвольте мне поделиться тем, что я сделал.

Во-первых, чтобы сделать sticky, вам не нужна библиотека для этого.

Вам просто нужно добавить в css эти строки

left: 0;
top: 0;
position: fixed;
transform: translateZ(0);

И после этого вам нужно работать с z-index для других компонентов.

Делая это, вы можете достичь sticky без каких-либо рамок.

Я оставлю вопрос для себя в будущем:

Это будет работать на всех устройствах?

...