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

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

ただいまの
回答率

91.05%

  • JavaScript

    13325questions

    JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

  • WordPress

    5766questions

    WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

  • jQuery

    5623questions

    jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

  • ループ

    44questions

    ループとは、プログラミングにおいて、条件に合致している間、複数回繰り返し実行される箇所や、その制御構造を指します

jsで自動生成するli要素をクラスの有無で入れ子構造にしたい.

解決済

回答 1

投稿

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

yuyauver98

score 6

実現したいこと

jsで自動生成するli要素をクラスの有無で入れ子構造にしたいです。
条件分岐の仕方がうまくいかないのでどなたかご教授願いたいです。よろしくお願いいたします!

目次の自動生成の流れ

1:WordPress投稿画面で[@title1@][@/title1@],[@title2@][@/title2@]を使う
2:single.phpで[@title1@][@/title1@],[@title2@][@/title2@]を任意のhtmlに変換
3:main.jsで.scrollTitleが.borderLeftBottomクラスを持っているのか否かで条件分岐。
trueの場合は、そのままliを出力する。持っていない場合(.scrollTitle.singleH2)の時はli要素にtitle2クラスを付与して出力したいです。

うまくいっていない箇所

b=$(".scrollTitle").eq(a).text();の後の条件分岐の仕方が間違っているのか目次のイメージ通りに出力されないです。。

該当のコードを実行した際の現状の目次

目次(.tosTitle)
margin-leftが入る  ●[@title2@][@/title2@]で囲ったテキスト(.tosUl li.title2)
margin-leftが入る  ●[@title2@][@/title2@]で囲ったテキスト(.tosUl li.title2)
margin-leftが入る  ●[@title2@][@/title2@]で囲ったテキスト(.tosUl li.title2)

margin-leftが入る  ●[@title2@][@/title2@]で囲ったテキスト(.tosUl li.title2)
margin-leftが入る  ●[@title2@][@/title2@]で囲ったテキスト(.tosUl li.title2)
margin-leftが入る  ●[@title2@][@/title2@]で囲ったテキスト(.tosUl li.title2)

目次のイメージです

目次(.tosTitle)
▷[@title1@][@/title1@]で囲ったテキスト(.tosUl li)
margin-leftが入る  ●[@title2@][@/title2@]で囲ったテキスト(.tosUl li.title2)
margin-leftが入る  ●[@title2@][@/title2@]で囲ったテキスト(.tosUl li.title2)
margin-leftが入る  ●[@title2@][@/title2@]で囲ったテキスト(.tosUl li.title2)

▷[@title1@][@/title1@]で囲ったテキスト(.tosUl li)
margin-leftが入る  ●[@title2@][@/title2@]で囲ったテキスト(.tosUl li.title2)
margin-leftが入る  ●[@title2@][@/title2@]で囲ったテキスト(.tosUl li.title2)
margin-leftが入る  ●[@title2@][@/title2@]で囲ったテキスト(.tosUl li.title2)

該当のコード

●main.js

$(function(){
    'use strict';
    if ($('.scrollTitle').length) {
        var b;
        $('.tosUl').css('display', 'block');
        $(".scrollTitle").each(function(a){
            $(".scrollTitle").eq(a).attr('id', 'scrollTitle'+(a+1));
            b=$(".scrollTitle").eq(a).text();

            if ($(".scrollTitle.borderLeftBottom").length) {
                $('.tosUl').append("<li onclick='singleScroll("+(a+1)+")'>"+b+"</li>")
            } else {
                $('.tosUl').append("<li onclick='singleScroll("+(a+1)+")' class='title2'>"+b+"</li>")
            } 

        })
    }
})

function singleScroll(b)
   {
   'use strict';
   var a;
   if($(window).width()<960)
       {
       a=$("#scrollTitle"+b).offset().top-51
   }
   else
       {
       a=$("#scrollTitle"+b).offset().top
   }
    $("html, body").animate(
       {
       scrollTop:a
   }
   )
}


●single.php

 <ul class="tosUl">
                    <li class="tosTitle">目次</li>
 </ul>
                    <?php
                        $postItem = str_replace("[@text@]", "<p>", get_field('postItem'));
                        $postItem = str_replace('[@/text@]', '</p>', $postItem);
                        $postItem = str_replace('[@colorBold@]', '<span class="greenBold">', $postItem);
                        $postItem = str_replace('[@/colorBold@]', '</span>', $postItem);
                        $postItem = str_replace('[@title1@]', '<h2 class="borderLeftBottom scrollTitle">', $postItem);
                        $postItem = str_replace('[@/title1@]', '</h2>', $postItem);
                        $postItem = str_replace('[@title2@]', '<h2 class="singleH2 scrollTitle">', $postItem);
                        $postItem = str_replace('[@/title2@]', '</h2>', $postItem);
                        $postItem = str_replace('[@title3@]', '<h3 class="singleH3">', $postItem);
                        $postItem = str_replace('[@/title3@]', '</h3>', $postItem);
                        $postItem = str_replace('[@pickup@]', '<p class="pickupTitle"><i class="fa fa-sticky-note-o" aria-hidden="true"></i> ピックアップ記事</p> <div class="pickupContent">', $postItem);
                        $postItem = str_replace('[@/pickup@]', '</div>', $postItem);
                        echo $postItem;
                    ?>


●single.css

.singleH2 {
    border-left: 6px solid #7CBFA3;
    margin-top: 20px;
    padding: 10px;
}
.tosUl {
    margin-bottom: 30px;
    padding: 10px;
    border: 1px solid #dedede;
    display: none;
}

.tosUl li {
    padding: 8px 0;
    -webkit-transition: .2s;
    transition: .2s;
}

.tosUl li:before {
    content: " ▶︎ ";
    color: rgba(140, 199, 175, 0.9);
}

.tosUl li:not(:first-child):hover {
    text-decoration: underline;
    cursor: pointer;
}
.title2 {
  margin-left: 16px;
}
.tosUl li.title2:before {
    content: "●";
}
.tosTitle {
    padding: 0 0 10px 0 !important;
    border-bottom: 1px solid #dedede;
}

.tosTitle:before {
    content: "" !important;
}

前提情報

WordPress
カスタムフィールド $postItem

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

check解決した方法

0

解決いたしました。
条件分岐のやり方が間違っていました。

$(function(){
    'use strict';
    if ($('.scrollTitle').length) {
        var b;
        $('.tosUl').css('display', 'block');
        $(".scrollTitle").each(function(a){
            $(".scrollTitle").eq(a).attr('id', 'scrollTitle'+(a+1));
            b=$(".scrollTitle").eq(a).text();
            if ($(this).hasClass('singleH2')) {
                 $('.tosUl').append("<li onclick='singleScroll("+(a+1)+")' class='title2'>"+b+"</li>")
            } else {
                 $('.tosUl').append("<li onclick='singleScroll("+(a+1)+")'>"+b+"</li>")
            }

        })
    }
})

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

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

関連した質問

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

  • JavaScript

    13325questions

    JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

  • WordPress

    5766questions

    WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

  • jQuery

    5623questions

    jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

  • ループ

    44questions

    ループとは、プログラミングにおいて、条件に合致している間、複数回繰り返し実行される箇所や、その制御構造を指します