ナビゲーションに子メニューを設定すると付与される「.item-has-children」というクラスが付いている場合に、親のメニューのaタグをdivにしてます。
基本的な事がよく分かっておらず、下記コードをもう少しスマートに書けないか(若しくは短縮)ご教授いただけませんでしょうか。
javascript
1(function($) { 2 if($('#gNavi').children().hasClass('menu-item-has-children')){ 3 var treeMenu1 = $('#item123.item-has-children > a'); 4 var treeMenu2 = $('#item002.item-has-children > a'); 5 $(treeMenu1).replaceWith(function() { 6 $(this).replaceWith('<div>'+$(this).html()+'</div>'); 7 }) 8 $(treeMenu2).replaceWith(function() { 9 $(this).replaceWith('<div>'+$(this).html()+'</div>'); 10 }) 11 } 12})(jQuery);
追記
「#item123」と「#item002」のIDを持つ2つのメニューのみが対象です。
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
回答4件
0
ベストアンサー
こんなところでしょうか。
HTML
1<ul id="gNavi"> 2 <li id="item002" class="menu-item-has-children"><a href="#product002">item002</a></li> 3 <li id="item123" class="menu-item-has-children"><a href="#product123">item123</a></li> 4</ul> 5<script> 6'use strict'; 7(function ($) { 8 if ($('#gNavi>.menu-item-has-children').length) { 9 $('#item123>a,#item002>a').replaceWith(function () { // id 属性値は一意の為、.item-has-children の条件を削除 10 return $('<div></div>').append(this.childNodes); // .html() で書き換えると addEventListener を代表とするDOM参照する機能が全て解除される(新しく参照が作られる為)ので既存のDOMノードを append() するように 11 }); 12 } 13}(jQuery)); 14</script>
(2015/12/16 12:31追記) wrapInner()
では期待通りには動作しないという指摘を頂き、wrap()
に修正しました。
(2015/12/16 14:57追記) 更に間違っていたので、replaceWith()
に修正しました。
投稿2015/12/16 03:20
編集2015/12/16 06:12総合スコア18162
0
面白そうなので参加します。
HTML が見えないのでいろいろエスパーしていますが、これで行けるのではないかと。
javascript
1$("#item123, #item002") 2 .filter(".item-has-children") 3 .find("a") 4 .wrapInner("<div/>") 5 .children("div") 6 .unwrap();
よくわかっていないとのことで、(function($){ }(jQuery));
も消しています。
もしどこかからコピペして紛れ込んでしまっただけなら、本来不要なコードです。
(実際に必要で書かれていたらすみません。)
これはjQuery
の短縮名$
がグローバル変数で使えないときにのみ有効なもので、詳しくはこちらを。
投稿2015/12/16 05:02
総合スコア790
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2015/12/16 08:47
2015/12/16 09:25
2015/12/16 10:25
2015/12/16 12:06 編集
2015/12/18 15:23
0
javascript
1(function($) { 2 if ($('#gNavi').children().hasClass('menu-item-has-children')) { 3 $('#item123.item-has-children,#item002.item-has-children').children('a').each(function() { 4 $(this).replaceWith('<div>' + $(this).html() + '</div>'); 5 }); 6 } 7})(jQuery);
投稿2015/12/16 03:17
総合スコア736
0
こんにちは。
一部ファンクションにしてみましたが、こんな感じでいかがでしょうか?
動けばいいのですが・・・
javascript
1 2(function($) { 3 function replace(elm){ 4 $(elm + ".item-has-children > a").replaceWith(function() { 5 $(this).replaceWith('<div>'+$(this).html()+'</div>'); 6 }); 7 } 8 9 if($('#gNavi').children().hasClass('menu-item-has-children')){ 10 replace('#item123'); 11 replace('#item002'); 12 } 13})(jQuery); 14
投稿2015/12/16 03:04
総合スコア295
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2015/12/16 03:23
2015/12/16 03:33
2015/12/16 05:16
2015/12/16 05:59
2015/12/18 15:18