現在PCサイトにおいて多階層のドロップダウンメニューのスマホ対応を、jQueryプラグインを使うことによって実装致しました。
しかし一つ問題があるのですが、スマホ化した際に、liの親要素は全てリンクがヌルリンクになり、タッチして下の階層が開ける仕様になっているため、PCの方ではコンテンツのあるメニューの一部が開けなくなってしまいました。
他のプラグインやbootsstrap等の例も見たのですが、やはりスマホでは親要素はクリックできるようになっているため、ヌルリンクになっているようです。
メニューの構成自体を変えた方が良いのでしょうか?それとも他に実装できる方法があれば、解説サイトのリンクだけでも良いのでご教示お願い致します。
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
jqueryではなく普通にCSSだけでよいのでは??
スマホはHTML5,CSS3に対応していますので・・
そのプルダウンメニューのソースを提示してください。
<header>
・・・
<nav>
<ul>
<li><a href="/">Top</a></li>
<li><a href="/Products">Products</a>
<ul>
<li><a href="/Products/a.html">製品A</a></li>
<li><a href="/Products/b.html">製品B</a></li>
<li><a href="/Products/c.html">製品C</a></li>
</ul>
</li>
<li><a href="/Manual">Manual</a>
<ul>
<li><a href="/Manual/a.html">説明A</a></li>
<li><a href="/Manual/b.html">説明B</a></li>
<li><a href="/Manual/c.html">説明C</a></li>
</ul>
</li>
<li><a href="/ContactUs">ContautUs</a>
</li>
</ul>
</nav>
</header>
<!-- header,navはHTML4などでは、div class="header"のようになります。 -->
そのうえで、
・ニ階層目のリストは隠しておいて
・focusまたはhoverの時に二階層目が開くようにする。
>タッチして下の階層が開ける仕様になっているため、
この意味が分からないのですか、タップではなくタッチですか??タップ/クリックだとリンク先に飛んでしまうので、hocus,hoverでないとまずい気がしますが???
jqueryではなく、スタイルシートを使うほうが良いでしょう。スタイルシートでリキッドでデザインし、それ以上のことがしたければmediaqueryでスタイル自体を変更できますからね。
HTMLをデザイン目的で書いたら、それに制約されてメディアごとにデザインを変える事を始め何もできなくなります。HTMLには文書構造しか書かない。そのための
『文書の構造をプレゼンテーションと切り離すことで広汎なプラットフォームや多様なメディアでの文書提供コストを低下でき、文書の改訂も容易になる---2.4.1 構造とプレゼンテーションの分離( http://www.asahi-net.or.jp/%7Esd5a-ucd/rec-html4 … )』
ですから・・
この回答への補足
回答ありがとうございます。
プルダウンメニューは仰る通りhtml5とcss3だけで実装していて、サンプルで書かれているようなhtmlです。
jQueryは、スマホ化したときにアコーディオンにするために使いました。
メニューが20以上もあるので、スマホ化した時に、画面いっぱいにメニューが開いているのはよくないと思うのです。
多階層のドロップダウンメニューをスマホでアコーディオン化したものは、やはりいろんなサンプルを見ても、アコーディオンの親要素をタップして下の階層を開く仕様なので、ヌルリンクなのだと思います。
今まで多階層でないドロップダウンのアコーディオン化しかしたことがなかったので、そのことに気づきませんでした。
スマホ化してもスマートに見えるには、どのような実現方法がいいのでしょうか?
すみません、お礼と補足が前後いたしましたが、
もう一つ補足です。
書いて頂いたサンプルと異なる部分があります。
<nav>
<ul>
<li><a href="/">Top</a></li>
<li><a href="/Products.html">Products</a>
<ul>
<li><a href="/Products/a.html">製品A</a></li>
<li><a href="/Products/b.html">製品B</a></li>
<li><a href="/Products/c.html">製品C</a></li>
</ul>
</li>
<li><a href="/Manual">Manual</a>
<ul>
<li><a href="/Manual/a.html">説明A</a></li>
<li><a href="/Manual/b.html">説明B</a></li>
<li><a href="/Manual/c.html">説明C</a></li>
</ul>
</li>
<li><a href="/ContactUs">ContautUs</a>
</li>
</ul>
</nav>
3階層ある場合、2階層目にもリンク(コンテンツ)があるのです。
やはりこれをアコーディオンにするのは無理ですよね...。
メニューの階層を変更することもできるので、アコーディオンにしたいなら、
構成を練り直した方がいいでしょうか。
補足に書きましたが、20以上もあるメニューがスマホで表示した時に全て表示されているのはコンテンツ重視と言ってもUIが不便だと思うのですがいかがでしょうか。
まだ経験が未熟なのでアドバイス頂ければと思います。
No.1
- 回答日時:
実装の方法以前に、質問者様が実現したいUIはどのようなものなのでしょうか?
ユーザがリンクしたいと思うとリンクになり、ドロップダウンと思うとドロップダウンになるというのだとすると、今のところ難しそうです。(そのうち実現できるようになるかもしれませんが…)
回答有り難うございます。
すみません、順番が前後しましたが、2番目の回答者様の補足に書いたように、
PCサイトのプルダウンメニューはhtml5とcss3だけで実装していて、
jQueryは、スマホ化したときにアコーディオンにするために使いました。
メニューが20以上もあるので、スマホ化した時に、画面いっぱいにメニューが開いているのはよくないと思うのです。
どのようなメニューのスマホ化が適しているのでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「jQuery」アコーディオンメニ...
-
スムーズスクロールとfleXcroll...
-
動画サイトのURLからswfを抜き...
-
FireFoxのjavascriptでonloadで...
-
jqueryで複数のIDをまとめたい...
-
jQueryのeqで最後からn番目以降...
-
オブジェクトがありませんのエラー
-
JS外部ファイル
-
多階層ドロップダウンのスマホ...
-
ネストされたチェックボックス...
-
JQueryで、liタグの背景に色を...
-
jqueryのsortableで一部ソート...
-
MAX関数を使ってからLEFT JOIN...
-
スクロール可能なチェックボックス
-
OpenCVで固定枠で画像を操作す...
-
スワップイメージが上手く動作...
-
JavaScript - 月ごとに画像変化
-
createElementで作成した要素を...
-
HPで写真をクリックすると次の...
-
関数の引数を動的に変えたい
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
jqueryのsortableで一部ソート...
-
jquery ドロップダウンメニュー...
-
JQueryタブのアクティブ アン...
-
jQueryのeqで最後からn番目以降...
-
チェックボックスに入っている...
-
「jQuery」アコーディオンメニ...
-
クリックした<a>タグのみにClas...
-
javascriptでEnterキーをtabキ...
-
【JQuery】アコーディオンの入...
-
タブ切り替えの初期表示について
-
jQueryでネスト構造の<li>がク...
-
どの<li><a> が押されたか判別...
-
大量のチェックボックス状態取...
-
フルスクリーンについて・・・
-
jQueryのhide,showで中の要素が...
-
【jQuery】遅延実行(タイムラ...
-
アコーディオン自動開閉メニュ...
-
jQueryで表示する吹き出しdivの...
-
JqueryFileTree.js でフォルダ...
-
タブ切り替えの初期表示に関して
おすすめ情報