美文网首页
用bootstrap3 做个模态框

用bootstrap3 做个模态框

作者: 金发萌音 | 来源:发表于2014-11-22 13:23 被阅读1207次

    我们经常在网页上使用模态框这一元素

    使用起来的效果如下

    点击一个连接或按钮后弹出一个新的“网页”

    使用bootstrap3可以方便快速的创建这一效果

    比如我的这个登录框的代码

        <!--登录莫泰框-->
        <div class="modal fade" id="signin" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
          <div class="modal-dialog">
            <div class="modal-content">
              <div class="modal-header">
                <button type="button" class="close"
                        data-dismiss="modal" aria-hidden="true">
                  &times;
                </button>
                <h4 class="modal-title" id="myModalLabel">
                  登录到先声文库
                </h4>
              </div>
              <div class="modal-body">
                <from class="form-horizontal"  role="form" action="#">
                  <div class="form-group">
                    <label for="usernameinputsign" class="col-sm-2 control-label">账号</label>
                    <div class="col-sm-8">
                      <input type="text" class="form-control" id="usernameinputsign" placeholder="请输入账号">
                    </div>
                  </div>
                  <div class="form-group">
                    <label for="passwordinputsign" class="col-sm-2 control-label">密码</label>
                    <div class="col-sm-8">
                      <input type="text" class="form-control" id="passwordinputsign" placeholder="请输入密码">
                    </div>
                  </div>
                </from>
              </div>
              <div class="modal-footer">
                <button type="button" class="btn btn-default"
                        data-dismiss="modal">关闭
                </button>
                <input  type="submit" class="btn btn-primary">
                </button>
              </div>
            </div>
          </div><!-- /.modal-content -->
        </div><!-- /.modal -->
    
    

    注意

    1

    千万不要在一个模态框上重叠另一个模态框。要想同时支持多个模态框,需要自己写额外的代码来实现。
    模态框的 HTML 代码放置的位置

    2

    务必将模态框的 HTML 代码放在文档的最高层级内(也就是说,尽量作为 body 标签的直接子元素),以避免其他组件影响模态框的展现和/或功能。

    class="modal fade"

    这个类说明这是一个模态框,且出现、关闭时带有动画效果
    不想要动画效果可以去除fade类

    <div class="modal-dialog">

    在这一层中增加类modal-lgmodal-sm可以控制模态框的大小
    比如我要在模态框中显示pdf 就需要用大的模态框了

    QQ截图20141122131412.png

    代码

        <div class="modal fade" id="showpdf" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true">
          <div class="modal-dialog modal-lg">
            <div class="modal-content">
              <div class="modal-header">
                <button type="button" class="close"
                        data-dismiss="modal" aria-hidden="true">
                  &times;
                </button>
                <h4 class="modal-title" >
                  {{你的标题}}
                </h4>
              </div>
              <div id="pdf">It appears you don't have Adobe Reader or PDF support in this web browser. <a href="/pdf/sample.pdf">Click here to download the PDF</a></div>
              <div class="modal-footer">
                <button type="button" class="btn btn-default"
                        data-dismiss="modal">关闭
                </button>
                <button id="download" type="submit" class="btn btn-primary">点击下载
                </button>
              </div>
            </div>
          </div><!-- /.modal-content -->
        </div><!-- /.modal -->
    

    <div class="modal-header"> 和<div class="modal-footer">

    可以为模态框增加头和脚 效果如图

    显示模态框

    可以为控制元素如<button><a>添加
    data-toggle="modal" data-target="#register"属性来控制模态框的显示

    比如这样的代码将显示 id为register的模态框
    <a data-toggle="modal" data-target="#register" >注册</a>

    或者也可以写成
    <a data-toggle="modal" href="#register" >注册</a>

    当然也可以通过js来调用

    模态框的事件

    Bootstrap 的模态框类提供了一些事件用于监听并执行你自己的代码。
    
    事件类型    描述
    show.bs.modal   show 方法调用之后立即触发该事件。如果是通过点击某个作为触发器的元素,则此元素可以通过事件的 relatedTarget 属性进行访问。
    shown.bs.modal  此事件在模态框已经显示出来(并且同时在 CSS 过渡效果完成)之后被触发。如果是通过点击某个作为触发器的元素,则此元素可以通过事件的 relatedTarget 属性进行访问。
    hide.bs.modal   hide 方法调用之后立即触发该事件。
    hidden.bs.modal 此事件在模态框被隐藏(并且同时在 CSS 过渡效果完成)之后被触发。
    loaded.bs.modal 从远端的数据源加载完数据之后触发该事件。
    
    
    $('#myModal').on('hidden.bs.modal', function (e) {
      // do something...
    })
    

    相关文章

      网友评论

          本文标题: 用bootstrap3 做个模态框

          本文链接:https://www.haomeiwen.com/subject/iqkwtttx.html