teratail header banner
teratail header banner
質問するログイン新規登録

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

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

新規登録して質問してみよう
ただいま回答率
85.30%
jQuery

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

Q&A

解決済

1回答

1518閲覧

visualViewport.height キーボードの高さを引いたwindowの高さを取得したい

yukarichang

総合スコア14

jQuery

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

0グッド

0クリップ

投稿2023/04/27 03:22

編集2023/04/27 07:11

0

0

実現したいこと

キーボードの高さを引いたwindowの高さを取得したいです。visualViewport.heightを使えば取得できるようなので下記のコードを書いたのですが、キーボードの高さを引いていない全体のwindowの高さしか取得できず、助言を頂きたいです。

該当のソースコード

.oneにキーボードの高さを引いていないwindowの高さを表示、
入力欄(input)を押してキーボードが表示されると.twoにキーボードの高さを引いたwindowの高さを表示させたいです。

html

1 <input type="text"> 2 <span class="one"></span> 3 <span class="two"></span>

jQuery

1 var window_height = $(window).height(); 2 var keyboard_height = visualViewport.height; 3 $('.one').text(window_height); 4 $('.two').text(keyboard_height);

動作確認端末

iphone11
iOS 16.3.1
safari バージョン16.3.1
chrome バージョン112.0.5615.167

参考リンク

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

int32_t

2023/04/27 05:56 編集

質問文の JavaScript コードをどういうタイミングで実行しましたか? また、動作を確認した OS とブラウザのバージョンなども書いたほうがいいかもしれません。
yukarichang

2023/04/27 07:12

コメントありがとうございます。特にタイミングは指定しておらず、htmlファイルのbody閉じタグの直前に書いています。
guest

回答1

0

ベストアンサー

質問文の JavaScript コードをどういうタイミングで実行しましたか?
body閉じタグの直前に書いています。

それではキーボードが出現したときに情報が更新されないですね。

resize イベントがあるらしいので、以下のような感じでどうでしょうか。

js

1const vp = window.visualViewport; 2function showSize() { 3 $('.one').text($(window).height()); 4 $('.two').text(vp.height); 5} 6vp.addEventListener('resize', showSize); 7showSize();

投稿2023/04/27 07:19

int32_t

総合スコア21929

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yukarichang

2023/04/27 08:47

ありがとうございます。頂いたコードで無事に取得できたので、なぜ動くのかをよく勉強したいと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.30%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問