Como aumentar a largura modal do bootstrap?


104

eu tentei isso, mas deu errado

aqui está o css

body .modal-ku {
width: 750px;
}

e aqui está o resultado com falha

insira a descrição da imagem aqui


1
no bootstrap, você pode usar modal-sm, modal-lg para tamanhos pequenos e grandes.
Leão, o leão

Você pode compartilhar seu código HTML e CSS específico. Alguns estilos podem estar sendo substituídos
Nikhil Batra

Você pode compartilhar seu código completo? Ou você pode ver este exemplo, neste modelo a largura pode ser alterável. w3schools.com/bootstrap/…
Har devgun

1
@Hardevgun Por favor, explique onde nesse exemplo pode-se alterar o tamanho modal? Isso nada mais é do que um modal simples de demonstração de tamanho fixo.
ProfK

Respostas:


251

Em seu código, para o modal-dialogdiv, adicione outra classe modal-lg:

<div class="modal-dialog modal-lg">

Ou se você quiser centralizar sua caixa de diálogo modal, use:

.modal-ku {
  width: 750px;
  margin: auto;
}

40

A maneira mais fácil pode ser o estilo embutido em modal-dialogdiv:

<div class="modal" id="myModal">
   <div class="modal-dialog" style="width:1250px;">
      <div class="modal-content">
            ...

        </div>
     </div>
 </div>

28
que tal todo o alarido sobre ser responsivo em tudo?
Abhinav Singh

@Abhinav Singh: Você está certo. O valor de px de código fixo não é recomendado. Porcentagem ou Calc é recomendado.
Pensando em

3
responsivo: largura: 100%; largura máxima: 1250 px
clamchoda

15

No meu caso,

  1. Dar uma largura estática ao modal prejudica a capacidade de resposta.
  2. A modal-lgclasse não era grande o suficiente.

então a solução foi

@media (min-width: 1200px) {
   .modal-xlg {
      width: 90%; 
   }
}

e usar a classe acima em vez da modal-lgclasse


Qual aula anterior, por favor?
John Max

@JohnMax, ele significa "usar a classe acima"
Sr. Heelis

8

No Bootstrap 3, você precisa alterar o diálogo modal. Portanto, neste caso, você pode adicionar a classe modal-admin no local onde está o diálogo modal.

@media (min-width: 768px) {
  .modal-dialog {
    width: 600;
    margin: 30px auto;
  }
  .modal-content {
    -webkit-box-shadow: 0 5px 15px rgba(0, 0, 0, .5);
            box-shadow: 0 5px 15px rgba(0, 0, 0, .5);
  }
  .modal-sm {
    width: 300px;
  }
}

8

Você pode escolher entre modal-lge modal-xlclasses ou, se quiser largura personalizada, defina a propriedade max-width com css embutido. Por exemplo,

<div class="modal-dialog modal-xl" role="document">

ou

<div class="modal-dialog" style="max-width: 80%;" role="document">

1
Isso funcionou muito bem @sumod badchhape. Eu removi a classe 'modal-lg' e coloquei a largura máxima: 80% e funcionou !!
Sotiris Zegiannis

5

No Bootstrap, a largura padrão de modal-dialogé 600px. Mas você pode alterar explicitamente sua largura. Por exemplo, se você quiser maximizar sua largura para o valor de sua escolha, 800pxpor exemplo, faça o seguinte:

.modal-dialog {
    width: 800px;
    margin: 30px auto;
}

Nota : Esta mudança define para todos os diálogos modais que você usa em seu aplicativo. Além disso, minha sugestão é que é melhor ter suas próprias regras CSS definidas e não tocar o núcleo da estrutura.

Se você deseja que seja definido apenas para uma caixa de diálogo modal específica, use seu próprio nome de classe atraente, modal-800cuja largura é definida 800pxcomo, da seguinte forma:

HTML

<div class="modal">
   <div class="modal-dialog modal-800">
      <div class="modal-content">

      </div>
   </div>
</div>

CSS

.modal-dialog.modal-800 {
    width: 800px;
    margin: 30px auto;
}

Da mesma forma, você pode ter o nome da classe com base no tamanho da largura, como modal-700cuja largura é700px .

Espero que seja útil!


4

Eu tinha uma grade grande que precisava ser exibida no modal e apenas aplicar a largura no corpo não estava funcionando corretamente, pois a tabela estava transbordando, embora tivesse classes de bootstrap nela. Acabei aplicando a mesma largura em modal-bodye modal-content:

<!--begin::Modal-->
<div class="modal fade" role="dialog" aria-labelledby="" aria-hidden="true">
    <div class="modal-dialog modal-lg modal-dialog-centered" role="document">
        <div class="modal-content" style="width:980px;">
            <div class="modal-header">
                <h5 class="modal-title" id="">Title</h5>
                <button type="button" class="close" data-dismiss="modal" aria-label="Close">
                    <span aria-hidden="true" class="la la-remove"></span>
                </button>
            </div>
            <form class="m-form m-form--fit m-form--label-align-right">
                <div class="modal-body" style="width:980px;">
                </div>
                <div class="modal-footer">
                    <button type="button" class="btn btn-brand m-btn" data-dismiss="modal">Close</button>

                </div>
            </form>
        </div>
    </div>
</div>

<!--end::Modal-->

3

Se você quiser manter o modo responsivo, use% da largura em vez de pixels. Você pode fazer isso in-line (veja abaixo) ou com CSS.

<div class="modal fade" id="phpModal" role="dialog">
            <div class="modal-dialog modal-lg" style="width:80%;">
                <div class="modal-content">
                    <div class="modal-header">
                        <button type="button" class="close" data-dismiss="modal">&times;</button>
                        <h4 class="modal-title">HERE YOU TITLE</h4>
                    </div>
                    <div class="modal-body helpModal phpModal">
                        HERE YOUR CONTENT
                    </div>
                </div>
            </div>
        </div>

Se você usar CSS, você pode até mesmo fazer% diferente para modal-sm e modal-lg.


3

Também enfrentei o mesmo problema ao aumentar a largura do modal, a janela não é exibida no centro. Depois de trabalhar ao redor, encontrei a solução abaixo.

.modal-dialog {
    max-width: 850px;
    margin: 2rem auto;
}

1

Na verdade, você está aplicando CSS em div modal.

você tem que aplicar CSS em .modal-dialog

Por exemplo, consulte o código a seguir.

<div class="modal" id="myModal">
 <div class="modal-dialog" style="width:xxxpx;"> <!-- Set width of div which you want -->
      <div class="modal-content">
           Lorem Ipsum some text...content 

        </div>
     </div>
 </div>

O bootstrap também fornece classes para definir a largura div.

Para pequeno uso modal modal-sm

E para grande modal modal-lg


1

A maneira mais simples de fazer isso é:

$(".modal-dialog").css("width", "80%");

onde podemos especificar a largura do modal em termos de porcentagem da tela.

Aqui está um exemplo prático para demonstrar o mesmo:

<!DOCTYPE html>
<html lang="en">
<head>
  <title>Bootstrap Example</title>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width, initial-scale=1">
  <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.4.1/css/bootstrap.min.css">
  <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
  <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.4.1/js/bootstrap.min.js"></script>
  <script type="text/javascript">
  $(document).ready(function () {
  		$(".modal-dialog").css("width", "90%");
  });
  </script>
</head>
<body>

<div class="container">
  <h2>Modal Example</h2>
  <!-- Trigger the modal with a button -->
  <button type="button" class="btn btn-info btn-lg" data-toggle="modal" data-target="#myModal">Open Modal</button>

  <!-- Modal -->
  <div class="modal fade" id="myModal" role="dialog">
    <div class="modal-dialog">
    
      <!-- Modal content-->
      <div class="modal-content">
        <div class="modal-header">
          <button type="button" class="close" data-dismiss="modal">&times;</button>
          <h4 class="modal-title">Modal Header</h4>
        </div>
        <div class="modal-body">
          <p>Some text in the modal.</p>
        </div>
        <div class="modal-footer">
          <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
        </div>
      </div>
      
    </div>
  </div>
  
</div>

</body>
</html>


1

Em seu código, para o div de diálogo modal, adicione outra classe, modal-lg:

usar modal-xl


1
não copie a resposta dos outros
Rai Talha Rehman Khan

0

Suponho que isso aconteça devido ao max-width de um modal sendo definido como 500px e max-width do modal-lg é 800px. Suponho que defini-lo como automático tornará seu modal responsivo


-2
.your_modal {
    width: 800px;
    margin-left: -400px; 
 }

o valor da margem esquerda é a metade da largura do modal. Estou usando isso com o tema Maruti Admin, pois não tem classe.modal-lg .modal-sm

Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.