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

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

ただいまの
回答率

87.48%

jQueryアニメーションにて要素の高さを保ちたい

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 375

score 28

こんばんは jQueryでの質問です
スクロールしたら.serviceがフェードインするというアニメーションをつけています
ある位置までスクロールするまでは.serviceは表示されないのですが、表示されていないとき.serviceの親要素である.service-wrapperの高さが低くなってしまいます
.service-wrapperにheight:80%;と高さを指定しても同じ挙動になってしまいます
何か.service-wrapperの高さを保つ方法はありませんでしょうか

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title>MY PORTFOLIO</title>
    <link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.8.2/css/all.css">
  </head>
  <body>
    <header class="header">
      <p class="header-left">My portfolio</p>
      <ul class="header-right">
        <li class="header-right-li"><a href="#about">ABOUT</a></li>
        <li class="header-right-li"><a href="#skills">SKILLS</a></li>
        <li class="header-right-li"><a href="#services">SERVICES</a></li>
        <li class="header-right-li"><a href="#works">WORKS</a></li>
      </ul>
    </header>

    <section class="skills" id="skills">
     <h2 class="about-h2 ">SKILLS</h2>
     <div class="skills-wrapper">
       <div class="skill-icon ">
         <img class="skill-img skill-margin" src="img/html2.png" alt="">
         <p class="skill-icon-name ">HTML</p>
         <p class="skill-setumei">Webページを作るための核になる言語です。</p>
       </div>

       <div class="skill-icon">
         <img class="skill-img" src="img/css.png" alt="">
         <p class="skill-icon-name">CSS</p>
         <p class="skill-setumei">コンテンツのデザインやレイアウトをカスタマイズして、Webサイトの見た目を良くしてくれます。</p>
       </div>

       <div class="skill-icon">
         <img class="skill-img skill-margin" src="img/jQuery.png" alt="">
         <p class="skill-icon-name">jQuery</p>
         <p class="skill-setumei">Webサイトに動きをつけます</p>
       </div>

       <div class="skill-icon">
         <img class="skill-img skill-margin" src="img/sass.png" alt="">
         <p class="skill-icon-name">SASS</p>
         <p class="skill-setumei">CSSを改良し、効率性を高めた言語です。</p>
       </div>
     </div>
    </section>

    <section class="services" id="services">
      <h2 class="about-h2">SERVICES</h2>
     <div class="services-wrapper">
       <div class="service service-1">
     <i class="fas fa-laptop-code"></i>
         <h4>コーディング</h4>
         <p>お客様から頂いたデザインを元に丁寧にコーディングいたします</p>
       </div>

       <div class="service service-2">
     <i class="fas fa-file-alt"></i>
         <h4>LP制作</h4>
         <p>お客様のご要望に適切に沿ったサイトを制作いたします</p>
       </div>
     </div>
    </section>

    <script src="js/jquery-3.5.1.min.js"></script>
    <script src="js/portfolio.js"></script>
  </body>
</html>
html {
  font-size: 62.5%;
}

a {
  color: #333;
  text-decoration: none;
}

*, *::before, *::after {
  box-sizing: border-box;
}

body {
  font-family: Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  margin: 0px;
  background: url(../img/ocean.jpg) no-repeat fixed;
  background-size: cover;
  padding-bottom: 30px;
}

h1, h2, h3, h4, h5, h6 {
  margin: 0px;
}

.header {
  display: flex;
  justify-content: space-between;
  height: 70px;
  width: 100%;
  background-color: #333;
  position: fixed;
  z-index: 5;
}

.header-left {
  line-height: 70px;
  font-size: 1.5rem;
  color: #fff;
  margin-left: 20px;
  font-family: "Redressed";
  letter-spacing: 1px;
  cursor: pointer;
}

.header-right {
  display: flex;
}

.header-right-li {
  text-align: center;
  list-style-type: none;
  color: #fff;
  height: 70px;
  margin: 0 30px;
}
.header-right-li a {
  font-weight: bold;
  font-size: 1.2rem;
  color: #fff;
  display: block;
  height: 100%;
  padding: 0px 2px;
  line-height: 70px;
  transition: 0.15s;
}
.header-right-li a:hover {
  background-color: #fff;
  color: #333;
}

.skills {
  width: 80%;
  margin: 0 auto;
  background-color: black;
  padding: 50px 4% 70px;
  padding-top: 70px;
  text-align: center;
  margin-bottom: 150px;
}
.skills h2 {
  font-size: 3rem;
  margin-bottom: 60px;
  color: #fff;
  letter-spacing: 1px;
  background-color: #172C45;
  line-height: 1.5;
}

.skills-wrapper {
  display: flex;
  justify-content: center;
}

.skills-p-1 {
  color: #fff;
  font-size: 1.8rem;
  margin-bottom: 80px;
  letter-spacing: 1px;
}

.skill-icon {
  display: inline-block;
  margin: 0 20px;
  width: 200px;
}

.skill-icon-name {
  color: #fff;
  font-size: 2.3rem;
  letter-spacing: 1px;
  margin-bottom: 15px;
  font-family: "Raleway";
  font-weight: bold;
}

.skill-img {
  height: 120px;
}

.skill-icon:nth-of-type(2) img {
  height: 150px;
}

.skill-icon:nth-of-type(2) {
  position: relative;
  top: -17px;
}

.skill-margin {
  margin-bottom: 10px;
}

.skill-setumei {
  color: #fff;
  font-size: 1.8rem;
  line-height: 1.5;
}

.services {
  text-align: center;
  width: 80%;
  margin: 0 auto;
  margin-bottom: 150px;
  padding-top: 70px;
  margin-top: -70px;
}
.services h2 {
  font-size: 3rem;
  color: #fff;
  line-height: 2.5;
  background-color: rgba(0, 0, 0, 0.7);
  letter-spacing: 1px;
}
.services .services-wrapper {
  display: flex;
  justify-content: center;
  background-color: rgba(255, 255, 255, 0.7);
  padding: 50px 0px;
}
.services .service {
  width: 300px;
  height: 250px;
  background-color: #fff;
  margin: 0 50px;
  padding: 30px 3% 0;
  box-shadow: 5px 5px 15px rgba(0, 0, 0, 0.7);
  border-radius: 4px;
}
.services .service .fas {
  font-size: 4rem;
  display: block;
  margin-bottom: 30px;
  color: orange;
}
.services .service h4 {
  font-size: 2rem;
  margin-bottom: 20px;
}
.services .service p {
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.5;
}
$(function(){

 $("#skills").click(function(){
  var skills = $(this).attr("href");
  var skills_position = $(skills).offset().top();
  $("html,body").animate({"scrollTop":skills_position},"fast");
});
///////////////////////////////////////////////////
$("#services").click(function(){
 var services = $(this).attr("href");
 var services_position = $(services).offset().top();
 $("html,body").animate({"scrollTop":services_position},"fast");
});
////////////////////////////////////////////////
$(window).scroll(function(){
  var service_1_position = $(".services").offset().top;
  if($(window).scrollTop()> service_1_position - 200)
   {$(".service").fadeIn();}
  else{$(".service").fadeOut();}
})
///////////////////////////////////////////////
});
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • yambejp

    2021/04/04 13:36

    動作を確認できるサンプルをどこかに上げて確認できませんか?

    キャンセル

回答 1

check解決した方法

0

https://teratail.com/questions/20357
こちらの質問で解決いたしました ありがとうございました

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

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