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

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

ただいまの
回答率

88.13%

フェードインアニメーションで要素の位置が取得できない

受付中

回答 1

投稿

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

score 27

フェードインアニメーションを実装するため、.servicesの位置を取得しようとしているのですができません
デベロッパーツールで$(...).offset(...).top is not a functionという表示がされます
https://toriton.link/coding/current_nav/
こちらのサイトを参考にjQueryのコードを書き直してみても同じ状態です

ちなみに、  if($(".services").length()){
var service_opa = $(".services").offset().top();}のlengthとtopの後ろの()を消すとこのエラー文は消えます 理由はわかりません

<!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;
}
.visible{
  opacity:1;
}
.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;
opacity:0;
}
.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(){
  if($(".services").length()){
  var service_opa = $(".services").offset().top();}
  if ($(window).scrollTop()>service_opa){
  $(".service").addClass("visible");
  }
  else{$("service").removeClass("visible")};
});
///////////////////////////////////////////////
});
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

+1

いろいろ間違いがあるので、diff で -と+の違いをみてください。

$(window).scroll(function(){
-  if($(".services").length()){
+  if($(".services").length){
-  var service_opa = $(".services").offset().top();}
+  var service_opa = $(".services").offset().top;}
  if ($(window).scrollTop()>service_opa){
  $(".service").addClass("visible");
  }
-  else{$("service").removeClass("visible")};
+  else{$(".service").removeClass("visible")};
});

あと、CSSを詳細度の関係で、visibleクラスのセレクターが効いてません。

詳細度を上げるか、

.services .service.visible{
  opacity:1;
}

!important を付けるかしてください。

.visible {
  opacity: 1 !important;
}

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2021/04/08 12:30

    ありがとうございます 無事動くようになりました 

    jQueryのlengthメソッドとtopメソッドの()を消したら動くようになった理由について
    ご存じでしたら教えていただけますでしょうか
    調べてみても全く情報が出てこなくて.....

    キャンセル

  • 2021/04/08 13:15

    lengthはメソッドではなくプロパティだからです。詳細は下記を参照してください。
    https://www.sejuku.net/blog/34465

    topも同様にプロパティです。offset()は top と leftプロパティを持つオブジェクトを返します。
    https://api.jquery.com/offset/

    キャンセル

  • 2021/04/09 11:11

    メソッドとプロパティを区別を曖昧にしていました
    復習します ありがとうございました!

    キャンセル

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

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

関連した質問

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