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

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

ただいまの
回答率

87.59%

left: 100%; がはみ出さないようにしたい。

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 1,374
退会済みユーザー

退会済みユーザー

JQuery初心者です。
ランダムな位置に吹き出しが表示される、というプログラムを作っています。
このコードには問題があり、たとえば、.fukidashiがleft: 100%;top: 100%となった場合、要素が画面からはみ出してしまいます。
left: 100%;top: 100%;がはみ出さず、ちょうど画面の右端に来るようないいアイデアはないでしょうか。
出来れば、幅を変えても対応できるようにしてほしいです。

<div id="chat">
  <!-- PHPで複製(30個ほど) -->
  <div class="fukidashi"><!-- 略 --></div>
  <div class="fukidashi"><!-- 略 --></div>
</div>
#chat{
  width: 100%;
  height: 100%;
}
.fukidashi{
  position: absolute;
}
/*
画面もwidth,height100%です。
吹き出しの幅は200pxに設定しています。
*/
$(document).ready(function(){
  $('#chat .fukidashi').each(
    function(randompos){
       var left = Math.floor(Math.random() * 100);
       var top = Math.floor(Math.random() * 100);
       $(this).css('left',left + '%');
       $(this).css('top',top + '%');
    }
  )
});
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

checkベストアンサー

+1

position: relative; が #chat にあるものとして

#chat {
  position: relative;
  width: auto;
  margin-right: 200px;
}

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

+1

widthの幅は、ボックスモデルで言うcontentのみにかかる数値です。
ですので、chatより上の要素でmarginやpaddingが指定されていた場合は
その分はみ出してしまいます。
chat要素に対して
box-sizing:border-box
↑これをcssプロパティにつけてあげてみてください。

http://www.htmq.com/css3/box-sizing.shtml
一応参照URL置いておきます

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/03/27 16:21

    解答ありがとうございます。
    質問ですが、padding: 0; margin: 0; でも要素の幅ちょうど一個分はみ出てしまいます。
    (要素の左端がウィンドウの右端に来る)
    この場合の対応策はないでしょうか。

    キャンセル

  • 2019/03/27 17:03

    すみません、見落としていました。
    left:100%であれば要素の開始位置が100%なのではみ出ますね。
    .fukidashiの出現位置(leftとか)を算出しているプログラムを修正できるのであれば
    calcを使用するのが良いと思います。
    left:calc(100% - 200px)これで恐らく正しく右端に収まるはずです。
    calcの意味や使い方は調べてみてください。

    キャンセル

  • 2019/03/27 19:02

    そうすると0%の時に左にはみ出て難しいものです。

    キャンセル

  • 2019/03/27 19:15

    解決しました。
    calcはheightの方に利用させていただきました。
    ありがとうございました。

    キャンセル

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

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

関連した質問

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