質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

87.34%

slickのスライダーを要素と要素の間に重ねたい

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,080

score 6

slickのスライダーを要素と要素の間に重ねたい

slickでスライダーを作っています。
メインビジュアルとグレーの背景の上にスライダーを重ねようとしていますが、うまくいきません。

以下のようなイメージです。

イメージ説明

slickの動作自体はうまくいったのですが、
背景画像の上に浮いているように配置することがうまくいきません。

試したこと

デベロッパーツールを見る限り、
原因はslickのoverflow:hidden にあると推測し、以下の対応を行いました。

  • positionでスライダーを上に移動
  • slick-listのoverflow:hiddenをvisibleに変更

overflowを変更すると、背景の上に浮いたように配置はできたのですが、

slick の横幅が4100pxになってしまい、今度は横のレイアウトが崩れ、行き詰まってしまっています。

どなたかご存知の方はコメントいただけると助かります!

コードです。

<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta name="format-detection" content="telephone=no">
<link rel="stylesheet" href="./css/init.css">
<link rel="stylesheet" href="./css/pc.css">
<link rel="stylesheet" href="./slick/slick-theme.css">
<link rel="stylesheet" href="./slick/slick.css">
<title>TEST</title>




</head>


<body>


<!-- header -->
<header class="header">
  <div class="pickup">
    <div class="wrap">
      <p>テキストテキストテキストテキストテキストテキストテキストテキストテキスト</p>
    </div><!-- /wrap -->
  </div><!--/pickup-->


    <!--nav-area-->
    <div class="nav-area">
      <div class="wrap">
        <h1 class="logo"><a href="#"><img src="./img/header-logo.png" alt=""></a></h1>


        <nav>
          <ul>
            <li><a href="#">MENU</a></li>
            <li><a href="#">MENU</a></li>
            <li><a href="#">MENU</a></li>
            <li><a href="#">MENU</a></li>
            <li><a href="#">MENU</a></li>
          </ul>
        </nav>


        <div class="lang">

          <a href="#" class="select">ja</a>
          <a href="#" class="lang-btn">En</a>
          <a href="#" class="lang-btn">Sp</a>
          <a href="#" class="lang-btn">Cn</a>

        </div>
        <!--/lang-->


      </div><!-- /wrap -->
    </div><!--/nav-area-->


</header><!-- /header -->


<div id="top">
  <div class="mv">
    <h1>テキストテキストテキストテキストテキスト</h1>
    <p><img src="./img/mv-logo.png" alt=""></p>
  </div>



<div class="slide-wrap”>
    <div class="slider">
      <div class="slide"><img src="./img/hero-slide01.png" alt=""></div>
      <div class="slide"><img src="./img/hero-slide02.png" alt=""></div>
      <div class="slide"><img src="./img/hero-slide03.png" alt=""></div>
      <div class="slide"><img src="./img/hero-slide04.png" alt=""></div>
      <div class="slide"><img src="./img/hero-slide05.png" alt=""></div>

    </div><!--/slider-->
</div><!—-/slide-wrap—>

</div><!--/top-->



<script src="https://code.jquery.com/jquery-3.3.1.min.js"></script>
<script src="./slick/slick.min.js"></script>
<script>
window.addEventListener('load', function () {
  $('.slider').slick({
    autoplay: true,           //自動再生
    swipeToSlide: true,       //ドラックorスワイプで1スライド
    arrows: false,            //左右の矢印ボタン非表示
    slidesToShow: 4,          //表示するスライド数
    centerMode: true,         //中心に表示
    dots: false,              //ドットインジケーターを非表示
    centerPadding: '8%',      //見切れるスライドの幅
    autoplaySpeed: 0,         //自動再生のスライド切り替えスピード
    cssEase: 'linear',        //アニメーションの種類
    speed: 30000,             //アニメーションの速度
});


});
</script>


<script src="./js/script.js"></script>


</body>
</html>
// ベース色
$cr-m: #ec635d;




// 背景
$cr-bg: #fff;
$cr-bg-gray: #eee;
$cr-bg-gray-more: #d6d6d6;


// テキスト色
$cr-txt: #000;








/*----------------------------------
  base
----------------------------------*/




body{
  color:$cr-txt;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  line-height:1.5;
  min-width: 1400px;
}


.wrap{
  width: 1400px;
  margin: 0 auto;
}




/*----------------------------------
  header
----------------------------------*/


.test {
  padding:100px 20px;
  .text{
    font-style: 30px;
    color:#333;


  }
}




.header{
  position:fixed;
  width: 100%;
  z-index:10;

  .pickup{
    background-color: $cr-m;
    p{
      font-size:12px;
      padding: 3px 0 4px 15px;
      color:#fff;
    }
  }




  .nav-area{
    background-color: rgba(#000,.3);
    height:auto;
    padding:5px 0;

    .wrap{
      display: flex;
//      justify-content: center;


      .logo{
        margin-left:15px;
        a{
        font-size:20px;
        letter-spacing:0;
        text-decoration: none;

        }
      }

      nav{
        display: flex;
        align-items:center;
        margin:0 40px 0 20px;

        ul{
          display: flex;
          align-items:center;

          li{
            margin-right:25px;

            &:last-child{
              margin-right:0;
            }

            a{
              text-decoration: none;
              color:#fff;
              font-size:16px;

              &:hover{
                padding-bottom:5px;
                border-bottom:1px solid #fff;
              }
            }
          }
        }
      }

      .lang{
        display: flex;
        align-items:center;

        .select{
          display: inline-block;
          width: 80px;
          height: 40px;
          margin-right:8px;
          border:2px solid #fff;
          border-radius:20px;
          text-decoration: none;
          color:#fff;
          line-height:2.5;
          text-align: center;
          font-size:14px;



        }
        .lang-btn{
          display: inline-block;
          height: 40px;
          width: 40px;
          border:2px solid #fff;
          border-radius:50%;
          text-decoration: none;
          color:#fff;
          line-height:2.5;
          text-align: center;
          font-size:14px;
          margin-right:8px;

          &:last-child{
            margin-right:0;
          }
        }
      }

    }


  }
}








/*----------------------------------
  main visual
----------------------------------*/


 #top{
   width: 100%;
 .mv{
   background: url(../img/mv.png) ;
   background-repeat:no-repeat;
   background-position: center;
   background-size:cover;
   text-align: center;
   height:600px;
   width: 100%;
   padding:10% 0;


     h1{
       margin-bottom:20px;
       font-size:16px;
       color:#fff;
     }


   }


   .slide-wrap{
    height:300px;
    width: 100%;
    background-color: #fff;


    .slider{

      .slide{
        position:relative;
        top:-40px;
        left:0;
        z-index:999;
      }
    }
   }




}
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • kei344

    2019/10/07 12:38

    画像の状況を再現できるHTML/CSSも提示されたほうが回答を得やすいと思います。

    キャンセル

  • Lhankor_Mhy

    2019/10/07 15:01

    typoです。
    <div class="slide-wrap”>

    <div class="slide-wrap">

    キャンセル

回答 1

check解決した方法

0

.slideを動かしていましたが、

.slick-sliderに top:-40px;とすると解決しました。

画像の親要素ではなく、
スライダー全体を動かす必要があったみたいです。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 87.34%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る